db-vendo-client/test/retry.js

62 lines
1.5 KiB
JavaScript
Raw Normal View History

2019-02-08 13:42:32 +01:00
'use strict'
2021-05-20 16:42:43 +01:00
const tap = require('tap')
2019-02-08 13:42:32 +01:00
const createClient = require('..')
2019-10-31 18:48:11 +01:00
const withRetrying = require('../retry')
2019-02-08 13:42:32 +01:00
const vbbProfile = require('../p/vbb')
const userAgent = 'public-transport/hafas-client:test'
const spichernstr = '900000042101'
2021-05-20 16:42:43 +01:00
tap.test('withRetrying works', (t) => {
2019-02-08 13:42:32 +01:00
// for the first 3 calls, return different kinds of errors
let calls = 0
2019-10-31 18:48:11 +01:00
const failingRequest = async (ctx, userAgent, reqData) => {
2019-02-08 13:42:32 +01:00
calls++
if (calls === 1) {
const err = new Error('HAFAS error')
err.isHafasError = true
return Promise.reject(err)
}
if (calls === 2) {
const err = new Error('fetch error')
err.code = 'EFOO'
return Promise.reject(err)
}
if (calls < 4) return Promise.reject(new Error('generic error'))
2019-10-31 18:48:11 +01:00
return {
res: [],
common: {}
}
2019-02-08 13:42:32 +01:00
}
2019-10-31 18:48:11 +01:00
const profile = withRetrying({
...vbbProfile,
request: failingRequest
}, {
2019-02-08 13:42:32 +01:00
retries: 3,
minTimeout: 100,
factor: 2,
randomize: false
})
2019-10-31 18:48:11 +01:00
const client = createClient(profile, userAgent)
2019-02-08 13:42:32 +01:00
t.plan(2 + 4)
2019-02-08 13:42:32 +01:00
client.departures(spichernstr, {duration: 1})
.then((res) => {
const {
departures: deps,
realtimeDataUpdatedAt,
} = res
t.same(deps, [], 'resolved with invalid value')
t.equal(realtimeDataUpdatedAt, null, 'resolved with invalid value')
})
2019-02-08 13:42:32 +01:00
.catch(t.ifError)
setTimeout(() => t.equal(calls, 1), 50) // buffer
2021-05-20 16:56:41 +01:00
setTimeout(() => t.equal(calls, 2), 200) // 100 + buffer
setTimeout(() => t.equal(calls, 3), 450) // 100 + 200 + buffer
setTimeout(() => t.equal(calls, 4), 900) // 100 + 200 + 400 + buffer
2019-02-08 13:42:32 +01:00
})