n8n/packages/cli/test/integration/role.api.test.ts

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

168 lines
4.3 KiB
TypeScript
Raw Permalink Normal View History

import type { Scope } from '@n8n/permissions';
import { Container } from 'typedi';
import type { ProjectRole } from '@/databases/entities/project-relation';
import type { CredentialSharingRole } from '@/databases/entities/shared-credentials';
import type { WorkflowSharingRole } from '@/databases/entities/shared-workflow';
import type { GlobalRole } from '@/databases/entities/user';
import { RoleService } from '@/services/role.service';
import { createMember } from './shared/db/users';
import type { SuperAgentTest } from './shared/types';
import * as utils from './shared/utils/';
const testServer = utils.setupTestServer({
endpointGroups: ['role'],
});
let memberAgent: SuperAgentTest;
const expectedCategories = ['global', 'project', 'credential', 'workflow'] as const;
let expectedGlobalRoles: Array<{
name: string;
role: GlobalRole;
scopes: Scope[];
licensed: boolean;
}>;
let expectedProjectRoles: Array<{
name: string;
role: ProjectRole;
scopes: Scope[];
licensed: boolean;
}>;
let expectedCredentialRoles: Array<{
name: string;
role: CredentialSharingRole;
scopes: Scope[];
licensed: boolean;
}>;
let expectedWorkflowRoles: Array<{
name: string;
role: WorkflowSharingRole;
scopes: Scope[];
licensed: boolean;
}>;
beforeAll(async () => {
memberAgent = testServer.authAgentFor(await createMember());
expectedGlobalRoles = [
{
name: 'Owner',
role: 'global:owner',
scopes: Container.get(RoleService).getRoleScopes('global:owner'),
licensed: true,
},
{
name: 'Admin',
role: 'global:admin',
scopes: Container.get(RoleService).getRoleScopes('global:admin'),
licensed: false,
},
{
name: 'Member',
role: 'global:member',
scopes: Container.get(RoleService).getRoleScopes('global:member'),
licensed: true,
},
];
expectedProjectRoles = [
{
name: 'Project Owner',
role: 'project:personalOwner',
scopes: Container.get(RoleService).getRoleScopes('project:personalOwner'),
licensed: true,
},
{
name: 'Project Admin',
role: 'project:admin',
scopes: Container.get(RoleService).getRoleScopes('project:admin'),
licensed: false,
},
{
name: 'Project Editor',
role: 'project:editor',
scopes: Container.get(RoleService).getRoleScopes('project:editor'),
licensed: false,
},
];
expectedCredentialRoles = [
{
name: 'Credential Owner',
role: 'credential:owner',
scopes: Container.get(RoleService).getRoleScopes('credential:owner'),
licensed: true,
},
{
name: 'Credential User',
role: 'credential:user',
scopes: Container.get(RoleService).getRoleScopes('credential:user'),
licensed: true,
},
];
expectedWorkflowRoles = [
{
name: 'Workflow Owner',
role: 'workflow:owner',
scopes: Container.get(RoleService).getRoleScopes('workflow:owner'),
licensed: true,
},
{
name: 'Workflow Editor',
role: 'workflow:editor',
scopes: Container.get(RoleService).getRoleScopes('workflow:editor'),
licensed: true,
},
];
});
describe('GET /roles/', () => {
test('should return all role categories', async () => {
const resp = await memberAgent.get('/roles/');
expect(resp.status).toBe(200);
const data: Record<string, string[]> = resp.body.data;
const categories = [...Object.keys(data)];
expect(categories.length).toBe(expectedCategories.length);
expect(expectedCategories.every((c) => categories.includes(c))).toBe(true);
});
test('should return fixed global roles', async () => {
const resp = await memberAgent.get('/roles/');
expect(resp.status).toBe(200);
for (const role of expectedGlobalRoles) {
expect(resp.body.data.global).toContainEqual(role);
}
});
test('should return fixed project roles', async () => {
const resp = await memberAgent.get('/roles/');
expect(resp.status).toBe(200);
for (const role of expectedProjectRoles) {
expect(resp.body.data.project).toContainEqual(role);
}
});
test('should return fixed credential sharing roles', async () => {
const resp = await memberAgent.get('/roles/');
expect(resp.status).toBe(200);
for (const role of expectedCredentialRoles) {
expect(resp.body.data.credential).toContainEqual(role);
}
});
test('should return fixed workflow sharing roles', async () => {
const resp = await memberAgent.get('/roles/');
expect(resp.status).toBe(200);
for (const role of expectedWorkflowRoles) {
expect(resp.body.data.workflow).toContainEqual(role);
}
});
});