strapi/packages/core/admin/server/tests/admin-user.test.api.js

407 lines
10 KiB
JavaScript
Raw Normal View History

'use strict';
const { omit } = require('lodash/fp');
2021-08-02 17:54:49 +02:00
const { createStrapiInstance } = require('../../../../../test/helpers/strapi');
const { createAuthRequest } = require('../../../../../test/helpers/request');
const { createUtils } = require('../../../../../test/helpers/utils');
const edition = process.env.STRAPI_DISABLE_EE === 'true' ? 'CE' : 'EE';
const omitTimestamps = omit(['updatedAt', 'createdAt']);
const omitRegistrationToken = omit(['registrationToken']);
2020-06-04 12:34:22 +02:00
/**
* == Test Suite Overview ==
*
* N° Description
* -------------------------------------------
* 1. Creates a user (wrong body)
* 2. Creates a user (successfully)
* 3. Creates users with superAdmin role (success)
* 4. Updates a user (wrong body)
* 5. Updates a user (successfully)
* 6. Finds a user (successfully)
* 7. Finds a list of users (contains user)
* 8. Deletes a user (successfully)
* 9. Deletes a user (not found)
* 10. Deletes 2 super admin users (successfully)
* 11. Deletes a super admin user (successfully)
* 12. Deletes last super admin user (bad request)
* 13. Deletes last super admin user in batch (bad request)
* 14. Updates a user (not found)
* 15. Finds a user (not found)
* 16. Finds a list of users (missing user)
*/
describe('Admin User CRUD (e2e)', () => {
let rq;
let utils;
let strapi;
// Local test data used across the test suite
2022-08-08 15:50:34 +02:00
const testData = {
firstSuperAdminUser: undefined,
otherSuperAdminUsers: [],
user: undefined,
role: undefined,
superAdminRole: undefined,
};
const createUserRole = async () =>
utils.createRole({
name: 'user_test_role',
description: 'Only used for user crud test (e2e)',
});
// Initialization Actions
beforeAll(async () => {
strapi = await createStrapiInstance();
rq = await createAuthRequest({ strapi });
utils = createUtils(strapi);
if (edition === 'EE') {
testData.role = await createUserRole();
} else {
testData.role = await utils.getSuperAdminRole();
}
testData.firstSuperAdminUser = rq.getLoggedUser();
testData.superAdminRole = await utils.getSuperAdminRole();
});
// Cleanup actions
afterAll(async () => {
if (edition === 'EE') {
await utils.deleteRolesById([testData.role.id]);
}
await strapi.destroy();
});
test('1. Creates a user (wrong body)', async () => {
const body = {
firstname: 'user_tests-firstname',
lastname: 'user_tests-lastname',
roles: [testData.role.id],
};
const res = await rq({
url: '/admin/users',
method: 'POST',
body,
});
expect(res.statusCode).toBe(400);
expect(res.body).toMatchObject({
2021-10-20 17:30:05 +02:00
data: null,
error: {
details: {
errors: [
{
message: 'email is a required field',
name: 'ValidationError',
path: ['email'],
},
],
},
message: 'email is a required field',
name: 'ValidationError',
status: 400,
},
});
});
test('2. Creates a user (successfully)', async () => {
const body = {
email: 'uSer-tEsTs@strapi-e2e.com', // Tested with a camelCase email address
firstname: 'user_tests-firstname',
lastname: 'user_tests-lastname',
roles: [testData.role.id],
};
const res = await rq({
url: '/admin/users',
method: 'POST',
body,
2021-07-28 15:32:21 +02:00
qs: {
populate: ['roles'],
},
});
expect(res.statusCode).toBe(201);
expect(res.body.data).not.toBeNull();
expect(res.body.data).toHaveProperty('registrationToken');
// Using the created user as an example for the rest of the tests
testData.user = omitRegistrationToken(res.body.data);
});
test('3. Creates users with superAdmin role (success)', async () => {
2022-08-08 23:33:39 +02:00
const getBody = (index) => {
return {
email: `user-tests${index}@strapi-e2e.com`,
firstname: 'user_tests-firstname',
lastname: 'user_tests-lastname',
roles: [testData.superAdminRole.id],
};
};
2022-09-05 16:15:21 +02:00
for (let i = 0; i < 3; i += 1) {
const res = await rq({
url: '/admin/users',
method: 'POST',
body: getBody(i),
});
expect(res.statusCode).toBe(201);
expect(res.body.data).not.toBeNull();
testData.otherSuperAdminUsers.push(omitRegistrationToken(res.body.data));
}
});
test('4. Updates a user (wrong body)', async () => {
const body = {
email: 42,
};
const res = await rq({
url: `/admin/users/${testData.user.id}`,
method: 'PUT',
body,
});
expect(res.statusCode).toBe(400);
expect(res.body).toMatchObject({
2021-10-20 17:30:05 +02:00
data: null,
error: {
details: {
errors: [
{
message: 'email must be a `string` type, but the final value was: `42`.',
name: 'ValidationError',
path: ['email'],
},
],
},
message: 'email must be a `string` type, but the final value was: `42`.',
name: 'ValidationError',
status: 400,
},
});
});
test('5. Updates a user (successfully)', async () => {
const body = {
firstname: 'foobar',
};
const res = await rq({
url: `/admin/users/${testData.user.id}`,
method: 'PUT',
body,
});
expect(res.statusCode).toBe(200);
expect(res.body).not.toBeNull();
2020-06-04 12:34:22 +02:00
expect(omitTimestamps(res.body.data)).toMatchObject({
...omitTimestamps(testData.user),
...body,
});
// Update the local copy of the user
testData.user = res.body.data;
});
test('6. Finds a user (successfully)', async () => {
const res = await rq({
url: `/admin/users/${testData.user.id}`,
method: 'GET',
});
expect(res.statusCode).toBe(200);
expect(res.body.data).toMatchObject(testData.user);
});
describe('7. Finds a list of users (contains user)', () => {
2020-06-04 12:34:22 +02:00
const expectedBodyFormat = () => ({
data: {
pagination: {
page: 1,
pageSize: expect.any(Number),
pageCount: expect.any(Number),
total: expect.any(Number),
},
results: expect.any(Array),
},
});
test('7.1. Using findPage', async () => {
const res = await rq({
url: `/admin/users?email=${testData.user.email}`,
method: 'GET',
});
expect(res.statusCode).toBe(200);
2020-06-04 12:34:22 +02:00
expect(res.body).toMatchObject(expectedBodyFormat());
expect(res.body.data.results).toContainEqual(testData.user);
});
2021-07-28 21:03:32 +02:00
test('7.2. Using search', async () => {
const res = await rq({
url: `/admin/users?_q=${testData.user.email}`,
method: 'GET',
});
expect(res.statusCode).toBe(200);
2020-06-04 12:34:22 +02:00
expect(res.body).toMatchObject(expectedBodyFormat());
expect(res.body.data.results).toContainEqual(testData.user);
});
});
test('8. Deletes a user (successfully)', async () => {
const res = await rq({
url: `/admin/users/${testData.user.id}`,
method: 'DELETE',
});
expect(res.statusCode).toBe(200);
expect(res.body.data).toMatchObject(testData.user);
});
test('9. Deletes a user (not found)', async () => {
const res = await rq({
url: `/admin/users/${testData.user.id}`,
method: 'DELETE',
});
expect(res.statusCode).toBe(404);
});
test('10. Deletes 2 super admin users (successfully)', async () => {
const users = testData.otherSuperAdminUsers.splice(0, 2);
const res = await rq({
url: `/admin/users/batch-delete`,
method: 'POST',
body: {
2022-08-08 23:33:39 +02:00
ids: users.map((u) => u.id),
},
});
expect(res.statusCode).toBe(200);
expect(res.body.data).toMatchObject(users);
});
test('11. Deletes a super admin user (successfully)', async () => {
const user = testData.otherSuperAdminUsers.pop();
const res = await rq({
url: `/admin/users/${user.id}`,
method: 'DELETE',
});
expect(res.statusCode).toBe(200);
expect(res.body.data).toMatchObject(user);
});
test('12. Deletes last super admin user (bad request)', async () => {
const res = await rq({
url: `/admin/users/${testData.firstSuperAdminUser.id}`,
method: 'DELETE',
});
expect(res.statusCode).toBe(400);
expect(res.body).toMatchObject({
2021-10-20 17:30:05 +02:00
data: null,
error: {
details: {},
message: 'You must have at least one user with super admin role.',
name: 'ValidationError',
status: 400,
},
});
});
test('13. Deletes last super admin user in batch (bad request)', async () => {
const res = await rq({
url: `/admin/users/batch-delete`,
method: 'POST',
body: {
ids: [testData.firstSuperAdminUser.id],
},
});
expect(res.statusCode).toBe(400);
expect(res.body).toMatchObject({
2021-10-20 17:30:05 +02:00
data: null,
error: {
details: {},
message: 'You must have at least one user with super admin role.',
name: 'ValidationError',
status: 400,
},
});
});
test('14. Updates a user (not found)', async () => {
const body = {
lastname: 'doe',
};
const res = await rq({
url: `/admin/users/${testData.user.id}`,
method: 'PUT',
body,
});
expect(res.statusCode).toBe(404);
expect(res.body).toMatchObject({
2021-10-20 17:30:05 +02:00
error: {
details: {},
message: 'User does not exist',
name: 'NotFoundError',
status: 404,
},
});
});
test('15. Finds a user (not found)', async () => {
const res = await rq({
url: `/admin/users/${testData.user.id}`,
method: 'GET',
});
expect(res.statusCode).toBe(404);
2020-06-04 12:34:22 +02:00
expect(res.body).toMatchObject({
2021-10-20 17:30:05 +02:00
error: {
details: {},
message: 'User does not exist',
name: 'NotFoundError',
status: 404,
},
2020-06-04 12:34:22 +02:00
});
});
test('16. Finds a list of users (missing user)', async () => {
const res = await rq({
2021-06-29 16:27:35 +02:00
url: `/admin/users`,
method: 'GET',
2021-06-29 16:27:35 +02:00
qs: {
filters: {
email: testData.user.email,
},
},
});
expect(res.statusCode).toBe(200);
expect(res.body.data).toMatchObject({
pagination: {
page: 1,
pageSize: expect.any(Number),
pageCount: expect.any(Number),
total: expect.any(Number),
},
results: expect.any(Array),
});
2020-06-04 12:34:22 +02:00
expect(res.body.data.results).toHaveLength(0);
});
});