0
0
mirror of https://github.com/PostHog/posthog.git synced 2024-11-28 18:26:15 +01:00
posthog/plugin-server/tests/utils/retries.test.ts

28 lines
1.1 KiB
TypeScript
Raw Normal View History

2023-12-05 16:47:41 +01:00
import { getNextRetryMs } from '../../src/utils/retries'
jest.useFakeTimers()
jest.spyOn(global, 'setTimeout')
describe('getNextRetryMs', () => {
it('returns the correct number of milliseconds with a multiplier of 1', () => {
expect(getNextRetryMs(500, 1, 1)).toBe(500)
expect(getNextRetryMs(500, 1, 2)).toBe(500)
expect(getNextRetryMs(500, 1, 3)).toBe(500)
expect(getNextRetryMs(500, 1, 4)).toBe(500)
expect(getNextRetryMs(500, 1, 5)).toBe(500)
})
it('returns the correct number of milliseconds with a multiplier of 2', () => {
expect(getNextRetryMs(4000, 2, 1)).toBe(4000)
expect(getNextRetryMs(4000, 2, 2)).toBe(8000)
expect(getNextRetryMs(4000, 2, 3)).toBe(16000)
expect(getNextRetryMs(4000, 2, 4)).toBe(32000)
expect(getNextRetryMs(4000, 2, 5)).toBe(64000)
})
it('throws on attempt below 0', () => {
expect(() => getNextRetryMs(4000, 2, 0)).toThrowError('Attempts are indexed starting with 1')
expect(() => getNextRetryMs(4000, 2, -1)).toThrowError('Attempts are indexed starting with 1')
})
})