mirror of
https://github.com/jdalrymple/gitbeaker.git
synced 2026-01-25 16:04:01 +00:00
94 lines
2.9 KiB
TypeScript
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');
|
|
});
|
|
});
|