gitbeaker/test/tests/infrastructure/RequestHelper.ts
jdalrymple 6d5a4b92b0
Typescript Support (#183)
* chore: Introduce typescript 
* chore: Remove lodash.pick, use native js instead
* chore: Add tslint and extend Airbnb ruleset
* chore: Remove Babel Dependency, replace build steps with tsc
* chore: change target for modern env from es2017 to es6 (async/await should be transpiled to downlevel js)
* chore(package): Updating packages
* fix: Fix error while throwing an error in RequestHelper (#156)
* feat: Support rejectUnauthorized parameter (#164)
* feat: Adding project archive abilities
* fix(test): Application settings API updated (#177)
* fix: Removing token requirement (#176)
* chore: Removing npmignore and using files instead.
* fix: obey rate limits for all request types correctly (#170)
* fix: Camel casing broke the body params
2018-09-05 11:22:28 -04:00

161 lines
3.9 KiB
TypeScript

import { RequestHelper } from '../../../src/infrastructure';
const mockService = {
url: 'testing',
headers: {},
requester: {
get: () => ({
body: {
prop1: 5,
prop2: 'test property',
},
headers: {
'X-Page': 1,
'X-Total-Pages': 1,
},
}),
},
};
const mockService2 = {
url: 'testing',
headers: {},
requester: {
get: ({ url, qs }) => {
let u = url;
if (qs.page) u += `page=${qs.page}`;
const page1 = {
body: [
{
prop1: 1,
prop2: 'test property1',
},
{
prop1: 2,
prop2: 'test property2',
},
],
headers: {
link: "<'https://www.test.com/api/v3/projects/8?page=2&per_page=2>; rel='next', <'https://www.test.com/api/v3/projects/8?page=1&per_page=2>; rel='first', <'https://www.test.com/api/v3/projects/8?page=2&per_page=2>; rel='last'",
'x-next-page': 2,
'x-page': 1,
'x-per-page': 2,
'x-prev-page': '',
'x-total': 4,
'x-total-pages': 2,
},
};
const page2 = {
body: [
{
prop1: 3,
prop2: 'test property3',
},
{
prop1: 4,
prop2: 'test property4',
},
],
headers: {
link: "<'https://www.test.com/api/v3/projects/8?page=1&per_page=2>; rel='prev', <'https://www.test.com/api/v3/projects/8?page=1&per_page=2>; rel='first', <'https://www.test.com/api/v3/projects/8?page=2&per_page=2>; rel='last'",
'x-next-page': '',
'x-page': 2,
'x-per-page': 2,
'x-prev-page': 1,
'x-total': 4,
'x-total-pages': 2,
},
};
if (u.includes('page=2')) return page2;
return page1;
},
},
};
describe('RequestHelper.get()', () => {
it('Should respond with an object', async () => {
const response = await RequestHelper.get(
mockService,
'https://www.test.com',
);
expect(response.prop1).toBe(5);
expect(response.prop2).toBe('test property');
});
it('Should be paginated when links are present', async () => {
const response = await RequestHelper.get(
mockService2,
'https://www.test.com',
);
response.forEach((l, index) => {
expect(l.prop1).toBe(1 + index);
expect(l.prop2).toBe(`test property${1 + index}`);
});
});
it('Should be paginated but limited by the maxPages option', async () => {
const response = await RequestHelper.get(
mockService2,
'https://www.test.com',
{ maxPages: 1 },
);
expect(response).toHaveLength(2);
expect(response[0].prop1).toBe(1);
response.forEach((l, index) => {
expect(l.prop1).toBe(1 + index);
expect(l.prop2).toBe(`test property${1 + index}`);
});
});
it('Should be paginated but limited by the page option', async () => {
const response = await RequestHelper.get(
mockService2,
'https://www.test.com',
{ page: 2 },
);
expect(response).toHaveLength(2);
expect(response[0].prop1).toBe(3);
response.forEach((l, index) => {
expect(l.prop1).toBe(3 + index);
expect(l.prop2).toBe(`test property${3 + index}`);
});
});
it('Should show the pagination information when the page option is given', async () => {
const response = await RequestHelper.get(
mockService2,
'https://www.test.com',
{ page: 2, showPagination: true },
);
expect(response.data).toBeDefined();
expect(response.data).toHaveLength(2);
expect(response.data[0].prop1).toBe(3);
response.data.forEach((l, index) => {
expect(l.prop1).toBe(3 + index);
expect(l.prop2).toBe(`test property${3 + index}`);
});
expect(response.pagination).toMatchObject({
total: 4,
previous: 1,
current: 2,
next: null,
perPage: 2,
totalPages: 2,
});
});
});