2021-07-23 22:02:36 +00:00
|
|
|
// Copyright 2021 Signal Messenger, LLC
|
|
|
|
// SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
|
|
|
|
import { assert } from 'chai';
|
2021-08-26 14:10:58 +00:00
|
|
|
import * as durations from '../../util/durations';
|
2021-07-23 22:02:36 +00:00
|
|
|
|
|
|
|
import {
|
|
|
|
exponentialBackoffSleepTime,
|
|
|
|
exponentialBackoffMaxAttempts,
|
|
|
|
} from '../../util/exponentialBackoff';
|
|
|
|
|
|
|
|
describe('exponential backoff utilities', () => {
|
|
|
|
describe('exponentialBackoffSleepTime', () => {
|
|
|
|
it('returns slowly growing values', () => {
|
|
|
|
assert.strictEqual(exponentialBackoffSleepTime(1), 0);
|
|
|
|
assert.strictEqual(exponentialBackoffSleepTime(2), 190);
|
|
|
|
assert.strictEqual(exponentialBackoffSleepTime(3), 361);
|
|
|
|
assert.approximately(exponentialBackoffSleepTime(4), 686, 1);
|
|
|
|
assert.approximately(exponentialBackoffSleepTime(5), 1303, 1);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('plateaus at a maximum after 15 attempts', () => {
|
2021-08-26 14:10:58 +00:00
|
|
|
const maximum = 15 * durations.MINUTE;
|
2021-07-23 22:02:36 +00:00
|
|
|
for (let attempt = 16; attempt < 100; attempt += 1) {
|
|
|
|
assert.strictEqual(exponentialBackoffSleepTime(attempt), maximum);
|
|
|
|
}
|
|
|
|
});
|
2024-04-16 00:11:48 +00:00
|
|
|
|
|
|
|
it('respects custom variables', () => {
|
|
|
|
const options = {
|
|
|
|
maxBackoffTime: 10000,
|
|
|
|
multiplier: 2,
|
|
|
|
firstBackoffTime: 1000,
|
|
|
|
};
|
|
|
|
assert.strictEqual(exponentialBackoffSleepTime(1, options), 0);
|
|
|
|
assert.strictEqual(exponentialBackoffSleepTime(2, options), 1000);
|
|
|
|
assert.strictEqual(exponentialBackoffSleepTime(3, options), 2000);
|
|
|
|
assert.strictEqual(exponentialBackoffSleepTime(4, options), 4000);
|
|
|
|
assert.strictEqual(exponentialBackoffSleepTime(5, options), 8000);
|
|
|
|
assert.strictEqual(exponentialBackoffSleepTime(6, options), 10000);
|
|
|
|
assert.strictEqual(exponentialBackoffSleepTime(7, options), 10000);
|
|
|
|
});
|
2021-07-23 22:02:36 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
describe('exponentialBackoffMaxAttempts', () => {
|
|
|
|
it('returns 2 attempts for a short period of time', () => {
|
|
|
|
assert.strictEqual(exponentialBackoffMaxAttempts(1), 2);
|
|
|
|
assert.strictEqual(exponentialBackoffMaxAttempts(99), 2);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('returns 6 attempts for a 5 seconds', () => {
|
|
|
|
assert.strictEqual(exponentialBackoffMaxAttempts(5000), 6);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('returns 110 attempts for 1 day', () => {
|
|
|
|
// This is a test case that is lifted from iOS's codebase.
|
2021-08-26 14:10:58 +00:00
|
|
|
assert.strictEqual(exponentialBackoffMaxAttempts(durations.DAY), 110);
|
2021-07-23 22:02:36 +00:00
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|