gitbeaker/packages/gitbeaker-core/test/unit/templates/ResourceAccessRequests.ts

94 lines
2.9 KiB
TypeScript

import { RequesterType } from '@gitbeaker/requester-utils';
import { ResourceAccessRequests } from '../../../src/templates';
import { RequestHelper } from '../../../src/infrastructure';
jest.mock('../../../src/infrastructure/RequestHelper');
let service: ResourceAccessRequests;
beforeEach(() => {
const requester = {
get: jest.fn(() => Promise.resolve([])),
post: jest.fn(() => Promise.resolve({})),
put: jest.fn(() => Promise.resolve({})),
delete: jest.fn(() => Promise.resolve({})),
} as RequesterType;
service = new ResourceAccessRequests('resource', {
requester,
token: 'abcdefg',
});
});
afterEach(() => {
jest.clearAllMocks();
});
describe('Instantiating ResourceAccessRequests service', () => {
it('should create a valid service object', async () => {
expect(service).toBeInstanceOf(ResourceAccessRequests);
expect(service.url).toBeDefined();
expect(service.url).toContain('resource');
});
});
describe('ResourceAccessRequests.all', () => {
it('should call the correct url for getting all access requests with a string identifer', async () => {
await service.all('5');
expect(RequestHelper.get).toBeCalledWith(service, '5/access_requests');
});
it('should call the correct url for getting all access requests with a number identifer', async () => {
await service.all(5);
expect(RequestHelper.get).toBeCalledWith(service, '5/access_requests');
});
});
describe('ResourceAccessRequests.request', () => {
it('should call the correct url for requesting access requests with a string identifer', async () => {
await service.request('5');
expect(RequestHelper.post).toBeCalledWith(service, '5/access_requests');
});
it('should call the correct url for requesting access requests with a number identifer', async () => {
await service.request(5);
expect(RequestHelper.post).lastCalledWith(service, '5/access_requests');
});
});
describe('ResourceAccessRequests.approve', () => {
it('should call the correct url for approving access requests with the resource id and user id', async () => {
await service.approve('5', 1);
expect(RequestHelper.post).toBeCalledWith(service, '5/access_requests/1/approve', undefined);
});
it('should accept the correct access levels', async () => {
await service.approve(5, 1, { accessLevel: 20 });
expect(RequestHelper.post).toBeCalledWith(service, '5/access_requests/1/approve', {
accessLevel: 20,
});
});
it('should allow for sudo calls', async () => {
await service.approve(5, 1, { sudo: 'test' });
expect(RequestHelper.post).toBeCalledWith(service, '5/access_requests/1/approve', {
sudo: 'test',
});
});
});
describe('ResourceAccessRequests.deny', () => {
it('should call the correct url denying access requests with the resource id and user id', async () => {
await service.deny('5', 1);
expect(RequestHelper.del).toBeCalledWith(service, '5/access_requests/1');
});
});