Files
Automata/packages/editor-ui/src/__tests__/permissions.spec.ts
Csaba Tuncsik 596c472ecc feat: RBAC (#8922)
Signed-off-by: Oleg Ivaniv <me@olegivaniv.com>
Co-authored-by: Val <68596159+valya@users.noreply.github.com>
Co-authored-by: कारतोफ्फेलस्क्रिप्ट™ <aditya@netroy.in>
Co-authored-by: Valya Bullions <valya@n8n.io>
Co-authored-by: Danny Martini <danny@n8n.io>
Co-authored-by: Danny Martini <despair.blue@gmail.com>
Co-authored-by: Iván Ovejero <ivov.src@gmail.com>
Co-authored-by: Omar Ajoue <krynble@gmail.com>
Co-authored-by: oleg <me@olegivaniv.com>
Co-authored-by: Michael Kret <michael.k@radency.com>
Co-authored-by: Michael Kret <88898367+michael-radency@users.noreply.github.com>
Co-authored-by: Elias Meire <elias@meire.dev>
Co-authored-by: Giulio Andreini <andreini@netseven.it>
Co-authored-by: Giulio Andreini <g.andreini@gmail.com>
Co-authored-by: Ayato Hayashi <go12limchangyong@gmail.com>
2024-05-17 10:53:15 +02:00

117 lines
2.1 KiB
TypeScript

import {
getVariablesPermissions,
getProjectPermissions,
getCredentialPermissions,
getWorkflowPermissions,
} from '@/permissions';
import type { ICredentialsResponse, IUser, IWorkflowDb } from '@/Interface';
import type { Project } from '@/features/projects/projects.types';
describe('permissions', () => {
it('getVariablesPermissions', () => {
expect(getVariablesPermissions(null)).toEqual({
create: false,
read: false,
update: false,
delete: false,
list: false,
});
expect(
getVariablesPermissions({
globalScopes: [
'variable:create',
'variable:read',
'variable:update',
'variable:delete',
'variable:list',
],
} as IUser),
).toEqual({
create: true,
read: true,
update: true,
delete: true,
list: true,
});
expect(
getVariablesPermissions({
globalScopes: ['variable:read', 'variable:list'],
} as IUser),
).toEqual({
create: false,
read: true,
update: false,
delete: false,
list: true,
});
});
it('getProjectPermissions', () => {
expect(
getProjectPermissions({
scopes: [
'project:create',
'project:read',
'project:update',
'project:delete',
'project:list',
],
} as Project),
).toEqual({
create: true,
read: true,
update: true,
delete: true,
list: true,
});
});
it('getCredentialPermissions', () => {
expect(
getCredentialPermissions({
scopes: [
'credential:create',
'credential:read',
'credential:update',
'credential:delete',
'credential:list',
'credential:share',
],
} as ICredentialsResponse),
).toEqual({
create: true,
read: true,
update: true,
delete: true,
list: true,
share: true,
});
});
it('getWorkflowPermissions', () => {
expect(
getWorkflowPermissions({
scopes: [
'workflow:create',
'workflow:read',
'workflow:update',
'workflow:delete',
'workflow:list',
'workflow:share',
'workflow:execute',
],
} as IWorkflowDb),
).toEqual({
create: true,
read: true,
update: true,
delete: true,
list: true,
share: true,
execute: true,
});
});
});