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

105 lines
2.9 KiB
TypeScript

import { RequesterType } from '@gitbeaker/requester-utils';
import { RequestHelper } from '../../../src/infrastructure';
import { ContainerRegistry } from '../../../src';
jest.mock('../../../src/infrastructure/RequestHelper');
let service: ContainerRegistry;
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 ContainerRegistry({
requester,
token: 'abcdefg',
requestTimeout: 3000,
});
});
describe('Instantiating ContainerRegistry service', () => {
it('should create a valid service object', async () => {
expect(service).toBeInstanceOf(ContainerRegistry);
expect(service.url).toBeDefined();
expect(service.rejectUnauthorized).toBeTruthy();
expect(service.headers).toMatchObject({ 'private-token': 'abcdefg' });
expect(service.requestTimeout).toBe(3000);
});
});
describe('ContainerRegistry.repositories', () => {
it('should request GET /projects/:id/registry/repositories', async () => {
await service.repositories(1);
expect(RequestHelper.get).toHaveBeenCalledWith(
service,
'projects/1/registry/repositories',
undefined,
);
});
});
describe('ContainerRegistry.tags', () => {
it('should request GET /projects/:id/registry/repositories/:id/tags', async () => {
await service.tags(1, 2);
expect(RequestHelper.get).toHaveBeenCalledWith(
service,
'projects/1/registry/repositories/2/tags',
undefined,
);
});
});
describe('ContainerRegistry.removeRepository', () => {
it('should request DELETE /projects/:id/registry/repositories/:id', async () => {
await service.removeRepository(1, 2);
expect(RequestHelper.del).toHaveBeenCalledWith(
service,
'projects/1/registry/repositories/2',
undefined,
);
});
});
describe('ContainerRegistry.removeTag', () => {
it('should request DELETE /projects/:id/registry/repositories/:id/tags/:id', async () => {
await service.removeTag(1, 2, 'name');
expect(RequestHelper.del).toHaveBeenCalledWith(
service,
'projects/1/registry/repositories/2/tags/name',
undefined,
);
});
});
describe('ContainerRegistry.removeTags', () => {
it('should request DELETE /projects/:id/registry/repositories/:id/tags', async () => {
await service.removeTags(1, 2, 'name');
expect(RequestHelper.del).toHaveBeenCalledWith(
service,
'projects/1/registry/repositories/2/tags',
{ nameRegexDelete: 'name' },
);
});
});
describe('ContainerRegistry.showTag', () => {
it('should request GET /projects/:id/registry/repositories/:id/tags/:id', async () => {
await service.showTag(1, 2, 'name');
expect(RequestHelper.get).toHaveBeenCalledWith(
service,
'projects/1/registry/repositories/2/tags/name',
undefined,
);
});
});