mirror of
https://github.com/jdalrymple/gitbeaker.git
synced 2026-01-25 16:04:01 +00:00
* Dependency and Configuration updates * CHANGELOG and README updates * Added support for camel case and snake case response types in the request helper and base service * Added support for the Dockerfile Templates API * Added support for the Issue Note Award Emojis API * Removed redundant Group Projects service * Updated types for a variety of services * Added type updates and removed protect and unprotect endpoints from the Branches API * Added type updates and signature endpoint to the Commits API * Added type updates and edit support to the Deployments API * Added type updates and a showRepository function to the Container Registry API * Added type updates and updated the service support to include create, edit, show and remove for the Feature Flags API * Added type updates and support for the removal of geonodes with the Geo Nodes API * Renamed UserKeys to UserSSHKeys and added type updates for the User SSH Keys API * Added type updates for the License Templates API and renamed the export to fix the spelling error * Added type updates and support for the transfer projects endpoint for the Groups API * Added type updates and removed removed events endpoint on the Projects API * Added type updates and modified the create function to require a resource name in the Todos API
101 lines
2.8 KiB
TypeScript
101 lines
2.8 KiB
TypeScript
import { RequestHelper } from '../../../src/infrastructure';
|
|
import { ProtectedBranches } from '../../../src';
|
|
|
|
jest.mock(
|
|
'../../../src/infrastructure/RequestHelper',
|
|
() => require('../../__mocks__/RequestHelper').default,
|
|
);
|
|
|
|
let service: ProtectedBranches;
|
|
|
|
beforeEach(() => {
|
|
service = new ProtectedBranches({
|
|
requesterFn: jest.fn(),
|
|
token: 'abcdefg',
|
|
requestTimeout: 3000,
|
|
});
|
|
});
|
|
|
|
describe('Instantiating ProtectedBranches service', () => {
|
|
it('should create a valid service object', async () => {
|
|
expect(service).toBeInstanceOf(ProtectedBranches);
|
|
expect(service.url).toBeDefined();
|
|
expect(service.rejectUnauthorized).toBeTruthy();
|
|
expect(service.headers).toMatchObject({ 'private-token': 'abcdefg' });
|
|
expect(service.requestTimeout).toBe(3000);
|
|
});
|
|
});
|
|
|
|
describe('ProtectedBranches.all', () => {
|
|
it('should request GET /projects/:id/protected_branches', async () => {
|
|
await service.all(1, { test: 1 });
|
|
|
|
expect(RequestHelper.get()).toHaveBeenCalledWith(service, 'projects/1/protected_branches', {
|
|
test: 1,
|
|
});
|
|
});
|
|
|
|
it('should request GET /projects/:id/protected_branches without options', async () => {
|
|
await service.all(1);
|
|
|
|
expect(RequestHelper.get()).toHaveBeenCalledWith(service, 'projects/1/protected_branches', {});
|
|
});
|
|
});
|
|
|
|
describe('ProtectedBranches.protect', () => {
|
|
it('should request POST /projects/:id/protected_branches', async () => {
|
|
await service.protect(1, 'name', { test: 1 });
|
|
|
|
expect(RequestHelper.post()).toHaveBeenCalledWith(service, 'projects/1/protected_branches', {
|
|
name: 'name',
|
|
test: 1,
|
|
});
|
|
});
|
|
});
|
|
|
|
describe('ProtectedBranches.show', () => {
|
|
it('should request GET /projects/:id/protected_branches/:branch_name', async () => {
|
|
await service.show(1, 'name', { sudo: 1 });
|
|
|
|
expect(RequestHelper.get()).toHaveBeenCalledWith(
|
|
service,
|
|
'projects/1/protected_branches/name',
|
|
{
|
|
sudo: 1,
|
|
},
|
|
);
|
|
});
|
|
|
|
it('should request GET /projects/:id/protected_branches/:branch_name without options', async () => {
|
|
await service.show(1, 'name');
|
|
|
|
expect(RequestHelper.get()).toHaveBeenCalledWith(
|
|
service,
|
|
'projects/1/protected_branches/name',
|
|
undefined,
|
|
);
|
|
});
|
|
});
|
|
|
|
describe('ProtectedBranches.unprotect', () => {
|
|
it('should request DEL /projects/:id/protected_branches/:branch_name without options', async () => {
|
|
await service.unprotect(1, 'name');
|
|
|
|
expect(RequestHelper.del()).toHaveBeenCalledWith(
|
|
service,
|
|
'projects/1/protected_branches/name',
|
|
undefined,
|
|
);
|
|
});
|
|
|
|
it('should request DEL /projects/:id/protected_branches/:branch_name', async () => {
|
|
await service.unprotect(1, 'name', { sudo: 1 });
|
|
|
|
expect(RequestHelper.del()).toHaveBeenCalledWith(
|
|
service,
|
|
'projects/1/protected_branches/name',
|
|
{ sudo: 1 },
|
|
);
|
|
});
|
|
});
|