renovate/lib/platform/bitbucket/utils.spec.ts
Sergio Zharinov 01be64987b
refactor(bitbucket): Switch to new http wrapper (#6392)
Co-authored-by: Rhys Arkins <rhys@arkins.net>
2020-06-01 16:02:25 +02:00

39 lines
1.2 KiB
TypeScript

import * as httpMock from '../../../test/httpMock';
import { setBaseUrl } from '../../util/http/bitbucket';
import * as utils from './utils';
const range = (count: number) => [...Array(count).keys()];
const baseUrl = 'https://api.bitbucket.org';
describe('accumulateValues()', () => {
it('paginates', async () => {
httpMock.reset();
httpMock.setup();
setBaseUrl(baseUrl);
httpMock
.scope(baseUrl)
.get('/some-url?pagelen=10')
.reply(200, {
values: range(10),
next:
'https://api.bitbucket.org/2.0/repositories/?pagelen=10&after=9&role=contributor',
})
.get('/2.0/repositories/?pagelen=10&after=9&role=contributor')
.reply(200, {
values: range(10),
next:
'https://api.bitbucket.org/2.0/repositories/?pagelen=10&after=19&role=contributor',
})
.get('/2.0/repositories/?pagelen=10&after=19&role=contributor')
.reply(200, {
values: range(5),
});
const res = await utils.accumulateValues('some-url', 'get', null, 10);
expect(res).toHaveLength(25);
expect(httpMock.getTrace()).toHaveLength(3);
expect(httpMock.getTrace()).toMatchSnapshot();
});
});