fix(git-gateway): unpublished entries not loaded for git-gateway(GitHub) (#2856)

This commit is contained in:
Erez Rokah
2019-11-11 18:33:20 +02:00
committed by GitHub
parent 86adca3a18
commit 4a2328b2f1
5 changed files with 168 additions and 33 deletions

View File

@ -109,8 +109,13 @@ export default class API {
return textPromise;
}
request(path, options = {}, parseResponse = response => this.parseResponse(response)) {
const headers = this.requestHeaders(options.headers || {});
handleRequestError(error, responseStatus) {
throw new APIError(error.message, responseStatus, 'GitHub');
}
async request(path, options = {}, parseResponse = response => this.parseResponse(response)) {
// overriding classes can return a promise from requestHeaders
const headers = await this.requestHeaders(options.headers || {});
const url = this.urlFor(path, options);
let responseStatus;
return fetch(url, { ...options, headers })
@ -118,13 +123,12 @@ export default class API {
responseStatus = response.status;
return parseResponse(response);
})
.catch(error => {
throw new APIError(error.message, responseStatus, 'GitHub');
});
.catch(error => this.handleRequestError(error, responseStatus));
}
async requestAllPages(url, options = {}) {
const headers = this.requestHeaders(options.headers || {});
// overriding classes can return a promise from requestHeaders
const headers = await this.requestHeaders(options.headers || {});
const processedURL = this.urlFor(url, options);
const allResponses = await getAllResponses(processedURL, { ...options, headers });
const pages = await Promise.all(allResponses.map(res => this.parseResponse(res)));

View File

@ -36,4 +36,74 @@ describe('github API', () => {
.then(() => prBaseBranch),
).resolves.toEqual('gh-pages');
});
describe('request', () => {
beforeEach(() => {
const fetch = jest.fn();
global.fetch = fetch;
global.Date = jest.fn(() => ({ getTime: () => 1000 }));
});
afterEach(() => {
jest.resetAllMocks();
});
it('should fetch url with authorization header', async () => {
const api = new API({ branch: 'gh-pages', repo: 'my-repo', token: 'token' });
fetch.mockResolvedValue({
text: jest.fn().mockResolvedValue('some response'),
ok: true,
status: 200,
headers: { get: () => '' },
});
const result = await api.request('/some-path');
expect(result).toEqual('some response');
expect(fetch).toHaveBeenCalledTimes(1);
expect(fetch).toHaveBeenCalledWith('https://api.github.com/some-path?ts=1000', {
headers: { Authorization: 'token token', 'Content-Type': 'application/json' },
});
});
it('should throw error on not ok response', async () => {
const api = new API({ branch: 'gh-pages', repo: 'my-repo', token: 'token' });
fetch.mockResolvedValue({
text: jest.fn().mockResolvedValue({ message: 'some error' }),
ok: false,
status: 404,
headers: { get: () => '' },
});
await expect(api.request('some-path')).rejects.toThrow(
expect.objectContaining({
message: 'some error',
name: 'API_ERROR',
status: 404,
api: 'GitHub',
}),
);
});
it('should allow overriding requestHeaders to return a promise ', async () => {
const api = new API({ branch: 'gh-pages', repo: 'my-repo', token: 'token' });
api.requestHeaders = jest
.fn()
.mockResolvedValue({ Authorization: 'promise-token', 'Content-Type': 'application/json' });
fetch.mockResolvedValue({
text: jest.fn().mockResolvedValue('some response'),
ok: true,
status: 200,
headers: { get: () => '' },
});
const result = await api.request('/some-path');
expect(result).toEqual('some response');
expect(fetch).toHaveBeenCalledTimes(1);
expect(fetch).toHaveBeenCalledWith('https://api.github.com/some-path?ts=1000', {
headers: { Authorization: 'promise-token', 'Content-Type': 'application/json' },
});
});
});
});