]> git.immae.eu Git - github/Chocobozzz/PeerTube.git/blame - server/helpers/database-utils.ts
Add follow tests
[github/Chocobozzz/PeerTube.git] / server / helpers / database-utils.ts
CommitLineData
65fcc311 1// TODO: import from ES6 when retry typing file will include errorFilter function
4d4e5cd4 2import * as retry from 'async/retry'
20494f12 3import * as Bluebird from 'bluebird'
65fcc311 4import { logger } from './logger'
4145c1c6 5
69818c93 6type RetryTransactionWrapperOptions = { errorMessage: string, arguments?: any[] }
0f91ae62
C
7function retryTransactionWrapper <T> (
8 functionToRetry: (...args) => Promise<T> | Bluebird<T>,
9 options: RetryTransactionWrapperOptions
10): Promise<T> {
4df023f2
C
11 const args = options.arguments ? options.arguments : []
12
0f91ae62 13 return transactionRetryer<T>(callback => {
075f16ca 14 functionToRetry.apply(this, args)
0f91ae62 15 .then((result: T) => callback(null, result))
6fcd19ba 16 .catch(err => callback(err))
075f16ca 17 })
6fcd19ba 18 .catch(err => {
ad0997ad 19 logger.error(options.errorMessage, err)
20494f12 20 throw err
6fcd19ba 21 })
4df023f2
C
22}
23
0f91ae62
C
24function transactionRetryer <T> (func: (err: any, data: T) => any) {
25 return new Promise<T>((res, rej) => {
6fcd19ba
C
26 retry({
27 times: 5,
4df023f2 28
075f16ca 29 errorFilter: err => {
6fcd19ba
C
30 const willRetry = (err.name === 'SequelizeDatabaseError')
31 logger.debug('Maybe retrying the transaction function.', { willRetry })
32 return willRetry
33 }
20494f12 34 }, func, (err, data) => err ? rej(err) : res(data))
4df023f2
C
35 })
36}
37
38// ---------------------------------------------------------------------------
39
65fcc311 40export {
65fcc311 41 retryTransactionWrapper,
65fcc311
C
42 transactionRetryer
43}