2020-10-27 11:27:17 +01:00
|
|
|
'use strict';
|
|
|
|
|
2019-05-14 12:41:17 +02:00
|
|
|
// Test a simple default API with no relations
|
|
|
|
|
2021-04-29 11:11:46 +02:00
|
|
|
const { createStrapiInstance } = require('../../../../test/helpers/strapi');
|
|
|
|
const { createAuthRequest } = require('../../../../test/helpers/request');
|
2019-05-14 12:41:17 +02:00
|
|
|
|
2020-11-17 15:38:41 +01:00
|
|
|
let strapi;
|
2019-05-14 12:41:17 +02:00
|
|
|
let rq;
|
|
|
|
let data = {};
|
|
|
|
let internals = {
|
|
|
|
user: {
|
|
|
|
username: 'User 1',
|
|
|
|
email: 'user1@strapi.io',
|
|
|
|
password: 'test1234',
|
|
|
|
},
|
|
|
|
role: {
|
|
|
|
name: 'Test Role',
|
|
|
|
description: 'Some random test role',
|
|
|
|
},
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Utils for this test files
|
|
|
|
*/
|
|
|
|
const createTestUser = () =>
|
|
|
|
rq({
|
|
|
|
method: 'POST',
|
|
|
|
url: '/auth/local/register',
|
|
|
|
body: internals.user,
|
|
|
|
});
|
|
|
|
|
|
|
|
const deleteTestUser = () =>
|
|
|
|
rq({
|
|
|
|
method: 'DELETE',
|
|
|
|
url: `/users/${data.user.id}`,
|
|
|
|
});
|
|
|
|
|
|
|
|
/*****************************
|
|
|
|
* TESTS
|
|
|
|
*****************************/
|
|
|
|
describe('Roles API', () => {
|
|
|
|
beforeAll(async () => {
|
2020-11-30 20:20:36 +01:00
|
|
|
strapi = await createStrapiInstance();
|
2020-11-17 15:38:41 +01:00
|
|
|
rq = await createAuthRequest({ strapi });
|
2019-05-14 12:41:17 +02:00
|
|
|
|
|
|
|
const res = await createTestUser();
|
|
|
|
data.user = res.body.user;
|
2021-03-26 20:15:38 +01:00
|
|
|
});
|
2019-05-14 12:41:17 +02:00
|
|
|
|
2020-11-17 15:38:41 +01:00
|
|
|
afterAll(async () => {
|
|
|
|
await deleteTestUser();
|
|
|
|
await strapi.destroy();
|
|
|
|
});
|
2019-05-14 12:41:17 +02:00
|
|
|
|
|
|
|
test('Create Role', async () => {
|
|
|
|
const res = await rq({
|
|
|
|
method: 'POST',
|
|
|
|
url: '/users-permissions/roles',
|
|
|
|
body: {
|
|
|
|
...internals.role,
|
|
|
|
permissions: [],
|
|
|
|
users: [data.user],
|
|
|
|
},
|
|
|
|
});
|
|
|
|
|
|
|
|
expect(res.statusCode).toBe(200);
|
|
|
|
expect(res.body).toMatchObject({ ok: true });
|
|
|
|
});
|
|
|
|
|
|
|
|
test('List Roles', async () => {
|
|
|
|
const res = await rq({
|
|
|
|
method: 'GET',
|
|
|
|
url: '/users-permissions/roles',
|
|
|
|
});
|
|
|
|
|
|
|
|
expect(res.statusCode).toBe(200);
|
|
|
|
expect(res.body.roles).toEqual(
|
|
|
|
expect.arrayContaining([expect.objectContaining(internals.role)])
|
|
|
|
);
|
|
|
|
|
|
|
|
data.role = res.body.roles.find(r => r.name === internals.role.name);
|
|
|
|
});
|
|
|
|
|
|
|
|
test('Delete Role', async () => {
|
|
|
|
const res = await rq({
|
|
|
|
method: 'DELETE',
|
|
|
|
url: `/users-permissions/roles/${data.role.id}`,
|
|
|
|
});
|
|
|
|
|
|
|
|
expect(res.statusCode).toBe(200);
|
|
|
|
});
|
|
|
|
});
|