- config/
- node_modules/
- client
+- scripts/
- server/tests/
- .tmp/
// Handle retries on fail
function addRemoteVideoRetryWrapper (videoToCreateData, fromPod, finalCallback) {
- utils.transactionRetryer(
- function (callback) {
- return addRemoteVideo(videoToCreateData, fromPod, callback)
- },
- function (err) {
- if (err) {
- logger.error('Cannot insert the remote video with many retries.', { error: err })
- }
+ const options = {
+ arguments: [ videoToCreateData, fromPod ],
+ errorMessage: 'Cannot insert the remote video with many retries.'
+ }
- // Do not return the error, continue the process
- return finalCallback(null)
- }
- )
+ utils.retryWrapper(addRemoteVideo, options, finalCallback)
}
function addRemoteVideo (videoToCreateData, fromPod, finalCallback) {
// Handle retries on fail
function updateRemoteVideoRetryWrapper (videoAttributesToUpdate, fromPod, finalCallback) {
- utils.transactionRetryer(
- function (callback) {
- return updateRemoteVideo(videoAttributesToUpdate, fromPod, callback)
- },
- function (err) {
- if (err) {
- logger.error('Cannot update the remote video with many retries.', { error: err })
- }
+ const options = {
+ arguments: [ fromPod, videoAttributesToUpdate ],
+ errorMessage: 'Cannot update the remote video with many retries'
+ }
- // Do not return the error, continue the process
- return finalCallback(null)
- }
- )
+ utils.retryWrapper(updateRemoteVideo, options, finalCallback)
}
function updateRemoteVideo (videoAttributesToUpdate, fromPod, finalCallback) {
// Wrapper to video add that retry the function if there is a database error
// We need this because we run the transaction in SERIALIZABLE isolation that can fail
function addVideoRetryWrapper (req, res, next) {
- utils.transactionRetryer(
- function (callback) {
- return addVideo(req, res, req.files.videofile[0], callback)
- },
- function (err) {
- if (err) {
- logger.error('Cannot insert the video with many retries.', { error: err })
- return next(err)
- }
+ const options = {
+ arguments: [ req, res, req.files.videofile[0] ],
+ errorMessage: 'Cannot insert the video with many retries.'
+ }
- // TODO : include Location of the new video -> 201
- return res.type('json').status(204).end()
- }
- )
+ utils.retryWrapper(addVideo, options, function (err) {
+ if (err) return next(err)
+
+ // TODO : include Location of the new video -> 201
+ return res.type('json').status(204).end()
+ })
}
function addVideo (req, res, videoFile, callback) {
}
function updateVideoRetryWrapper (req, res, next) {
- utils.transactionRetryer(
- function (callback) {
- return updateVideo(req, res, callback)
- },
- function (err) {
- if (err) {
- logger.error('Cannot update the video with many retries.', { error: err })
- return next(err)
- }
+ const options = {
+ arguments: [ req, res ],
+ errorMessage: 'Cannot update the video with many retries.'
+ }
- // TODO : include Location of the new video -> 201
- return res.type('json').status(204).end()
- }
- )
+ utils.retryWrapper(updateVideo, options, function (err) {
+ if (err) return next(err)
+
+ // TODO : include Location of the new video -> 201
+ return res.type('json').status(204).end()
+ })
}
function updateVideo (req, res, finalCallback) {
generateRandomString,
isTestInstance,
getFormatedObjects,
+ retryWrapper,
transactionRetryer
}
}
}
+// { arguments, errorMessage }
+function retryWrapper (functionToRetry, options, finalCallback) {
+ const args = options.arguments ? options.arguments : []
+
+ utils.transactionRetryer(
+ function (callback) {
+ return functionToRetry.apply(this, args.concat([ callback ]))
+ },
+ function (err) {
+ if (err) {
+ logger.error(options.errorMessage, { error: err })
+ }
+
+ // Do not return the error, continue the process
+ return finalCallback(null)
+ }
+ )
+}
+
function transactionRetryer (func, callback) {
retry({
times: 5,