2019-12-07 21:02:00 +02:00
|
|
|
import expect from 'app/test/unexpected';
|
2017-02-26 13:40:07 +02:00
|
|
|
import sinon from 'sinon';
|
|
|
|
|
2019-12-07 21:02:00 +02:00
|
|
|
import request from 'app/services/request';
|
|
|
|
import { InternalServerError, RequestAbortedError } from 'app/services/request';
|
2017-02-26 13:40:07 +02:00
|
|
|
|
|
|
|
describe('services/request', () => {
|
2019-11-27 11:03:32 +02:00
|
|
|
beforeEach(() => {
|
|
|
|
sinon.stub(window, 'fetch').named('fetch');
|
|
|
|
});
|
2017-02-26 13:40:07 +02:00
|
|
|
|
2019-11-27 11:03:32 +02:00
|
|
|
afterEach(() => {
|
2019-12-07 13:28:52 +02:00
|
|
|
(window.fetch as any).restore();
|
2019-11-27 11:03:32 +02:00
|
|
|
});
|
2017-02-26 13:40:07 +02:00
|
|
|
|
2019-11-27 11:03:32 +02:00
|
|
|
describe('InternalServerError', () => {
|
|
|
|
it('should wrap json errors', () => {
|
|
|
|
const resp = new Response('bad resp format', { status: 200 });
|
2017-02-26 13:40:07 +02:00
|
|
|
|
2019-12-07 13:28:52 +02:00
|
|
|
(fetch as any).returns(Promise.resolve(resp));
|
2017-02-26 13:40:07 +02:00
|
|
|
|
2020-01-17 23:37:52 +03:00
|
|
|
return expect(request.get('/foo'), 'to be rejected').then(
|
|
|
|
(error: InternalServerError) => {
|
|
|
|
expect(error, 'to be an', InternalServerError);
|
|
|
|
expect(error.originalResponse, 'to be', resp);
|
|
|
|
expect(error.message, 'to contain', 'Unexpected token');
|
|
|
|
},
|
|
|
|
);
|
2019-11-27 11:03:32 +02:00
|
|
|
});
|
2017-02-26 13:40:07 +02:00
|
|
|
|
2019-11-27 11:03:32 +02:00
|
|
|
it('should wrap 5xx errors', () => {
|
|
|
|
const resp = new Response('{}', { status: 500 });
|
2017-02-26 13:40:07 +02:00
|
|
|
|
2019-12-07 13:28:52 +02:00
|
|
|
(fetch as any).returns(Promise.resolve(resp));
|
2017-02-26 13:40:07 +02:00
|
|
|
|
2020-01-17 23:37:52 +03:00
|
|
|
return expect(request.get('/foo'), 'to be rejected').then(
|
|
|
|
(error: InternalServerError) => {
|
|
|
|
expect(error, 'to be an', InternalServerError);
|
|
|
|
expect(error.originalResponse, 'to be', resp);
|
|
|
|
},
|
|
|
|
);
|
2019-11-27 11:03:32 +02:00
|
|
|
});
|
2017-02-26 13:40:07 +02:00
|
|
|
|
2019-11-27 11:03:32 +02:00
|
|
|
it('should wrap aborted errors', () => {
|
|
|
|
const resp = new Response('{}', { status: 0 });
|
2018-11-04 10:09:42 +02:00
|
|
|
|
2019-12-07 13:28:52 +02:00
|
|
|
(fetch as any).returns(Promise.resolve(resp));
|
2018-11-04 10:09:42 +02:00
|
|
|
|
2020-01-17 23:37:52 +03:00
|
|
|
return expect(request.get('/foo'), 'to be rejected').then(
|
|
|
|
(error: RequestAbortedError) => {
|
|
|
|
expect(error, 'to be an', RequestAbortedError);
|
|
|
|
// @ts-ignore
|
|
|
|
expect(error.error, 'to be', resp);
|
|
|
|
},
|
|
|
|
);
|
2019-11-27 11:03:32 +02:00
|
|
|
});
|
2018-11-04 10:09:42 +02:00
|
|
|
|
2019-11-27 11:03:32 +02:00
|
|
|
it('should wrap "Failed to fetch" errors', () => {
|
|
|
|
const resp = new TypeError('Failed to fetch');
|
2017-02-26 13:40:07 +02:00
|
|
|
|
2019-12-07 13:28:52 +02:00
|
|
|
(fetch as any).returns(Promise.resolve(resp));
|
2017-02-26 13:40:07 +02:00
|
|
|
|
2020-01-17 23:37:52 +03:00
|
|
|
return expect(request.get('/foo'), 'to be rejected').then(
|
|
|
|
(error: RequestAbortedError) => {
|
|
|
|
expect(error, 'to be an', RequestAbortedError);
|
|
|
|
expect(error.message, 'to be', resp.message);
|
|
|
|
// @ts-ignore
|
|
|
|
expect(error.error, 'to be', resp);
|
|
|
|
},
|
|
|
|
);
|
2017-02-26 13:40:07 +02:00
|
|
|
});
|
2019-11-27 11:03:32 +02:00
|
|
|
});
|
|
|
|
|
|
|
|
describe('#buildQuery', () => {
|
|
|
|
it('should build query', () => {
|
|
|
|
const data = {
|
|
|
|
notSet: undefined,
|
|
|
|
notSet2: null,
|
|
|
|
numeric: 1,
|
|
|
|
complexString: 'sdfgs sdfg ',
|
|
|
|
positive: true,
|
|
|
|
negative: false,
|
|
|
|
};
|
|
|
|
const expectedQs =
|
|
|
|
'notSet=¬Set2=&numeric=1&complexString=sdfgs%20sdfg%20&positive=1&negative=0';
|
|
|
|
|
|
|
|
expect(request.buildQuery(data), 'to equal', expectedQs);
|
2017-05-25 22:11:57 +03:00
|
|
|
});
|
2019-11-27 11:03:32 +02:00
|
|
|
});
|
2017-02-26 13:40:07 +02:00
|
|
|
});
|