2022-01-12 00:50:11 +00:00
|
|
|
// Copyright 2022 Signal Messenger, LLC
|
|
|
|
// SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
|
|
|
|
import { assert } from 'chai';
|
|
|
|
|
|
|
|
import { findRetryAfterTimeFromError } from '../../../jobs/helpers/findRetryAfterTimeFromError';
|
|
|
|
import { HTTPError } from '../../../textsecure/Errors';
|
2022-01-31 21:09:58 +00:00
|
|
|
import { MINUTE } from '../../../util/durations';
|
2022-01-12 00:50:11 +00:00
|
|
|
|
|
|
|
describe('findRetryAfterTimeFromError', () => {
|
2022-01-31 21:09:58 +00:00
|
|
|
it('returns 1 minute if no Retry-After time is found', () => {
|
2022-01-12 00:50:11 +00:00
|
|
|
[
|
|
|
|
undefined,
|
|
|
|
null,
|
|
|
|
{},
|
|
|
|
{ responseHeaders: {} },
|
|
|
|
{ responseHeaders: { 'retry-after': 'garbage' } },
|
2022-01-31 21:09:58 +00:00
|
|
|
{ responseHeaders: { 'retry-after': '0.5' } },
|
|
|
|
{ responseHeaders: { 'retry-after': '12.34' } },
|
2022-01-12 00:50:11 +00:00
|
|
|
{
|
|
|
|
httpError: new HTTPError('Slow down', {
|
|
|
|
code: 413,
|
|
|
|
headers: {},
|
|
|
|
response: {},
|
|
|
|
}),
|
|
|
|
},
|
|
|
|
{
|
|
|
|
httpError: new HTTPError('Slow down', {
|
|
|
|
code: 413,
|
|
|
|
headers: { 'retry-after': 'garbage' },
|
|
|
|
response: {},
|
|
|
|
}),
|
|
|
|
},
|
|
|
|
].forEach(input => {
|
2022-01-31 21:09:58 +00:00
|
|
|
assert.strictEqual(findRetryAfterTimeFromError(input), MINUTE);
|
2022-01-12 00:50:11 +00:00
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it("returns 1 second if a Retry-After time is found, but it's less than 1 second", () => {
|
2022-01-31 21:09:58 +00:00
|
|
|
['0', '-99'].forEach(headerValue => {
|
2022-01-12 00:50:11 +00:00
|
|
|
const input = { responseHeaders: { 'retry-after': headerValue } };
|
|
|
|
assert.strictEqual(findRetryAfterTimeFromError(input), 1000);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2022-01-31 21:09:58 +00:00
|
|
|
it('returns 1 minute for extremely large numbers', () => {
|
2022-01-12 00:50:11 +00:00
|
|
|
const input = { responseHeaders: { 'retry-after': '999999999999999999' } };
|
2022-01-31 21:09:58 +00:00
|
|
|
assert.strictEqual(findRetryAfterTimeFromError(input), MINUTE);
|
2022-01-12 00:50:11 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
it('finds the retry-after time on top-level response headers', () => {
|
|
|
|
const input = { responseHeaders: { 'retry-after': '1234' } };
|
|
|
|
assert.strictEqual(findRetryAfterTimeFromError(input), 1234 * 1000);
|
|
|
|
});
|
|
|
|
|
|
|
|
it("finds the retry-after time on an HTTP error's response headers", () => {
|
|
|
|
const input = {
|
|
|
|
httpError: new HTTPError('Slow down', {
|
|
|
|
code: 413,
|
|
|
|
headers: { 'retry-after': '1234' },
|
|
|
|
response: {},
|
|
|
|
}),
|
|
|
|
};
|
|
|
|
assert.strictEqual(findRetryAfterTimeFromError(input), 1234 * 1000);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('prefers the top-level response headers over an HTTP error', () => {
|
|
|
|
const input = {
|
|
|
|
responseHeaders: { 'retry-after': '1234' },
|
|
|
|
httpError: new HTTPError('Slow down', {
|
|
|
|
code: 413,
|
|
|
|
headers: { 'retry-after': '999' },
|
|
|
|
response: {},
|
|
|
|
}),
|
|
|
|
};
|
|
|
|
assert.strictEqual(findRetryAfterTimeFromError(input), 1234 * 1000);
|
|
|
|
});
|
|
|
|
});
|