Justin Dalrymple db63076a5a
Reach > 90% coverage and add Integration Testing (#709)
- Added many many more unit tests to increase coverage to 90% +
- Removed the upsert functionality of PushRules to maintain documented API parity
2020-06-20 14:55:12 +02:00

98 lines
2.8 KiB
TypeScript

import { RequesterType } from '@gitbeaker/requester-utils';
import { Triggers } from '../../../src';
import { RequestHelper } from '../../../src/infrastructure';
jest.mock('../../../src/infrastructure/RequestHelper');
let service: Triggers;
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 Triggers({
requester,
token: 'abcdefg',
requestTimeout: 3000,
});
});
describe('Instantiating Triggers service', () => {
it('should create a valid service object', async () => {
expect(service).toBeInstanceOf(Triggers);
expect(service.url).toBeDefined();
expect(service.rejectUnauthorized).toBeTruthy();
expect(service.headers).toMatchObject({ 'private-token': 'abcdefg' });
expect(service.requestTimeout).toBe(3000);
});
});
describe('Triggers.all', () => {
it('should request GET /projects/:id/triggers', async () => {
await service.all(1);
expect(RequestHelper.get).toHaveBeenCalledWith(service, 'projects/1/triggers', undefined);
});
});
describe('Triggers.add', () => {
it('should request POST /projects/:id/triggers', async () => {
await service.add(1);
expect(RequestHelper.post).toHaveBeenCalledWith(service, 'projects/1/triggers', undefined);
});
});
describe('Triggers.edit', () => {
it('should request PUT /projects/:id/triggers/:id', async () => {
await service.edit(1, 2, { prop: 5 });
expect(RequestHelper.put).toHaveBeenCalledWith(service, 'projects/1/triggers/2', {
prop: 5,
});
});
});
describe('Triggers.pipeline', () => {
it('should request PUT /projects/:id/trigger/pipeline with variables', async () => {
await service.pipeline(1, 'main', 'abcd', { variables: { VAR_ONE: 'val' } });
expect(RequestHelper.post).toHaveBeenCalledWith(service, 'projects/1/trigger/pipeline', {
isForm: true,
ref: 'main',
token: 'abcd',
'variables[VAR_ONE]': 'val',
});
});
it('should request PUT /projects/:id/trigger/pipeline without variables', async () => {
await service.pipeline(1, 'main', 'abcd');
expect(RequestHelper.post).toHaveBeenCalledWith(service, 'projects/1/trigger/pipeline', {
isForm: true,
ref: 'main',
token: 'abcd',
});
});
});
describe('Triggers.show', () => {
it('should request GET /projects/:id/triggers/:id', async () => {
await service.show(1, 2);
expect(RequestHelper.get).toHaveBeenCalledWith(service, 'projects/1/triggers/2', undefined);
});
});
describe('Triggers.remove', () => {
it('should request DELETE /projects/:id/triggers/:id', async () => {
await service.remove(1, 2);
expect(RequestHelper.del).toHaveBeenCalledWith(service, 'projects/1/triggers/2', undefined);
});
});