2021-08-26 14:37:55 +02:00
|
|
|
'use strict';
|
|
|
|
|
|
|
|
const { createStrapiInstance } = require('../../../../../test/helpers/strapi');
|
|
|
|
const { createAuthRequest } = require('../../../../../test/helpers/request');
|
|
|
|
|
|
|
|
/**
|
|
|
|
* == Test Suite Overview ==
|
|
|
|
*
|
|
|
|
* N° Description
|
|
|
|
* -------------------------------------------
|
2021-08-27 16:23:19 +02:00
|
|
|
* 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)
|
|
|
|
* 8. Does not return an error if the ressource does not exist
|
2021-09-02 11:56:14 +02:00
|
|
|
* 9. Retrieves a token (successfully)
|
2021-09-02 14:04:59 +02:00
|
|
|
* 10. Returns a 404 if the ressource does not exist
|
2021-08-26 14:37:55 +02:00
|
|
|
*/
|
|
|
|
|
|
|
|
describe('Admin API Token CRUD (e2e)', () => {
|
|
|
|
let rq;
|
|
|
|
let strapi;
|
|
|
|
|
|
|
|
// Initialization Actions
|
|
|
|
beforeAll(async () => {
|
|
|
|
strapi = await createStrapiInstance();
|
|
|
|
rq = await createAuthRequest({ strapi });
|
|
|
|
});
|
|
|
|
|
|
|
|
// Cleanup actions
|
|
|
|
afterAll(async () => {
|
|
|
|
await strapi.destroy();
|
|
|
|
});
|
|
|
|
|
2021-08-27 16:23:19 +02:00
|
|
|
test('1. Fails to creates an api token (missing parameters from the body)', async () => {
|
2021-08-26 14:37:55 +02:00
|
|
|
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'],
|
|
|
|
},
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2021-08-27 16:23:19 +02:00
|
|
|
test('2. Fails to creates 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: {
|
2021-09-01 09:18:31 +02:00
|
|
|
type: ['type must be one of the following values: read-only, full-access'],
|
2021-08-27 16:23:19 +02:00
|
|
|
},
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
test('3. Creates an api token (successfully)', async () => {
|
2021-08-26 14:37:55 +02:00
|
|
|
const body = {
|
|
|
|
name: 'api-token_tests-name',
|
|
|
|
description: 'api-token_tests-description',
|
2021-09-01 09:18:31 +02:00
|
|
|
type: 'read-only',
|
2021-08-26 14:37:55 +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:23:19 +02:00
|
|
|
accessKey: expect.any(String),
|
|
|
|
name: body.name,
|
|
|
|
description: body.description,
|
|
|
|
type: body.type,
|
|
|
|
id: expect.any(Number),
|
|
|
|
});
|
2021-08-26 14:37:55 +02:00
|
|
|
});
|
|
|
|
|
2021-08-27 16:23:19 +02:00
|
|
|
test('4. Creates an api token without a description (successfully)', async () => {
|
2021-08-26 14:37:55 +02:00
|
|
|
const body = {
|
2021-08-27 08:47:27 +02:00
|
|
|
name: 'api-token_tests-name-without-description',
|
2021-09-01 09:18:31 +02:00
|
|
|
type: 'full-access',
|
2021-08-26 14:37:55 +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:23:19 +02:00
|
|
|
accessKey: expect.any(String),
|
|
|
|
name: body.name,
|
|
|
|
description: '',
|
|
|
|
type: body.type,
|
|
|
|
id: expect.any(Number),
|
|
|
|
});
|
2021-08-26 14:37:55 +02:00
|
|
|
});
|
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 ',
|
2021-09-01 09:18:31 +02:00
|
|
|
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-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',
|
2021-09-01 09:18:31 +02:00
|
|
|
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',
|
2021-09-01 09:18:31 +02:00
|
|
|
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: '',
|
2021-09-01 09:18:31 +02:00
|
|
|
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({
|
|
|
|
url: '/admin/api-tokens/3',
|
|
|
|
method: 'DELETE',
|
|
|
|
});
|
|
|
|
|
2021-09-02 10:47:06 +02:00
|
|
|
expect(res.statusCode).toBe(200);
|
|
|
|
expect(res.body.data).toStrictEqual({
|
|
|
|
name: 'api-token_tests-name-with-spaces-at-the-end',
|
|
|
|
description: 'api-token_tests-description-with-spaces-at-the-end',
|
|
|
|
type: 'read-only',
|
|
|
|
id: 3,
|
|
|
|
});
|
2021-08-31 15:31:54 +02:00
|
|
|
});
|
|
|
|
|
2021-09-02 11:57:53 +02:00
|
|
|
test('8. Does not return an error if the ressource 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
|
|
|
});
|
2021-09-02 11:56:14 +02:00
|
|
|
|
|
|
|
test('9. Retrieves a token (successfully)', async () => {
|
|
|
|
const res = await rq({
|
|
|
|
url: '/admin/api-tokens/1',
|
|
|
|
method: 'GET',
|
|
|
|
});
|
|
|
|
|
|
|
|
expect(res.statusCode).toBe(200);
|
|
|
|
expect(res.body.data).toStrictEqual({
|
|
|
|
name: 'api-token_tests-name',
|
|
|
|
description: 'api-token_tests-description',
|
|
|
|
type: 'read-only',
|
|
|
|
id: 1,
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2021-09-02 14:04:59 +02:00
|
|
|
test('10. Returns a 404 if the ressource does not exist', async () => {
|
2021-09-02 11:56:14 +02:00
|
|
|
const res = await rq({
|
|
|
|
url: '/admin/api-tokens/42',
|
|
|
|
method: 'GET',
|
|
|
|
});
|
|
|
|
|
|
|
|
expect(res.statusCode).toBe(404);
|
|
|
|
expect(res.body.data).toBeUndefined();
|
|
|
|
});
|
2021-08-26 14:37:55 +02:00
|
|
|
});
|