mirror of
https://github.com/strapi/strapi.git
synced 2025-10-24 06:23:40 +00:00
test(ee): add api test for getting available stage transitions
This commit is contained in:
parent
6bb9d68da2
commit
e54d29d7e6
@ -6,7 +6,7 @@ const { mapAsync } = require('@strapi/utils');
|
|||||||
const { createStrapiInstance } = require('api-tests/strapi');
|
const { createStrapiInstance } = require('api-tests/strapi');
|
||||||
const { createAuthRequest, createRequest } = require('api-tests/request');
|
const { createAuthRequest, createRequest } = require('api-tests/request');
|
||||||
const { createTestBuilder } = require('api-tests/builder');
|
const { createTestBuilder } = require('api-tests/builder');
|
||||||
const { describeOnCondition } = require('api-tests/utils');
|
const { describeOnCondition, createUtils } = require('api-tests/utils');
|
||||||
|
|
||||||
const {
|
const {
|
||||||
STAGE_MODEL_UID,
|
STAGE_MODEL_UID,
|
||||||
@ -129,6 +129,7 @@ describeOnCondition(edition === 'EE')('Review workflows', () => {
|
|||||||
where: { id: secondStage.id },
|
where: { id: secondStage.id },
|
||||||
data: { name: 'Stage 2' },
|
data: { name: 'Stage 2' },
|
||||||
});
|
});
|
||||||
|
|
||||||
await updateContentType(productUID, {
|
await updateContentType(productUID, {
|
||||||
components: [],
|
components: [],
|
||||||
contentType: model,
|
contentType: model,
|
||||||
@ -507,7 +508,7 @@ describeOnCondition(edition === 'EE')('Review workflows', () => {
|
|||||||
describe('Update a stage on an entity', () => {
|
describe('Update a stage on an entity', () => {
|
||||||
describe('Review Workflow is enabled', () => {
|
describe('Review Workflow is enabled', () => {
|
||||||
beforeAll(async () => {
|
beforeAll(async () => {
|
||||||
// Update workflow to unassign content type
|
// Update workflow to assign content type
|
||||||
await requests.admin.put(
|
await requests.admin.put(
|
||||||
`/admin/review-workflows/workflows/${testWorkflow.id}?populate=*`,
|
`/admin/review-workflows/workflows/${testWorkflow.id}?populate=*`,
|
||||||
{ body: { data: { contentTypes: [productUID] } } }
|
{ body: { data: { contentTypes: [productUID] } } }
|
||||||
@ -573,9 +574,83 @@ describeOnCondition(edition === 'EE')('Review workflows', () => {
|
|||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
describe('Listing available stages for transition', () => {
|
||||||
|
const endpoint = (id) => `/admin/content-manager/collection-types/${productUID}/${id}/stages`;
|
||||||
|
|
||||||
|
let utils;
|
||||||
|
let entry;
|
||||||
|
let restrictedRequest;
|
||||||
|
let restrictedRole;
|
||||||
|
|
||||||
|
beforeAll(async () => {
|
||||||
|
// Update workflow to assign content type
|
||||||
|
await requests.admin.put(`/admin/review-workflows/workflows/${testWorkflow.id}?populate=*`, {
|
||||||
|
body: { data: { contentTypes: [productUID] } },
|
||||||
|
});
|
||||||
|
|
||||||
|
entry = await createEntry(productUID, { name: 'Product' });
|
||||||
|
|
||||||
|
const restrictedUser = {
|
||||||
|
email: 'restricted@user.io',
|
||||||
|
password: 'Restricted123',
|
||||||
|
};
|
||||||
|
|
||||||
|
utils = createUtils(strapi);
|
||||||
|
const role = await utils.createRole({
|
||||||
|
name: 'restricted-role',
|
||||||
|
description: '',
|
||||||
|
});
|
||||||
|
|
||||||
|
await utils.createUserIfNotExists({
|
||||||
|
...restrictedUser,
|
||||||
|
roles: [role.id],
|
||||||
|
});
|
||||||
|
|
||||||
|
restrictedRole = role;
|
||||||
|
restrictedRequest = await createAuthRequest({ strapi, userInfo: restrictedUser });
|
||||||
|
});
|
||||||
|
|
||||||
|
test("It shouldn't be available for public", async () => {
|
||||||
|
const res = await requests.public.get(endpoint(entry.id));
|
||||||
|
|
||||||
|
if (hasRW) {
|
||||||
|
expect(res.status).toBe(401);
|
||||||
|
} else {
|
||||||
|
expect(res.status).toBe(404);
|
||||||
|
expect(res.body.data).toBeUndefined();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
test('It should return available stages for an admin user', async () => {
|
||||||
|
const res = await requests.admin.get(endpoint(entry.id));
|
||||||
|
|
||||||
|
expect(res.body.data).toHaveLength(1);
|
||||||
|
expect(res.body.data[0]).toMatchObject(secondStage);
|
||||||
|
});
|
||||||
|
|
||||||
|
test('It should return forbidden for a user who does not have permissions to read review workflows', async () => {
|
||||||
|
const res = await restrictedRequest.get(endpoint(entry.id));
|
||||||
|
|
||||||
|
expect(res.status).toBe(403);
|
||||||
|
});
|
||||||
|
|
||||||
|
test('It should return forbidden for a user who does not have permissions to read review workflows', async () => {
|
||||||
|
const permission = {
|
||||||
|
action: 'admin::review-workflows.read',
|
||||||
|
fields: null,
|
||||||
|
conditions: [],
|
||||||
|
};
|
||||||
|
await utils.assignPermissionsToRole(restrictedRole.id, [permission]);
|
||||||
|
|
||||||
|
const res = await restrictedRequest.get(endpoint(entry.id));
|
||||||
|
|
||||||
|
expect(res.body.data).toHaveLength(0);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
describe('Deleting a stage when content already exists', () => {
|
describe('Deleting a stage when content already exists', () => {
|
||||||
beforeAll(async () => {
|
beforeAll(async () => {
|
||||||
// Update workflow to unassign content type
|
// Update workflow to assign content type
|
||||||
await requests.admin.put(`/admin/review-workflows/workflows/${testWorkflow.id}?populate=*`, {
|
await requests.admin.put(`/admin/review-workflows/workflows/${testWorkflow.id}?populate=*`, {
|
||||||
body: { data: { contentTypes: [productUID] } },
|
body: { data: { contentTypes: [productUID] } },
|
||||||
});
|
});
|
||||||
|
Loading…
x
Reference in New Issue
Block a user