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

331 lines
8.5 KiB
JavaScript
Raw Normal View History

'use strict';
const { createStrapiInstance } = require('../../../../../test/helpers/strapi');
const { createAuthRequest } = require('../../../../../test/helpers/request');
/**
* == Test Suite Overview ==
*
* N° Description
* -------------------------------------------
* 1. Fails to creates an api token (missing parameters from the body)
* 2. Fails to creates an api token (invalid `type` in the body)
* 3. Creates an api token (successfully)
* 4. Creates an api token without a description (successfully)
2021-08-27 16:35:34 +02:00
* 5. Creates an api token with trimmed description and name (successfully)
2021-08-27 08:39:08 +02:00
* 6. List all tokens (successfully)
2021-09-02 11:57:53 +02:00
* 7. Deletes a token (successfully)
2021-09-06 15:14:45 +02:00
* 8. Does not return an error if the ressource to delete does not exist
* 9. Retrieves a token (successfully)
2021-09-06 15:14:45 +02:00
* 10. Returns a 404 if the ressource to retrieve does not exist
* 11. Updates a token (successfully)
* 12. Returns a 404 if the ressource to update does not exist
* 13. Fails to creates an api token (missing parameters from the body)
* 14. Fails to creates an api token (invalid `type` in the body)
*/
describe('Admin API Token CRUD (e2e)', () => {
let rq;
let strapi;
2021-09-06 15:14:45 +02:00
const apiTokens = [];
// Initialization Actions
beforeAll(async () => {
strapi = await createStrapiInstance();
rq = await createAuthRequest({ strapi });
});
// Cleanup actions
afterAll(async () => {
await strapi.destroy();
});
test('1. Fails to create an api token (missing parameters from the body)', async () => {
const body = {
name: 'api-token_tests-name',
description: 'api-token_tests-description',
};
const res = await rq({
url: '/admin/api-tokens',
method: 'POST',
body,
});
expect(res.statusCode).toBe(400);
expect(res.body).toMatchObject({
statusCode: 400,
error: 'Bad Request',
message: 'ValidationError',
data: {
type: ['type is a required field'],
},
});
});
test('2. Fails to create an api token (invalid `type` in the body)', async () => {
const body = {
name: 'api-token_tests-name',
description: 'api-token_tests-description',
type: 'invalid-type',
};
const res = await rq({
url: '/admin/api-tokens',
method: 'POST',
body,
});
expect(res.statusCode).toBe(400);
expect(res.body).toMatchObject({
statusCode: 400,
error: 'Bad Request',
message: 'ValidationError',
data: {
type: ['type must be one of the following values: read-only, full-access'],
},
});
});
test('3. Creates an api token (successfully)', async () => {
const body = {
name: 'api-token_tests-name',
description: 'api-token_tests-description',
type: 'read-only',
};
const res = await rq({
url: '/admin/api-tokens',
method: 'POST',
body,
});
expect(res.statusCode).toBe(201);
2021-09-02 10:47:06 +02:00
expect(res.body.data).toStrictEqual({
accessKey: expect.any(String),
name: body.name,
description: body.description,
type: body.type,
id: expect.any(Number),
});
2021-09-06 15:14:45 +02:00
apiTokens.push(res.body.data);
});
test('4. Creates an api token without a description (successfully)', async () => {
const body = {
2021-08-27 08:47:27 +02:00
name: 'api-token_tests-name-without-description',
type: 'full-access',
};
const res = await rq({
url: '/admin/api-tokens',
method: 'POST',
body,
});
expect(res.statusCode).toBe(201);
2021-09-02 10:47:06 +02:00
expect(res.body.data).toStrictEqual({
accessKey: expect.any(String),
name: body.name,
description: '',
type: body.type,
id: expect.any(Number),
});
2021-09-06 15:14:45 +02:00
apiTokens.push(res.body.data);
});
2021-08-27 16:35:34 +02:00
test('5. Creates an api token with trimmed description and name (successfully)', async () => {
const body = {
name: 'api-token_tests-name-with-spaces-at-the-end ',
description: 'api-token_tests-description-with-spaces-at-the-end ',
type: 'read-only',
2021-08-27 16:35:34 +02:00
};
const res = await rq({
url: '/admin/api-tokens',
method: 'POST',
body,
});
expect(res.statusCode).toBe(201);
2021-09-02 10:47:06 +02:00
expect(res.body.data).toStrictEqual({
2021-08-27 16:35:34 +02:00
accessKey: expect.any(String),
name: 'api-token_tests-name-with-spaces-at-the-end',
description: 'api-token_tests-description-with-spaces-at-the-end',
type: body.type,
id: expect.any(Number),
});
2021-09-06 15:14:45 +02:00
apiTokens.push(res.body.data);
2021-08-27 16:35:34 +02:00
});
2021-08-27 08:39:08 +02:00
test('6. List all tokens (successfully)', async () => {
const res = await rq({
url: '/admin/api-tokens',
method: 'GET',
});
expect(res.statusCode).toBe(200);
2021-08-30 14:00:53 +02:00
expect(res.body.data.length).toBe(3);
2021-08-27 08:39:08 +02:00
expect(res.body.data).toStrictEqual([
{
id: expect.any(Number),
name: 'api-token_tests-name',
description: 'api-token_tests-description',
type: 'read-only',
2021-08-27 08:39:08 +02:00
},
{
id: expect.any(Number),
2021-08-30 14:00:53 +02:00
name: 'api-token_tests-name-with-spaces-at-the-end',
description: 'api-token_tests-description-with-spaces-at-the-end',
type: 'read-only',
2021-08-30 14:00:53 +02:00
},
{
id: expect.any(Number),
name: 'api-token_tests-name-without-description',
2021-08-27 08:39:08 +02:00
description: '',
type: 'full-access',
2021-08-27 08:39:08 +02:00
},
]);
});
2021-08-31 15:31:54 +02:00
test('7. Deletes a token (successfully)', async () => {
const res = await rq({
2021-09-06 15:14:45 +02:00
url: `/admin/api-tokens/${apiTokens[2].id}`,
2021-08-31 15:31:54 +02:00
method: 'DELETE',
});
2021-09-02 10:47:06 +02:00
expect(res.statusCode).toBe(200);
expect(res.body.data).toStrictEqual({
2021-09-06 15:14:45 +02:00
name: apiTokens[2].name,
description: apiTokens[2].description,
type: apiTokens[2].type,
id: apiTokens[2].id,
2021-09-02 10:47:06 +02:00
});
2021-08-31 15:31:54 +02:00
});
2021-09-06 15:14:45 +02:00
test('8. Does not return an error if the ressource to delete does not exist', async () => {
2021-08-31 15:31:54 +02:00
const res = await rq({
url: '/admin/api-tokens/42',
method: 'DELETE',
});
2021-09-02 10:47:06 +02:00
expect(res.statusCode).toBe(200);
expect(res.body.data).toBeNull();
2021-08-31 15:31:54 +02:00
});
test('9. Retrieves a token (successfully)', async () => {
const res = await rq({
2021-09-06 15:14:45 +02:00
url: `/admin/api-tokens/${apiTokens[0].id}`,
method: 'GET',
});
expect(res.statusCode).toBe(200);
expect(res.body.data).toStrictEqual({
2021-09-06 15:14:45 +02:00
name: apiTokens[0].name,
description: apiTokens[0].description,
type: apiTokens[0].type,
id: apiTokens[0].id,
});
});
2021-09-06 15:14:45 +02:00
test('10. Returns a 404 if the ressource to retrieve does not exist', async () => {
const res = await rq({
url: '/admin/api-tokens/42',
method: 'GET',
});
expect(res.statusCode).toBe(404);
expect(res.body.data).toBeUndefined();
});
test('11. Updates a token (successfully)', async () => {
const body = {
name: 'api-token_tests-updated-name',
description: 'api-token_tests-description',
type: 'read-only',
};
const res = await rq({
url: `/admin/api-tokens/${apiTokens[0].id}`,
method: 'PUT',
body,
});
expect(res.statusCode).toBe(200);
expect(res.body.data).toStrictEqual({
name: body.name,
description: body.description,
type: body.type,
id: apiTokens[0].id,
});
});
test('12. Returns a 404 if the ressource to update does not exist', async () => {
const body = {
name: 'api-token_tests-updated-name',
description: 'api-token_tests-description',
type: 'read-only',
};
const res = await rq({
url: '/admin/api-tokens/42',
method: 'PUT',
body,
});
expect(res.statusCode).toBe(404);
expect(res.body.data).toBeUndefined();
});
test('13. Fails to update an api token (missing parameters from the body)', async () => {
const body = {
name: 'api-token_tests-updated-name',
description: 'api-token_tests-description',
};
const res = await rq({
url: '/admin/api-tokens/1',
method: 'PUT',
body,
});
expect(res.statusCode).toBe(400);
expect(res.body).toMatchObject({
statusCode: 400,
error: 'Bad Request',
message: 'ValidationError',
data: {
type: ['type is a required field'],
},
});
});
test('14. Fails to update an api token (invalid `type` in the body)', async () => {
const body = {
name: 'api-token_tests-name',
description: 'api-token_tests-description',
type: 'invalid-type',
};
const res = await rq({
url: '/admin/api-tokens/1',
method: 'PUT',
body,
});
expect(res.statusCode).toBe(400);
expect(res.body).toMatchObject({
statusCode: 400,
error: 'Bad Request',
message: 'ValidationError',
data: {
type: ['type must be one of the following values: read-only, full-access'],
},
});
});
});