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>
117 lines
2.1 KiB
TypeScript
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,
|
|
});
|
|
});
|
|
});
|