UNPKG

openhim-core

Version:

The OpenHIM core application that provides logging and routing of http requests

354 lines (353 loc) 12.8 kB
<!doctype html> <html lang="en"> <head> <title>Code coverage report for src/autoRetry.coffee</title> <meta charset="utf-8" /> <link rel="stylesheet" href="../prettify.css" /> <link rel="stylesheet" href="../base.css" /> <meta name="viewport" content="width=device-width, initial-scale=1"> <style type='text/css'> .coverage-summary .sorter { background-image: url(../sort-arrow-sprite.png); } </style> </head> <body> <div class='wrapper'> <div class='pad1'> <h1> <a href="../index.html">All files</a> / <a href="index.html">src</a> autoRetry.coffee </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">46.34% </span> <span class="quiet">Statements</span> <span class='fraction'>19/41</span> </div> <div class='fl pad1y space-right2'> <span class="strong">0% </span> <span class="quiet">Branches</span> <span class='fraction'>0/5</span> </div> <div class='fl pad1y space-right2'> <span class="strong">0% </span> <span class="quiet">Functions</span> <span class='fraction'>0/19</span> </div> <div class='fl pad1y space-right2'> <span class="strong">47.5% </span> <span class="quiet">Lines</span> <span class='fraction'>19/40</span> </div> </div> </div> <div class='status-line low'></div> <pre><table class="coverage"> <tr><td class="line-count quiet">1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97</td><td class="line-coverage quiet"><span class="cline-any cline-yes">1x</span> <span class="cline-any cline-yes">1x</span> <span class="cline-any cline-yes">1x</span> <span class="cline-any cline-yes">1x</span> <span class="cline-any cline-yes">1x</span> <span class="cline-any cline-yes">1x</span> <span class="cline-any cline-yes">1x</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">1x</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">1x</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">1x</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">1x</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">1x</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">1x</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">1x</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">1x</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">1x</span> <span class="cline-any cline-yes">1x</span> <span class="cline-any cline-yes">1x</span> <span class="cline-any cline-yes">1x</span> <span class="cline-any cline-neutral">&nbsp;</span></td><td class="text"><pre class="prettyprint lang-js">logger = require "winston" moment = require 'moment' Q = require 'q' Channels = require('./model/channels') Channel = Channels.Channel AutoRetry = require('./model/autoRetry').AutoRetry Task = require('./model/tasks').Task &nbsp; exports.reachedMaxAttempts = <span class="fstat-no" title="function not covered" >(</span>tx, channel) -&gt; <span class="cstat-no" title="statement not covered" > return channel.autoRetryMaxAttempts? and</span> channel.autoRetryMaxAttempts &gt; 0 and tx.autoRetryAttempt &gt;= channel.autoRetryMaxAttempts &nbsp; exports.queueForRetry = <span class="fstat-no" title="function not covered" >(</span>tx) -&gt; <span class="cstat-no" title="statement not covered" > retry = new A</span>utoRetry transactionID: tx._id channelID: tx.channelID requestTimestamp: tx.request.timestamp retry.save <span class="fstat-no" title="function not covered" >(</span>err) -&gt; if err logger.error "Failed to queue transaction #{tx._id} for auto retry: #{err}" &nbsp; getChannels = <span class="fstat-no" title="function not covered" >(</span>callback) -&gt; Channel.find autoRetryEnabled: true, status: 'enabled', callback &nbsp; popTransactions = <span class="fstat-no" title="function not covered" >(</span>channel, callback) -&gt; <span class="cstat-no" title="statement not covered" > to = m</span>oment().subtract channel.autoRetryPeriodMinutes-1, 'minutes' &nbsp; query = $and: [ channelID: channel._id , 'requestTimestamp': $lte: to.toDate() ] &nbsp; <span class="cstat-no" title="statement not covered" > logger.debug "Executing query autoRetry.findAndRemove(#{JSON.stringify query})"</span> AutoRetry.find query, <span class="fstat-no" title="function not covered" >(</span>err, transactions) -&gt; <span class="cstat-no" title="statement not covered" ></span> return callback err if err <span class="cstat-no" title="statement not covered" ></span> return callback null, [] if transactions.length is 0 AutoRetry.remove _id: $in: (transactions.map <span class="fstat-no" title="function not covered" >(</span>t) -&gt; t._id), <span class="fstat-no" title="function not covered" >(</span>err) -&gt; <span class="cstat-no" title="statement not covered" ></span> return callback err if err callback null, transactions &nbsp; createRerunTask = <span class="fstat-no" title="function not covered" >(</span>transactionIDs, callback) -&gt; <span class="cstat-no" title="statement not covered" > logger.info "Rerunning failed transactions: #{transactionIDs}"</span> <span class="cstat-no" title="statement not covered" > task = new T</span>ask transactions: (transactionIDs.map <span class="fstat-no" title="function not covered" >(</span>t) -&gt; tid: t ) totalTransactions: transactionIDs.length remainingTransactions: transactionIDs.length user: 'internal' &nbsp; task.save <span class="fstat-no" title="function not covered" >(</span>err) -&gt; <span class="cstat-no" title="statement not covered" ></span> logger.error err if err callback() &nbsp; autoRetryTask = <span class="fstat-no" title="function not covered" >(</span>job, done) -&gt; <span class="cstat-no" title="statement not covered" > _taskStart = new D</span>ate() <span class="cstat-no" title="statement not covered" > transactionsToRerun = [</span>] &nbsp; getChannels <span class="fstat-no" title="function not covered" >(</span>err, results) -&gt; <span class="cstat-no" title="statement not covered" > promises = [</span>] &nbsp; <span class="cstat-no" title="statement not covered" > for channel in results</span> do <span class="fstat-no" title="function not covered" >(</span>channel) -&gt; <span class="cstat-no" title="statement not covered" > deferred = Q</span>.defer() &nbsp; <span class="cstat-no" title="statement not covered" > popTransactions channel, <span class="fstat-no" title="function not covered" >(</span>err, results) -&gt;</span> if err <span class="cstat-no" title="statement not covered" > logger.error err</span> else if results? and results.length&gt;0 <span class="cstat-no" title="statement not covered" ><span class="cstat-no" title="statement not covered" > transactionsToRerun.push tid for tid in (results.map((r) -&gt; r.transactionID))</span></span> deferred.resolve() &nbsp; promises.push deferred.promise &nbsp; (Q.all promises).then <span class="fstat-no" title="function not covered" ></span>-&gt; <span class="cstat-no" title="statement not covered" > end = <span class="fstat-no" title="function not covered" ></span>-</span>&gt; <span class="cstat-no" title="statement not covered" > logger.debug "Auto retry task total time: #{new Date()-_taskStart} ms"</span> done() if transactionsToRerun.length &gt; 0 createRerunTask transactionsToRerun, end else end() &nbsp; &nbsp; setupAgenda = <span class="fstat-no" title="function not covered" >(</span>agenda) -&gt; <span class="cstat-no" title="statement not covered" > agenda.define 'auto retry failed transactions', <span class="fstat-no" title="function not covered" >(</span>job, done) -&gt; autoRetryTask job, done</span> agenda.every '1 minutes', 'auto retry failed transactions' &nbsp; &nbsp; exports.setupAgenda = setupAgenda &nbsp; if process.env.NODE_ENV is "test" exports.getChannels = getChannels exports.popTransactions = popTransactions exports.createRerunTask = createRerunTask exports.autoRetryTask = autoRetryTask &nbsp;</pre></td></tr> </table></pre> <div class='push'></div><!-- for sticky footer --> </div><!-- /wrapper --> <div class='footer quiet pad2 space-top1 center small'> Code coverage generated by <a href="http://istanbul-js.org/" target="_blank">istanbul</a> at Mon Oct 10 2016 13:39:22 GMT+0200 (SAST) </div> </div> <script src="../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../sorter.js"></script> </body> </html>