mirror of https://github.com/ghostfolio/ghostfolio
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
57 lines
1.8 KiB
57 lines
1.8 KiB
import { Test, TestingModule } from '@nestjs/testing';
|
|
import { HasPermissionsGuard } from './has-permissions.guard';
|
|
import { Reflector } from '@nestjs/core';
|
|
import { ExecutionContextHost } from '@nestjs/core/helpers/execution-context-host';
|
|
import { HttpException } from '@nestjs/common';
|
|
|
|
describe('HasPermissionsGuard', () => {
|
|
let guard: HasPermissionsGuard;
|
|
let reflector: Reflector;
|
|
|
|
beforeEach(async () => {
|
|
const module: TestingModule = await Test.createTestingModule({
|
|
providers: [
|
|
HasPermissionsGuard,
|
|
Reflector,
|
|
],
|
|
}).compile();
|
|
|
|
guard = module.get<HasPermissionsGuard>(HasPermissionsGuard);
|
|
reflector = module.get<Reflector>(Reflector);
|
|
});
|
|
|
|
function setupReflectorSpy(returnValue: string) {
|
|
jest.spyOn(reflector, 'get').mockReturnValue(returnValue);
|
|
}
|
|
|
|
function createMockExecutionContext(permissions: string[]) {
|
|
return new ExecutionContextHost([
|
|
{
|
|
user: {
|
|
permissions, // Set user permissions based on the argument
|
|
},
|
|
},
|
|
]);
|
|
}
|
|
|
|
it('should deny access if the user does not have any permission', () => {
|
|
setupReflectorSpy('required-permission');
|
|
const noPermissions = createMockExecutionContext([]);
|
|
|
|
expect(() => guard.canActivate(noPermissions)).toThrow(HttpException);
|
|
});
|
|
|
|
it('should deny access if the user has the wrong permission', () => {
|
|
setupReflectorSpy('required-permission');
|
|
const wrongPermission = createMockExecutionContext(['wrong-permission']);
|
|
|
|
expect(() => guard.canActivate(wrongPermission)).toThrow(HttpException);
|
|
});
|
|
|
|
it('should allow access if the user has the required permission', () => {
|
|
setupReflectorSpy('required-permission');
|
|
const rightPermission = createMockExecutionContext(['required-permission']);
|
|
|
|
expect(guard.canActivate(rightPermission)).toBe(true);
|
|
});
|
|
});
|
|
|