Files
RSSHub/test/utils/got.js
Chih-Hsuan Yen 1c9c4ccfc8 fix(core): make sure timeout error messages include URLs (#7981)
Before this fix, timeout messages are not quite useful

> error: Request undefined fail, retry attempt #1: TimeoutError: Timeout awaiting 'request' for 5000ms
2021-08-12 01:27:07 -07:00

82 lines
2.3 KiB
JavaScript

process.env.REQUEST_TIMEOUT = '500';
const got = require('../../lib/utils/got');
const logger = require('../../lib/utils/logger');
const config = require('../../lib/config').value;
const nock = require('nock');
afterAll(() => {
delete process.env.REQUEST_TIMEOUT;
});
describe('got', () => {
it('headers', async () => {
nock('http://rsshub.test')
.get('/test')
.reply(function () {
expect(this.req.headers['user-agent']).toBe(config.ua);
return [200, ''];
});
await got.get('http://rsshub.test/test');
});
it('retry', async () => {
const requestRun = jest.fn();
nock('http://rsshub.test')
.get('/testRerty')
.times(config.requestRetry + 1)
.reply(function () {
requestRun();
return [503, '0'];
});
try {
await got.get('http://rsshub.test/testRerty');
} catch (error) {
expect(error.name).toBe('HTTPError');
}
// retries
expect(requestRun).toHaveBeenCalledTimes(config.requestRetry + 1);
});
it('axios', async () => {
nock('http://rsshub.test')
.post('/post')
.reply(function () {
return [200, '{"code": 0}'];
});
const response1 = await got.post('http://rsshub.test/post', {
form: {
test: 1,
},
});
expect(response1.statusCode).toBe(200);
expect(response1.status).toBe(200);
expect(response1.body).toBe('{"code": 0}');
expect(response1.data.code).toBe(0);
});
it('timeout', async () => {
nock('http://rsshub.test')
.get('/timeout')
.delay(600)
.reply(function () {
return [200, '{"code": 0}'];
});
const loggerSpy = jest.spyOn(logger, 'error').mockReturnValue({});
try {
await got.get('http://rsshub.test/timeout');
throw Error('Timeout Invalid');
} catch (error) {
expect(error.name).toBe('RequestError');
}
expect(loggerSpy).toHaveBeenCalledWith(expect.stringContaining('http://rsshub.test/timeout'));
loggerSpy.mockRestore();
});
});