UNPKG

offshore

Version:
336 lines (335 loc) 10 kB
<!doctype html> <html lang="en"> <head> <title>Code coverage report for lib/offshore/query/index.js</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">lib/offshore/query/</a> index.js </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">88% </span> <span class="quiet">Statements</span> <span class='fraction'>22/25</span> </div> <div class='fl pad1y space-right2'> <span class="strong">75% </span> <span class="quiet">Branches</span> <span class='fraction'>9/12</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Functions</span> <span class='fraction'>4/4</span> </div> <div class='fl pad1y space-right2'> <span class="strong">91.67% </span> <span class="quiet">Lines</span> <span class='fraction'>22/24</span> </div> </div> </div> <div class='status-line high'></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</td><td class="line-coverage quiet"><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"></span> <span class="cline-any cline-yes"></span> <span class="cline-any cline-yes"></span> <span class="cline-any cline-yes"></span> <span class="cline-any cline-yes"></span> <span class="cline-any cline-yes"></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"></span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">410×</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">410×</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">410×</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-yes"></span> <span class="cline-any cline-yes">320×</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-yes">320×</span> <span class="cline-any cline-yes">321×</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">321×</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-yes">320×</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">320×</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">320×</span> <span class="cline-any cline-yes">320×</span> <span class="cline-any cline-yes">320×</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-neutral">&nbsp;</span> <span class="cline-any cline-yes"></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-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"></span> <span class="cline-any cline-neutral">&nbsp;</span></td><td class="text"><pre class="prettyprint lang-js">/** * Dependencies */ &nbsp; var _ = require('lodash'); var extend = require('../utils/extend'); var AdapterBase = require('../adapter'); var utils = require('../utils/helpers'); var AdapterMixin = require('./adapters'); var hop = utils.object.hasOwnProperty; &nbsp; /** * Query */ &nbsp; var Query = module.exports = function() { // Create a reference to an internal Adapter Base this.adapter = new AdapterBase({ connections: this.connections, query: this, collection: this.tableName || this.identity, identity: this.identity }); &nbsp; // Mixin Custom Adapter Functions. AdapterMixin.call(this); &nbsp; // Generate Dynamic Finders this.buildDynamicFinders(); }; &nbsp; &nbsp; /** * Automigrate * * @param {Function} cb */ Query.prototype.sync = function(cb) { var self = this; &nbsp; // If any adapters used in this collection have syncable turned off set migrate to safe. // // I don't think a collection would ever need two adapters where one needs migrations and // the other doesn't but it may be a possibility. The way the auto-migrations work now doesn't // allow for this either way so this should be good. We will probably need to revist this soonish // however and take a pass at getting something working for better migration systems. // - particlebanana &nbsp; _.keys(this.connections).forEach(function(connectionName) { var adapter = self.connections[connectionName]._adapter; &nbsp; // If not syncable, don't sync <span class="missing-if-branch" title="if path not taken" >I</span>if (hop(adapter, 'syncable') &amp;&amp; !adapter.syncable) { <span class="cstat-no" title="statement not covered" > self.migrate = 'safe';</span> } }); &nbsp; // Assign synchronization behavior depending on migrate option in collection <span class="missing-if-branch" title="else path not taken" >E</span>if (this.migrate &amp;&amp; ['drop', 'alter', 'create', 'safe'].indexOf(this.migrate) &gt; -1) { &nbsp; // Determine which sync strategy to use var strategyMethodName = 'migrate' + utils.capitalize(this.migrate); &nbsp; // Run automigration strategy this.adapter[strategyMethodName](function(err) { <span class="missing-if-branch" title="if path not taken" >I</span>if (err) <span class="cstat-no" title="statement not covered" >return cb(err);</span> cb(); }); } &nbsp; // Throw Error else <span class="cstat-no" title="statement not covered" >cb(new Error('Invalid `migrate` strategy defined for collection. Must be one of the following: drop, alter, create, safe'));</span> }; &nbsp; &nbsp; _.extend( Query.prototype, require('./validate'), require('./ddl'), require('./dql'), require('./aggregate'), require('./composite'), require('./finders/basic'), require('./finders/helpers'), require('./finders/dynamicFinders'), require('./stream') ); &nbsp; // Make Extendable Query.extend = extend; &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 Tue Apr 17 2018 10:49:40 GMT+0200 (CEST) </div> </div> <script src="../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../sorter.js"></script> </body> </html>