Justin Dalrymple 6a3292b033
Expose typing to consumer and remove export complexity (#1818)
- Exports all types
- Clean up type duplicates
- Remove Project,User and Group Bundles
- Fix typing on the Gitlab Export
- Clean up README.md
2021-07-05 15:34:19 -04:00

74 lines
2.0 KiB
TypeScript

import { RequestHelper } from '../../../src/infrastructure';
import { SystemHooks } from '../../../src';
jest.mock(
'../../../src/infrastructure/RequestHelper',
() => require('../../__mocks__/RequestHelper').default,
);
let service: SystemHooks;
beforeEach(() => {
service = new SystemHooks({
requesterFn: jest.fn(),
token: 'abcdefg',
requestTimeout: 3000,
});
});
describe('Instantiating SystemHooks service', () => {
it('should create a valid service object', () => {
expect(service).toBeInstanceOf(SystemHooks);
expect(service.url).toBeDefined();
expect(service.rejectUnauthorized).toBeTruthy();
expect(service.headers).toMatchObject({ 'private-token': 'abcdefg' });
expect(service.requestTimeout).toBe(3000);
});
});
describe('SystemHooks.all', () => {
it('should request GET /hooks without options', async () => {
await service.all();
expect(RequestHelper.get()).toHaveBeenCalledWith(service, 'hooks', undefined);
});
it('should request GET /hooks with options', async () => {
await service.all({ test: 1 });
expect(RequestHelper.get()).toHaveBeenCalledWith(service, 'hooks', { test: 1 });
});
});
describe('SystemHooks.add', () => {
it('should request POST /hooks', async () => {
await service.add('url');
expect(RequestHelper.post()).toHaveBeenCalledWith(service, 'hooks', {
url: 'url',
});
});
});
describe('SystemHooks.edit', () => {
it('should request PUT /hooks/:hook_id', async () => {
await service.edit(2, 'url');
expect(RequestHelper.put()).toHaveBeenCalledWith(service, 'hooks/2', { url: 'url' });
});
});
describe('SystemHooks.remove', () => {
it('should request DEL /hooks/:hook_id with options', async () => {
await service.remove(2, { sudo: 1 });
expect(RequestHelper.del()).toHaveBeenCalledWith(service, 'hooks/2', { sudo: 1 });
});
it('should request DEL /hooks/:hook_id without options', async () => {
await service.remove(2);
expect(RequestHelper.del()).toHaveBeenCalledWith(service, 'hooks/2', undefined);
});
});