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
|
|
|
|
2019-02-08 15:07:35 +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-02-08 15:07:35 +01:00
|
|
|
})
|
2019-10-31 18:48:11 +01:00
|
|
|
const client = createClient(profile, userAgent)
|
2019-02-08 13:42:32 +01:00
|
|
|
|
|
|
|
t.plan(1 + 4)
|
|
|
|
client.departures(spichernstr, {duration: 1})
|
2021-05-20 16:42:43 +01:00
|
|
|
.then(deps => t.same(deps, [], '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
|
|
|
})
|