├── .gitignore ├── .travis.yml ├── Changelog.md ├── Readme.md ├── config └── cleaner-config.js ├── examples └── mongodb.example.js ├── index.js ├── lib └── database-cleaner.js ├── package-lock.json ├── package.json └── test ├── couchdb.test.js ├── elasticsearch.test.js ├── mongodb.test.js ├── mysql.test.js ├── postgresql.test.js ├── redis.test.js └── sqlite.test.js /.gitignore: -------------------------------------------------------------------------------- 1 | node_modules 2 | .tmp_*~ 3 | *# 4 | .#* 5 | *.swp 6 | -------------------------------------------------------------------------------- /.travis.yml: -------------------------------------------------------------------------------- 1 | sudo: false 2 | language: node_js 3 | node_js: 4 | - 8 5 | - node 6 | - lts/* 7 | services: 8 | - mongodb 9 | - redis 10 | - couchdb 11 | - mysql 12 | - postgresql 13 | - elasticsearch 14 | before_script: 15 | - curl -X PUT localhost:5984/database_cleaner 16 | - mysql -e 'create database database_cleaner;' 17 | - createdb database_cleaner 18 | -------------------------------------------------------------------------------- /Changelog.md: -------------------------------------------------------------------------------- 1 | 1.3.0 / 2018-11-20 2 | ================== 3 | * Upgrade deps to newest versions 4 | * Fixing Node deps security warning - Node 8, LTS and Stable 5 | * fix: postgres -> error: cannot truncate a table referenced in a foreign key constraint (Sergei Khoma - @srghma) 6 | 7 | 1.2.0 / 2016-11-15 8 | ================== 9 | 10 | * Support pooled MySQL connections (Rob Wells) 11 | * Fix: Do not drop VIEWS (Matteo Ferrando) 12 | 13 | 1.1.0 / 2016-08-16 14 | ================== 15 | 16 | * Support for specifying postgres schema (Ian Zabel) 17 | 18 | 1.0.0 / 2016-06-25 19 | ================== 20 | 21 | * Sequence reset for postgres truncation (Matheus Pedroso) 22 | * Skip system.indexes when delete MongoDB collections (Kostas Bariotis) 23 | 24 | 0.13.0 / 2016-03-25 25 | ================== 26 | 27 | * Cleanup now have two strategy options. 'delete' (default) or 'truncate'. (yads) 28 | 29 | 0.12.0 / 2016-02-25 30 | ================== 31 | 32 | * Elastic Search support (luizgpsantos) 33 | * Removed version 0.8.x support (emerleite) 34 | * Handle errors and pass it to the callback (gabceb) 35 | 36 | 0.11.0 / 2016-01-13 37 | ================== 38 | 39 | * Allow to pass the config data on initialize (gabceb) 40 | * Fix: mysql/postgesql stuck if no table to clean. (Amoki) 41 | 42 | 0.10.1 / 2015-10-09 43 | ================== 44 | 45 | * Fix: Config can be relative to executing dir. Closes #31 (knappe) 46 | 47 | 0.10.0 / 2015-07-20 48 | ================== 49 | 50 | * Allow skip tables during tests. Supports MySQL and Postgres 51 | 52 | 0.9.2 / 2015-07-15 53 | ================== 54 | 55 | * MySQL cleanner. Issue #25 56 | * Postgres: quote database table name when delete data, fixed an issue when table name is capitalized. Pull Request #23 57 | 58 | 0.9.1 / 2014-01-24 59 | ================== 60 | 61 | * Moved all dependencies to devDependencies because you only need than on test environment. Closes issues #20 and #21. 62 | 63 | 0.9.0 / 2014-10-25 64 | ================== 65 | 66 | * Postgres support 67 | * Added POSTGRES_HOST, MYSQL_HOST and COUCHDB_HOST to allow use another ip than localhost when testing. 68 | 69 | 0.8.0 / 2014-10-03 70 | ================== 71 | 72 | * DatabaseCleanner global leak fixed. 73 | * Supports only node >= 0.8.0 74 | 75 | 0.7.0 / 2011-12-18 76 | ================== 77 | * Remove system.indexes during cleanner - Issue #13 (mongodb) 78 | * Invoke callback even if empty collection - Bug #14 and #15 (mongodb) 79 | * Mongodb usage example at examples dir 80 | * Updated mongodb, cradle, mysql and redis pkg versions 81 | 82 | 0.6.1 / 2011-12-18 83 | ================== 84 | * rewrited all tests using mocha 85 | * removed nodeunit dependency (not used anymore) 86 | 87 | 0.6.0 / 2011-11-05 88 | ================== 89 | * Node.JS 0.6.0 compatibility - Issue #10 90 | * Fixed nodeunit dependency version 91 | * Using database 1 for redis tests to not screw up user database 92 | * Added a test script to not require user install nodeunit globaly 93 | 94 | 0.5.0 / 2011-09-28 95 | ================== 96 | * Removed mongoose dependency and using only mongodb native driver 97 | * Fixed mongodb driver update - Issue #9 98 | 99 | 0.4.0 / 2011-08-08 100 | ================== 101 | 102 | * Mysql Support (Dai Akatsuka - https://github.com/dakatsuka) 103 | 104 | 0.3.3 / 2011-05-10 105 | ================== 106 | 107 | * Added dependencies and dev dependencies 108 | 109 | 0.3.2 / 2011-03-09 110 | ================== 111 | 112 | * Using index.js as main in package.json. This is a standard in npm 113 | 114 | 0.3.1 / 2011-03-09 115 | ================== 116 | 117 | * Updated package.json to work with npm >= 0.3 (Zach Smith - https://github.com/xcoderzach) 118 | 119 | 0.3.0 / 2011-03-04 120 | ================== 121 | 122 | * Added couchdb support usign cradle (http://cloudhead.io/cradle) 123 | 124 | 0.2.0 / 2011-03-02 125 | ================== 126 | 127 | * Added redis support 128 | * Changed the API 129 | * Updated documentation with the new API sintax 130 | 131 | 0.1.1 / 2011-02-09 132 | ================== 133 | 134 | * Added node-mongodb-native as a project dependency 135 | 136 | 0.1.0 / 2011-02-09 137 | ================== 138 | 139 | * Support MongoDB 140 | * Clean all databases but system.indexes 141 | * Basic test structure 142 | * Initial documentation 143 | -------------------------------------------------------------------------------- /Readme.md: -------------------------------------------------------------------------------- 1 | [![Build Status](https://secure.travis-ci.org/emerleite/node-database-cleaner.png)](http://travis-ci.org/emerleite/node-database-cleaner) 2 | 3 | Node.js Database Cleaner 4 | ======================== 5 | The simplest way to clean your database. 6 | 7 | Say you're doing test cases. How can you clean up your data after each 8 | test run? With Database Cleaner you can simply do it with one line of code. 9 | 10 | Supported Databases 11 | ------------------- 12 | * MongoDB 13 | * Redis 14 | * CouchDB 15 | * MySQL 16 | * Postgres 17 | * Elasticsearch 18 | 19 | Dependencies 20 | ------------ 21 | 22 | ### Runtime 23 | * Node 0.8.x+ 24 | * node-mongodb-native (a.k.a mongodb) 25 | * redis 26 | * cradle for couchdb () 27 | * mysql server 28 | * postgres server 29 | * elasticsearch 30 | 31 | ### Development/Tests 32 | * mocha 33 | * should 34 | * hredis 35 | * redis 36 | * cradle 37 | * mysql 38 | * pg 39 | * elasticsearch 40 | 41 | Installation 42 | ----------- 43 | ```shell 44 | $ npm install database-cleaner 45 | ``` 46 | 47 | Usage 48 | ------ 49 | ```javascript 50 | var DatabaseCleaner = require('database-cleaner'); 51 | var databaseCleaner = new DatabaseCleaner(type); //type = 'mongodb|redis|couchdb' 52 | 53 | databaseCleaner.clean(database, callback); 54 | ``` 55 | 56 | 57 | Config 58 | ------ 59 | By default it attempts to load the config/cleaner-config.js file and will fall back to the [default config](https://github.com/emerleite/node-database-cleaner/blob/master/config/cleaner-config.js). 60 | 61 | Both MySQL and Postgres support truncation and deletion strategies. To specify this strategy specify 62 | the configuration as follows: 63 | 64 | ```javascript 65 | { 66 | postgresql: { 67 | strategy: 'truncation', 68 | skipTables: [] 69 | } 70 | } 71 | ``` 72 | 73 | ### Examples 74 | Take look at test folder to see how it works. 75 | 76 | Look at examples dir. 77 | 78 | Running tests 79 | ------------- 80 | There is some ways to run tests: 81 | 82 | ```shell 83 | $ mocha test # you need mocha globaly installed. `npm install -g mocha` 84 | $ npm test 85 | ``` 86 | 87 | For tests you need each database running (mongodb, redis, couchdb, mysql) 88 | Or run once. Ex: `mocha test/redis.test.js` 89 | 90 | You can also run tests using local mocha. ./node_modules/mocha/bin/mocha 91 | 92 | MySQL 93 | ----- 94 | 95 | To run mysql tests you need to have a database_cleaner database. 96 | 97 | ``` 98 | mysql -u root -e 'create database database_cleaner;' 99 | ``` 100 | 101 | Postgres 102 | -------- 103 | 104 | To run postgres tests you need to have a database_cleaner database. 105 | 106 | ``` 107 | createdb database_cleaner 108 | ``` 109 | 110 | To-Do 111 | ----- 112 | * see () 113 | 114 | Author 115 | ------ 116 | 117 | * Emerson Macedo ( and ) 118 | 119 | License: 120 | -------- 121 | 122 | (The MIT License) 123 | 124 | Permission is hereby granted, free of charge, to any person obtaining 125 | a copy of this software and associated documentation files (the 126 | 'Software'), to deal in the Software without restriction, including 127 | without limitation the rights to use, copy, modify, merge, publish, 128 | distribute, sublicense, and/or sell copies of the Software, and to 129 | permit persons to whom the Software is furnished to do so, subject to 130 | the following conditions: 131 | 132 | The above copyright notice and this permission notice shall be 133 | included in all copies or substantial portions of the Software. 134 | 135 | THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, 136 | EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF 137 | MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. 138 | IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY 139 | CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, 140 | TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE 141 | SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 142 | -------------------------------------------------------------------------------- /config/cleaner-config.js: -------------------------------------------------------------------------------- 1 | module.exports = { 2 | mysql: { 3 | skipTables: ['schema_migrations'] 4 | }, 5 | 6 | postgresql: { 7 | skipTables: ['schema_migrations'] 8 | }, 9 | 10 | sqlite: { 11 | skipTables: ['schema_migrations'] 12 | }, 13 | 14 | mongodb: { 15 | skipCollections: ['schema_migrations'] 16 | } 17 | } 18 | -------------------------------------------------------------------------------- /examples/mongodb.example.js: -------------------------------------------------------------------------------- 1 | var DatabaseCleaner = require('../lib/database-cleaner'); 2 | var databaseCleaner = new DatabaseCleaner('mongodb'); 3 | 4 | var connect = require('mongodb').connect; 5 | 6 | connect('mongodb://localhost/database_cleaner_example', function(err, db) { 7 | databaseCleaner.clean(db, function() { 8 | console.log('done'); 9 | db.close(); 10 | }); 11 | }); 12 | 13 | 14 | -------------------------------------------------------------------------------- /index.js: -------------------------------------------------------------------------------- 1 | module.exports = require('./lib/database-cleaner'); 2 | -------------------------------------------------------------------------------- /lib/database-cleaner.js: -------------------------------------------------------------------------------- 1 | var DatabaseCleaner = module.exports = function(type, config) { 2 | var cleaner = {}; 3 | 4 | if (!config) { 5 | try { 6 | config = require("../../../config/cleaner-config.js"); 7 | } catch(e) { 8 | config = require("../config/cleaner-config.js"); 9 | } 10 | } 11 | 12 | cleaner['mongodb'] = function(db, callback) { 13 | db.collections( function (skip, collections) { 14 | var count = collections.length; 15 | if (count < 1) return callback(); 16 | 17 | var skippedCollections = config.mongodb.skipCollections || []; 18 | 19 | collections.forEach(function (collection) { 20 | if(skippedCollections.indexOf(collection.collectionName) > -1){ 21 | if (--count <= 0 && callback) { 22 | callback(); 23 | } else { 24 | return; 25 | } 26 | } else { 27 | collection.drop(function () { 28 | if (--count <= 0 && callback) { 29 | callback(); 30 | } 31 | }); 32 | } 33 | }); 34 | }); 35 | }; 36 | 37 | cleaner['redis'] = function(db, callback) { 38 | db.flushdb(callback); 39 | }; 40 | 41 | cleaner['couchdb'] = function(db, callback) { 42 | db.destroy(function (err, res) { 43 | if (err) return callback(err); 44 | 45 | db.create(callback); 46 | }); 47 | }; 48 | 49 | cleaner['mysql'] = function(db, callback) { 50 | db.query('show tables', function(err, tables) { 51 | if (err) return callback(err); 52 | 53 | var database = db.config.connectionConfig ? 54 | db.config.connectionConfig.database : db.config.database; 55 | 56 | var count = 0; 57 | var length = tables.length; 58 | var tableName = 'Tables_in_' + database; 59 | var skippedTables = config.mysql.skipTables; 60 | var strategy = config.mysql.strategy || 'deletion'; 61 | if (strategy !== 'deletion' && strategy !== 'truncation') { 62 | return callback(new Error('Invalid deletion strategy: ' + strategy)); 63 | } 64 | 65 | if(length === 0) { 66 | // The database is empty 67 | return callback(); 68 | } 69 | 70 | tables.forEach(function(table) { 71 | if (skippedTables.indexOf(table[tableName]) === -1) { 72 | var statement = strategy === 'deletion' ? 'DELETE FROM ' : 'TRUNCATE TABLE ' 73 | db.query(statement + table[tableName], function(err) { 74 | if(err) { 75 | return callback(err); 76 | } 77 | 78 | count++; 79 | if (count >= length) { 80 | callback(); 81 | } 82 | }); 83 | } else { 84 | count++; 85 | if (count >= length) { 86 | callback(); 87 | } 88 | } 89 | }); 90 | }); 91 | }; 92 | 93 | cleaner['postgresql'] = function(db, callback) { 94 | var schema = config.postgresql.schema || 'public'; 95 | var schemaPrefix = '"' + schema + '".'; 96 | 97 | db.query("SELECT table_name FROM information_schema.tables WHERE table_schema = '" + schema + "' AND table_type = 'BASE TABLE';", function(err, tables) { 98 | if (err) return callback(err); 99 | 100 | var count = 0; 101 | var length = tables.rows.length; 102 | var skippedTables = config.postgresql.skipTables; 103 | var strategy = config.postgresql.strategy || 'deletion'; 104 | if (strategy !== 'deletion' && strategy !== 'truncation') { 105 | return callback(new Error('Invalid deletion strategy: ' + strategy)); 106 | } 107 | 108 | if(length === 0) { 109 | // The database is empty 110 | return callback(); 111 | } 112 | 113 | if (strategy === 'deletion') { 114 | tables.rows.forEach(function(table) { 115 | if (skippedTables.indexOf(table['table_name']) === -1) { 116 | db.query("DELETE FROM " + schemaPrefix + "\"" + table['table_name'] + "\"", function() { 117 | count++; 118 | 119 | if (count >= length) { 120 | callback(); 121 | } 122 | }); 123 | } else { 124 | count++; 125 | if (count >= length) { 126 | callback(); 127 | } 128 | } 129 | }); 130 | } else if (strategy === 'truncation') { 131 | var tableExpression = tables.rows 132 | .filter(function(table) { 133 | return skippedTables.indexOf(table['table_name']) === -1; 134 | }).map(function(table) { 135 | return schemaPrefix + '"' + table['table_name'] + '"'; 136 | }).join(', '); 137 | 138 | // no tables to truncate 139 | if (!tableExpression) { 140 | return callback(); 141 | } 142 | 143 | db.query('TRUNCATE TABLE ' + tableExpression + ' RESTART IDENTITY CASCADE', function(err) { 144 | if(err) { 145 | return callback(err); 146 | } 147 | callback(); 148 | }); 149 | } 150 | 151 | }); 152 | }; 153 | 154 | cleaner['elasticsearch'] = function(db, callback) { 155 | db.indices.delete({index: "*"}, function(err, response) { 156 | callback.apply(); 157 | }); 158 | }; 159 | 160 | cleaner['sqlite'] = function(db, callback) { 161 | var skippedTables = config.sqlite.skipTables; 162 | 163 | return db.all("SELECT name FROM sqlite_master WHERE type='table'", function(err, rows) { 164 | if (err) return callback(err); 165 | 166 | var tables = rows.map(function(row) { 167 | return row.name; 168 | }); 169 | 170 | var num_expected = 0; 171 | var num_returned = 0; 172 | var responded = false; 173 | 174 | function maybeRespond(err) { 175 | if (responded) { 176 | return; 177 | } 178 | 179 | num_returned++; 180 | if (err || num_returned === num_expected) { 181 | responded = true; 182 | callback(err); 183 | } 184 | } 185 | 186 | tables.forEach(function(table) { 187 | if (table === 'sqlite_sequence') return; 188 | if (skippedTables.indexOf(table) !== -1) return; 189 | num_expected++; 190 | db.run("DELETE FROM " + table, maybeRespond); 191 | }); 192 | 193 | if (!num_expected) return callback(); // when there is nothing to clear 194 | }); 195 | }; 196 | 197 | 198 | this.clean = function (db, callback) { 199 | cleaner[type](db, callback); 200 | }; 201 | }; 202 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "database-cleaner", 3 | "version": "1.2.0", 4 | "lockfileVersion": 1, 5 | "requires": true, 6 | "dependencies": { 7 | "abbrev": { 8 | "version": "1.1.1", 9 | "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz", 10 | "integrity": "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q==", 11 | "dev": true 12 | }, 13 | "agentkeepalive": { 14 | "version": "3.5.2", 15 | "resolved": "https://registry.npmjs.org/agentkeepalive/-/agentkeepalive-3.5.2.tgz", 16 | "integrity": "sha512-e0L/HNe6qkQ7H19kTlRRqUibEAwDK5AFk6y3PtMsuut2VAH6+Q4xZml1tNDJD7kSAyqmbG/K08K5WEJYtUrSlQ==", 17 | "dev": true, 18 | "requires": { 19 | "humanize-ms": "^1.2.1" 20 | } 21 | }, 22 | "ajv": { 23 | "version": "6.5.5", 24 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.5.5.tgz", 25 | "integrity": "sha512-7q7gtRQDJSyuEHjuVgHoUa2VuemFiCMrfQc9Tc08XTAc4Zj/5U1buQJ0HU6i7fKjXU09SVgSmxa4sLvuvS8Iyg==", 26 | "dev": true, 27 | "requires": { 28 | "fast-deep-equal": "^2.0.1", 29 | "fast-json-stable-stringify": "^2.0.0", 30 | "json-schema-traverse": "^0.4.1", 31 | "uri-js": "^4.2.2" 32 | } 33 | }, 34 | "ansi-regex": { 35 | "version": "2.1.1", 36 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz", 37 | "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=", 38 | "dev": true 39 | }, 40 | "ansi-styles": { 41 | "version": "2.2.1", 42 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-2.2.1.tgz", 43 | "integrity": "sha1-tDLdM1i2NM914eRmQ2gkBTPB3b4=", 44 | "dev": true 45 | }, 46 | "aproba": { 47 | "version": "1.2.0", 48 | "resolved": "https://registry.npmjs.org/aproba/-/aproba-1.2.0.tgz", 49 | "integrity": "sha512-Y9J6ZjXtoYh8RnXVCMOU/ttDmk1aBjunq9vO0ta5x85WDQiQfUF9sIPBITdbiiIVcBo03Hi3jMxigBtsddlXRw==", 50 | "dev": true 51 | }, 52 | "are-we-there-yet": { 53 | "version": "1.1.5", 54 | "resolved": "https://registry.npmjs.org/are-we-there-yet/-/are-we-there-yet-1.1.5.tgz", 55 | "integrity": "sha512-5hYdAkZlcG8tOLujVDTgCT+uPX0VnpAH28gWsLfzpXYm7wP6mp5Q/gYyR7YQ0cKVJcXJnl3j2kpBan13PtQf6w==", 56 | "dev": true, 57 | "requires": { 58 | "delegates": "^1.0.0", 59 | "readable-stream": "^2.0.6" 60 | }, 61 | "dependencies": { 62 | "isarray": { 63 | "version": "1.0.0", 64 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 65 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=", 66 | "dev": true 67 | }, 68 | "readable-stream": { 69 | "version": "2.3.6", 70 | "resolved": "http://registry.npmjs.org/readable-stream/-/readable-stream-2.3.6.tgz", 71 | "integrity": "sha512-tQtKA9WIAhBF3+VLAseyMqZeBjW0AHJoxOtYqSUZNJxauErmLbVm2FW1y+J/YA9dUrAC39ITejlZWhVIwawkKw==", 72 | "dev": true, 73 | "requires": { 74 | "core-util-is": "~1.0.0", 75 | "inherits": "~2.0.3", 76 | "isarray": "~1.0.0", 77 | "process-nextick-args": "~2.0.0", 78 | "safe-buffer": "~5.1.1", 79 | "string_decoder": "~1.1.1", 80 | "util-deprecate": "~1.0.1" 81 | } 82 | }, 83 | "string_decoder": { 84 | "version": "1.1.1", 85 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", 86 | "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", 87 | "dev": true, 88 | "requires": { 89 | "safe-buffer": "~5.1.0" 90 | } 91 | } 92 | } 93 | }, 94 | "asn1": { 95 | "version": "0.2.4", 96 | "resolved": "https://registry.npmjs.org/asn1/-/asn1-0.2.4.tgz", 97 | "integrity": "sha512-jxwzQpLQjSmWXgwaCZE9Nz+glAG01yF1QnWgbhGwHI5A6FRIEY6IVqtHhIepHqI7/kyEyQEagBC5mBEFlIYvdg==", 98 | "dev": true, 99 | "requires": { 100 | "safer-buffer": "~2.1.0" 101 | } 102 | }, 103 | "assert-plus": { 104 | "version": "1.0.0", 105 | "resolved": "https://registry.npmjs.org/assert-plus/-/assert-plus-1.0.0.tgz", 106 | "integrity": "sha1-8S4PPF13sLHN2RRpQuTpbB5N1SU=", 107 | "dev": true 108 | }, 109 | "async": { 110 | "version": "1.5.0", 111 | "resolved": "http://registry.npmjs.org/async/-/async-1.5.0.tgz", 112 | "integrity": "sha1-J5ZkJyNXOFlWVjP8YnRES+4vjOM=", 113 | "dev": true 114 | }, 115 | "asynckit": { 116 | "version": "0.4.0", 117 | "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", 118 | "integrity": "sha1-x57Zf380y48robyXkLzDZkdLS3k=", 119 | "dev": true 120 | }, 121 | "aws-sign2": { 122 | "version": "0.7.0", 123 | "resolved": "https://registry.npmjs.org/aws-sign2/-/aws-sign2-0.7.0.tgz", 124 | "integrity": "sha1-tG6JCTSpWR8tL2+G1+ap8bP+dqg=", 125 | "dev": true 126 | }, 127 | "aws4": { 128 | "version": "1.8.0", 129 | "resolved": "https://registry.npmjs.org/aws4/-/aws4-1.8.0.tgz", 130 | "integrity": "sha512-ReZxvNHIOv88FlT7rxcXIIC0fPt4KZqZbOlivyWtXLt8ESx84zd3kMC6iK5jVeS2qt+g7ftS7ye4fi06X5rtRQ==", 131 | "dev": true 132 | }, 133 | "balanced-match": { 134 | "version": "1.0.0", 135 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 136 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", 137 | "dev": true 138 | }, 139 | "bcrypt-pbkdf": { 140 | "version": "1.0.2", 141 | "resolved": "https://registry.npmjs.org/bcrypt-pbkdf/-/bcrypt-pbkdf-1.0.2.tgz", 142 | "integrity": "sha1-pDAdOJtqQ/m2f/PKEaP2Y342Dp4=", 143 | "dev": true, 144 | "requires": { 145 | "tweetnacl": "^0.14.3" 146 | } 147 | }, 148 | "bignumber.js": { 149 | "version": "4.1.0", 150 | "resolved": "https://registry.npmjs.org/bignumber.js/-/bignumber.js-4.1.0.tgz", 151 | "integrity": "sha512-eJzYkFYy9L4JzXsbymsFn3p54D+llV27oTQ+ziJG7WFRheJcNZilgVXMG0LoZtlQSKBsJdWtLFqOD0u+U0jZKA==", 152 | "dev": true 153 | }, 154 | "brace-expansion": { 155 | "version": "1.1.11", 156 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 157 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 158 | "dev": true, 159 | "requires": { 160 | "balanced-match": "^1.0.0", 161 | "concat-map": "0.0.1" 162 | } 163 | }, 164 | "browser-stdout": { 165 | "version": "1.3.1", 166 | "resolved": "https://registry.npmjs.org/browser-stdout/-/browser-stdout-1.3.1.tgz", 167 | "integrity": "sha512-qhAVI1+Av2X7qelOfAIYwXONood6XlZE/fXaBSmW/T5SzLAmCgzi+eiWE7fUvbHaeNBQH13UftjpXxsfLkMpgw==", 168 | "dev": true 169 | }, 170 | "bson": { 171 | "version": "0.4.23", 172 | "resolved": "http://registry.npmjs.org/bson/-/bson-0.4.23.tgz", 173 | "integrity": "sha1-5louPHUH/63kEJvHV1p25Q+NqRU=", 174 | "dev": true 175 | }, 176 | "buffer-writer": { 177 | "version": "2.0.0", 178 | "resolved": "https://registry.npmjs.org/buffer-writer/-/buffer-writer-2.0.0.tgz", 179 | "integrity": "sha512-a7ZpuTZU1TRtnwyCNW3I5dc0wWNC3VR9S++Ewyk2HHZdrO3CQJqSpd+95Us590V6AL7JqUAH2IwZ/398PmNFgw==", 180 | "dev": true 181 | }, 182 | "caseless": { 183 | "version": "0.12.0", 184 | "resolved": "https://registry.npmjs.org/caseless/-/caseless-0.12.0.tgz", 185 | "integrity": "sha1-G2gcIf+EAzyCZUMJBolCDRhxUdw=", 186 | "dev": true 187 | }, 188 | "chalk": { 189 | "version": "1.1.3", 190 | "resolved": "http://registry.npmjs.org/chalk/-/chalk-1.1.3.tgz", 191 | "integrity": "sha1-qBFcVeSnAv5NFQq9OHKCKn4J/Jg=", 192 | "dev": true, 193 | "requires": { 194 | "ansi-styles": "^2.2.1", 195 | "escape-string-regexp": "^1.0.2", 196 | "has-ansi": "^2.0.0", 197 | "strip-ansi": "^3.0.0", 198 | "supports-color": "^2.0.0" 199 | } 200 | }, 201 | "chownr": { 202 | "version": "1.1.1", 203 | "resolved": "https://registry.npmjs.org/chownr/-/chownr-1.1.1.tgz", 204 | "integrity": "sha512-j38EvO5+LHX84jlo6h4UzmOwi0UgW61WRyPtJz4qaadK5eY3BTS5TY/S1Stc3Uk2lIM6TPevAlULiEJwie860g==", 205 | "dev": true 206 | }, 207 | "code-point-at": { 208 | "version": "1.1.0", 209 | "resolved": "https://registry.npmjs.org/code-point-at/-/code-point-at-1.1.0.tgz", 210 | "integrity": "sha1-DQcLTQQ6W+ozovGkDi7bPZpMz3c=", 211 | "dev": true 212 | }, 213 | "combined-stream": { 214 | "version": "1.0.7", 215 | "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.7.tgz", 216 | "integrity": "sha512-brWl9y6vOB1xYPZcpZde3N9zDByXTosAeMDo4p1wzo6UMOX4vumB+TP1RZ76sfE6Md68Q0NJSrE/gbezd4Ul+w==", 217 | "dev": true, 218 | "requires": { 219 | "delayed-stream": "~1.0.0" 220 | } 221 | }, 222 | "commander": { 223 | "version": "2.15.1", 224 | "resolved": "http://registry.npmjs.org/commander/-/commander-2.15.1.tgz", 225 | "integrity": "sha512-VlfT9F3V0v+jr4yxPc5gg9s62/fIVWsd2Bk2iD435um1NlGMYdVCq+MjcXnhYq2icNOizHr1kK+5TI6H0Hy0ag==", 226 | "dev": true 227 | }, 228 | "concat-map": { 229 | "version": "0.0.1", 230 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 231 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 232 | "dev": true 233 | }, 234 | "console-control-strings": { 235 | "version": "1.1.0", 236 | "resolved": "https://registry.npmjs.org/console-control-strings/-/console-control-strings-1.1.0.tgz", 237 | "integrity": "sha1-PXz0Rk22RG6mRL9LOVB/mFEAjo4=", 238 | "dev": true 239 | }, 240 | "core-util-is": { 241 | "version": "1.0.2", 242 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", 243 | "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=", 244 | "dev": true 245 | }, 246 | "cradle": { 247 | "version": "0.5.8", 248 | "resolved": "https://registry.npmjs.org/cradle/-/cradle-0.5.8.tgz", 249 | "integrity": "sha1-pG0kCHnYRE558Ql0IlUIhKRZf6Q=", 250 | "dev": true, 251 | "requires": { 252 | "vargs": ">=0.1.0" 253 | } 254 | }, 255 | "dashdash": { 256 | "version": "1.14.1", 257 | "resolved": "https://registry.npmjs.org/dashdash/-/dashdash-1.14.1.tgz", 258 | "integrity": "sha1-hTz6D3y+L+1d4gMmuN1YEDX24vA=", 259 | "dev": true, 260 | "requires": { 261 | "assert-plus": "^1.0.0" 262 | } 263 | }, 264 | "debug": { 265 | "version": "3.1.0", 266 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.1.0.tgz", 267 | "integrity": "sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g==", 268 | "dev": true, 269 | "requires": { 270 | "ms": "2.0.0" 271 | } 272 | }, 273 | "deep-extend": { 274 | "version": "0.6.0", 275 | "resolved": "https://registry.npmjs.org/deep-extend/-/deep-extend-0.6.0.tgz", 276 | "integrity": "sha512-LOHxIOaPYdHlJRtCQfDIVZtfw/ufM8+rVj649RIHzcm/vGwQRXFt6OPqIFWsm2XEMrNIEtWR64sY1LEKD2vAOA==", 277 | "dev": true 278 | }, 279 | "delayed-stream": { 280 | "version": "1.0.0", 281 | "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", 282 | "integrity": "sha1-3zrhmayt+31ECqrgsp4icrJOxhk=", 283 | "dev": true 284 | }, 285 | "delegates": { 286 | "version": "1.0.0", 287 | "resolved": "https://registry.npmjs.org/delegates/-/delegates-1.0.0.tgz", 288 | "integrity": "sha1-hMbhWbgZBP3KWaDvRM2HDTElD5o=", 289 | "dev": true 290 | }, 291 | "detect-libc": { 292 | "version": "1.0.3", 293 | "resolved": "https://registry.npmjs.org/detect-libc/-/detect-libc-1.0.3.tgz", 294 | "integrity": "sha1-+hN8S9aY7fVc1c0CrFWfkaTEups=", 295 | "dev": true 296 | }, 297 | "diff": { 298 | "version": "3.5.0", 299 | "resolved": "https://registry.npmjs.org/diff/-/diff-3.5.0.tgz", 300 | "integrity": "sha512-A46qtFgd+g7pDZinpnwiRJtxbC1hpgf0uzP3iG89scHk0AUC7A1TGxf5OiiOUv/JMZR8GOt8hL900hV0bOy5xA==", 301 | "dev": true 302 | }, 303 | "ecc-jsbn": { 304 | "version": "0.1.2", 305 | "resolved": "https://registry.npmjs.org/ecc-jsbn/-/ecc-jsbn-0.1.2.tgz", 306 | "integrity": "sha1-OoOpBOVDUyh4dMVkt1SThoSamMk=", 307 | "dev": true, 308 | "requires": { 309 | "jsbn": "~0.1.0", 310 | "safer-buffer": "^2.1.0" 311 | } 312 | }, 313 | "elasticsearch": { 314 | "version": "15.2.0", 315 | "resolved": "https://registry.npmjs.org/elasticsearch/-/elasticsearch-15.2.0.tgz", 316 | "integrity": "sha512-jOFcBoEh3Sn3gjUTozInODZTLriJtfppAUC7jnQCUE+OUj8o7GoAyC+L4h/L3ZxmXNFbQCunqVR+nmSofHdo9A==", 317 | "dev": true, 318 | "requires": { 319 | "agentkeepalive": "^3.4.1", 320 | "chalk": "^1.0.0", 321 | "lodash": "^4.17.10" 322 | } 323 | }, 324 | "es6-promise": { 325 | "version": "3.0.2", 326 | "resolved": "http://registry.npmjs.org/es6-promise/-/es6-promise-3.0.2.tgz", 327 | "integrity": "sha1-AQ1YWEI6XxGJeWZfRkhqlcbuK7Y=", 328 | "dev": true 329 | }, 330 | "escape-string-regexp": { 331 | "version": "1.0.5", 332 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 333 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", 334 | "dev": true 335 | }, 336 | "extend": { 337 | "version": "3.0.2", 338 | "resolved": "https://registry.npmjs.org/extend/-/extend-3.0.2.tgz", 339 | "integrity": "sha512-fjquC59cD7CyW6urNXK0FBufkZcoiGG80wTuPujX590cB5Ttln20E2UB4S/WARVqhXffZl2LNgS+gQdPIIim/g==", 340 | "dev": true 341 | }, 342 | "extsprintf": { 343 | "version": "1.3.0", 344 | "resolved": "https://registry.npmjs.org/extsprintf/-/extsprintf-1.3.0.tgz", 345 | "integrity": "sha1-lpGEQOMEGnpBT4xS48V06zw+HgU=", 346 | "dev": true 347 | }, 348 | "fast-deep-equal": { 349 | "version": "2.0.1", 350 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-2.0.1.tgz", 351 | "integrity": "sha1-ewUhjd+WZ79/Nwv3/bLLFf3Qqkk=", 352 | "dev": true 353 | }, 354 | "fast-json-stable-stringify": { 355 | "version": "2.0.0", 356 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.0.0.tgz", 357 | "integrity": "sha1-1RQsDK7msRifh9OnYREGT4bIu/I=", 358 | "dev": true 359 | }, 360 | "forever-agent": { 361 | "version": "0.6.1", 362 | "resolved": "https://registry.npmjs.org/forever-agent/-/forever-agent-0.6.1.tgz", 363 | "integrity": "sha1-+8cfDEGt6zf5bFd60e1C2P2sypE=", 364 | "dev": true 365 | }, 366 | "form-data": { 367 | "version": "2.3.3", 368 | "resolved": "https://registry.npmjs.org/form-data/-/form-data-2.3.3.tgz", 369 | "integrity": "sha512-1lLKB2Mu3aGP1Q/2eCOx0fNbRMe7XdwktwOruhfqqd0rIJWwN4Dh+E3hrPSlDCXnSR7UtZ1N38rVXm+6+MEhJQ==", 370 | "dev": true, 371 | "requires": { 372 | "asynckit": "^0.4.0", 373 | "combined-stream": "^1.0.6", 374 | "mime-types": "^2.1.12" 375 | } 376 | }, 377 | "fs-minipass": { 378 | "version": "1.2.5", 379 | "resolved": "https://registry.npmjs.org/fs-minipass/-/fs-minipass-1.2.5.tgz", 380 | "integrity": "sha512-JhBl0skXjUPCFH7x6x61gQxrKyXsxB5gcgePLZCwfyCGGsTISMoIeObbrvVeP6Xmyaudw4TT43qV2Gz+iyd2oQ==", 381 | "dev": true, 382 | "requires": { 383 | "minipass": "^2.2.1" 384 | } 385 | }, 386 | "fs.realpath": { 387 | "version": "1.0.0", 388 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 389 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 390 | "dev": true 391 | }, 392 | "gauge": { 393 | "version": "2.7.4", 394 | "resolved": "https://registry.npmjs.org/gauge/-/gauge-2.7.4.tgz", 395 | "integrity": "sha1-LANAXHU4w51+s3sxcCLjJfsBi/c=", 396 | "dev": true, 397 | "requires": { 398 | "aproba": "^1.0.3", 399 | "console-control-strings": "^1.0.0", 400 | "has-unicode": "^2.0.0", 401 | "object-assign": "^4.1.0", 402 | "signal-exit": "^3.0.0", 403 | "string-width": "^1.0.1", 404 | "strip-ansi": "^3.0.1", 405 | "wide-align": "^1.1.0" 406 | } 407 | }, 408 | "getpass": { 409 | "version": "0.1.7", 410 | "resolved": "https://registry.npmjs.org/getpass/-/getpass-0.1.7.tgz", 411 | "integrity": "sha1-Xv+OPmhNVprkyysSgmBOi6YhSfo=", 412 | "dev": true, 413 | "requires": { 414 | "assert-plus": "^1.0.0" 415 | } 416 | }, 417 | "glob": { 418 | "version": "7.1.2", 419 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.2.tgz", 420 | "integrity": "sha512-MJTUg1kjuLeQCJ+ccE4Vpa6kKVXkPYJ2mOCQyUuKLcLQsdrMCpBPUi8qVE6+YuaJkozeA9NusTAw3hLr8Xe5EQ==", 421 | "dev": true, 422 | "requires": { 423 | "fs.realpath": "^1.0.0", 424 | "inflight": "^1.0.4", 425 | "inherits": "2", 426 | "minimatch": "^3.0.4", 427 | "once": "^1.3.0", 428 | "path-is-absolute": "^1.0.0" 429 | } 430 | }, 431 | "growl": { 432 | "version": "1.10.5", 433 | "resolved": "https://registry.npmjs.org/growl/-/growl-1.10.5.tgz", 434 | "integrity": "sha512-qBr4OuELkhPenW6goKVXiv47US3clb3/IbuWF9KNKEijAy9oeHxU9IgzjvJhHkUzhaj7rOUD7+YGWqUjLp5oSA==", 435 | "dev": true 436 | }, 437 | "har-schema": { 438 | "version": "2.0.0", 439 | "resolved": "https://registry.npmjs.org/har-schema/-/har-schema-2.0.0.tgz", 440 | "integrity": "sha1-qUwiJOvKwEeCoNkDVSHyRzW37JI=", 441 | "dev": true 442 | }, 443 | "har-validator": { 444 | "version": "5.1.3", 445 | "resolved": "https://registry.npmjs.org/har-validator/-/har-validator-5.1.3.tgz", 446 | "integrity": "sha512-sNvOCzEQNr/qrvJgc3UG/kD4QtlHycrzwS+6mfTrrSq97BvaYcPZZI1ZSqGSPR73Cxn4LKTD4PttRwfU7jWq5g==", 447 | "dev": true, 448 | "requires": { 449 | "ajv": "^6.5.5", 450 | "har-schema": "^2.0.0" 451 | } 452 | }, 453 | "has-ansi": { 454 | "version": "2.0.0", 455 | "resolved": "https://registry.npmjs.org/has-ansi/-/has-ansi-2.0.0.tgz", 456 | "integrity": "sha1-NPUEnOHs3ysGSa8+8k5F7TVBbZE=", 457 | "dev": true, 458 | "requires": { 459 | "ansi-regex": "^2.0.0" 460 | } 461 | }, 462 | "has-flag": { 463 | "version": "3.0.0", 464 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 465 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", 466 | "dev": true 467 | }, 468 | "has-unicode": { 469 | "version": "2.0.1", 470 | "resolved": "https://registry.npmjs.org/has-unicode/-/has-unicode-2.0.1.tgz", 471 | "integrity": "sha1-4Ob+aijPUROIVeCG0Wkedx3iqLk=", 472 | "dev": true 473 | }, 474 | "he": { 475 | "version": "1.1.1", 476 | "resolved": "https://registry.npmjs.org/he/-/he-1.1.1.tgz", 477 | "integrity": "sha1-k0EP0hsAlzUVH4howvJx80J+I/0=", 478 | "dev": true 479 | }, 480 | "http-signature": { 481 | "version": "1.2.0", 482 | "resolved": "https://registry.npmjs.org/http-signature/-/http-signature-1.2.0.tgz", 483 | "integrity": "sha1-muzZJRFHcvPZW2WmCruPfBj7rOE=", 484 | "dev": true, 485 | "requires": { 486 | "assert-plus": "^1.0.0", 487 | "jsprim": "^1.2.2", 488 | "sshpk": "^1.7.0" 489 | } 490 | }, 491 | "humanize-ms": { 492 | "version": "1.2.1", 493 | "resolved": "https://registry.npmjs.org/humanize-ms/-/humanize-ms-1.2.1.tgz", 494 | "integrity": "sha1-xG4xWaKT9riW2ikxbYtv6Lt5u+0=", 495 | "dev": true, 496 | "requires": { 497 | "ms": "^2.0.0" 498 | } 499 | }, 500 | "iconv-lite": { 501 | "version": "0.4.24", 502 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 503 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 504 | "dev": true, 505 | "requires": { 506 | "safer-buffer": ">= 2.1.2 < 3" 507 | } 508 | }, 509 | "ignore-walk": { 510 | "version": "3.0.1", 511 | "resolved": "https://registry.npmjs.org/ignore-walk/-/ignore-walk-3.0.1.tgz", 512 | "integrity": "sha512-DTVlMx3IYPe0/JJcYP7Gxg7ttZZu3IInhuEhbchuqneY9wWe5Ojy2mXLBaQFUQmo0AW2r3qG7m1mg86js+gnlQ==", 513 | "dev": true, 514 | "requires": { 515 | "minimatch": "^3.0.4" 516 | }, 517 | "dependencies": { 518 | "minimatch": { 519 | "version": "3.0.4", 520 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 521 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 522 | "dev": true, 523 | "requires": { 524 | "brace-expansion": "^1.1.7" 525 | } 526 | } 527 | } 528 | }, 529 | "inflight": { 530 | "version": "1.0.6", 531 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 532 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 533 | "dev": true, 534 | "requires": { 535 | "once": "^1.3.0", 536 | "wrappy": "1" 537 | } 538 | }, 539 | "inherits": { 540 | "version": "2.0.3", 541 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", 542 | "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=", 543 | "dev": true 544 | }, 545 | "ini": { 546 | "version": "1.3.5", 547 | "resolved": "https://registry.npmjs.org/ini/-/ini-1.3.5.tgz", 548 | "integrity": "sha512-RZY5huIKCMRWDUqZlEi72f/lmXKMvuszcMBduliQ3nnWbx9X/ZBQO7DijMEYS9EhHBb2qacRUMtC7svLwe0lcw==", 549 | "dev": true 550 | }, 551 | "is-fullwidth-code-point": { 552 | "version": "1.0.0", 553 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-1.0.0.tgz", 554 | "integrity": "sha1-754xOG8DGn8NZDr4L95QxFfvAMs=", 555 | "dev": true, 556 | "requires": { 557 | "number-is-nan": "^1.0.0" 558 | } 559 | }, 560 | "is-typedarray": { 561 | "version": "1.0.0", 562 | "resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz", 563 | "integrity": "sha1-5HnICFjfDBsR3dppQPlgEfzaSpo=", 564 | "dev": true 565 | }, 566 | "isarray": { 567 | "version": "0.0.1", 568 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-0.0.1.tgz", 569 | "integrity": "sha1-ihis/Kmo9Bd+Cav8YDiTmwXR7t8=", 570 | "dev": true 571 | }, 572 | "isstream": { 573 | "version": "0.1.2", 574 | "resolved": "https://registry.npmjs.org/isstream/-/isstream-0.1.2.tgz", 575 | "integrity": "sha1-R+Y/evVa+m+S4VAOaQ64uFKcCZo=", 576 | "dev": true 577 | }, 578 | "jsbn": { 579 | "version": "0.1.1", 580 | "resolved": "https://registry.npmjs.org/jsbn/-/jsbn-0.1.1.tgz", 581 | "integrity": "sha1-peZUwuWi3rXyAdls77yoDA7y9RM=", 582 | "dev": true 583 | }, 584 | "json-schema": { 585 | "version": "0.2.3", 586 | "resolved": "https://registry.npmjs.org/json-schema/-/json-schema-0.2.3.tgz", 587 | "integrity": "sha1-tIDIkuWaLwWVTOcnvT8qTogvnhM=", 588 | "dev": true 589 | }, 590 | "json-schema-traverse": { 591 | "version": "0.4.1", 592 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 593 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 594 | "dev": true 595 | }, 596 | "json-stringify-safe": { 597 | "version": "5.0.1", 598 | "resolved": "https://registry.npmjs.org/json-stringify-safe/-/json-stringify-safe-5.0.1.tgz", 599 | "integrity": "sha1-Epai1Y/UXxmg9s4B1lcB4sc1tus=", 600 | "dev": true 601 | }, 602 | "jsprim": { 603 | "version": "1.4.1", 604 | "resolved": "https://registry.npmjs.org/jsprim/-/jsprim-1.4.1.tgz", 605 | "integrity": "sha1-MT5mvB5cwG5Di8G3SZwuXFastqI=", 606 | "dev": true, 607 | "requires": { 608 | "assert-plus": "1.0.0", 609 | "extsprintf": "1.3.0", 610 | "json-schema": "0.2.3", 611 | "verror": "1.10.0" 612 | } 613 | }, 614 | "lodash": { 615 | "version": "4.17.11", 616 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.11.tgz", 617 | "integrity": "sha512-cQKh8igo5QUhZ7lg38DYWAxMvjSAKG0A8wGSVimP07SIUEK2UO+arSRKbRZWtelMtN5V0Hkwh5ryOto/SshYIg==", 618 | "dev": true 619 | }, 620 | "mime-db": { 621 | "version": "1.37.0", 622 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.37.0.tgz", 623 | "integrity": "sha512-R3C4db6bgQhlIhPU48fUtdVmKnflq+hRdad7IyKhtFj06VPNVdk2RhiYL3UjQIlso8L+YxAtFkobT0VK+S/ybg==", 624 | "dev": true 625 | }, 626 | "mime-types": { 627 | "version": "2.1.21", 628 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.21.tgz", 629 | "integrity": "sha512-3iL6DbwpyLzjR3xHSFNFeb9Nz/M8WDkX33t1GFQnFOllWk8pOrh/LSrB5OXlnlW5P9LH73X6loW/eogc+F5lJg==", 630 | "dev": true, 631 | "requires": { 632 | "mime-db": "~1.37.0" 633 | } 634 | }, 635 | "minimatch": { 636 | "version": "3.0.4", 637 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 638 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 639 | "dev": true, 640 | "requires": { 641 | "brace-expansion": "^1.1.7" 642 | } 643 | }, 644 | "minimist": { 645 | "version": "0.0.8", 646 | "resolved": "http://registry.npmjs.org/minimist/-/minimist-0.0.8.tgz", 647 | "integrity": "sha1-hX/Kv8M5fSYluCKCYuhqp6ARsF0=", 648 | "dev": true 649 | }, 650 | "minipass": { 651 | "version": "2.3.5", 652 | "resolved": "https://registry.npmjs.org/minipass/-/minipass-2.3.5.tgz", 653 | "integrity": "sha512-Gi1W4k059gyRbyVUZQ4mEqLm0YIUiGYfvxhF6SIlk3ui1WVxMTGfGdQ2SInh3PDrRTVvPKgULkpJtT4RH10+VA==", 654 | "dev": true, 655 | "requires": { 656 | "safe-buffer": "^5.1.2", 657 | "yallist": "^3.0.0" 658 | } 659 | }, 660 | "minizlib": { 661 | "version": "1.1.1", 662 | "resolved": "https://registry.npmjs.org/minizlib/-/minizlib-1.1.1.tgz", 663 | "integrity": "sha512-TrfjCjk4jLhcJyGMYymBH6oTXcWjYbUAXTHDbtnWHjZC25h0cdajHuPE1zxb4DVmu8crfh+HwH/WMuyLG0nHBg==", 664 | "dev": true, 665 | "requires": { 666 | "minipass": "^2.2.1" 667 | } 668 | }, 669 | "mkdirp": { 670 | "version": "0.5.1", 671 | "resolved": "http://registry.npmjs.org/mkdirp/-/mkdirp-0.5.1.tgz", 672 | "integrity": "sha1-MAV0OOrGz3+MR2fzhkjWaX11yQM=", 673 | "dev": true, 674 | "requires": { 675 | "minimist": "0.0.8" 676 | } 677 | }, 678 | "mocha": { 679 | "version": "5.2.0", 680 | "resolved": "https://registry.npmjs.org/mocha/-/mocha-5.2.0.tgz", 681 | "integrity": "sha512-2IUgKDhc3J7Uug+FxMXuqIyYzH7gJjXECKe/w43IGgQHTSj3InJi+yAA7T24L9bQMRKiUEHxEX37G5JpVUGLcQ==", 682 | "dev": true, 683 | "requires": { 684 | "browser-stdout": "1.3.1", 685 | "commander": "2.15.1", 686 | "debug": "3.1.0", 687 | "diff": "3.5.0", 688 | "escape-string-regexp": "1.0.5", 689 | "glob": "7.1.2", 690 | "growl": "1.10.5", 691 | "he": "1.1.1", 692 | "minimatch": "3.0.4", 693 | "mkdirp": "0.5.1", 694 | "supports-color": "5.4.0" 695 | }, 696 | "dependencies": { 697 | "supports-color": { 698 | "version": "5.4.0", 699 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.4.0.tgz", 700 | "integrity": "sha512-zjaXglF5nnWpsq470jSv6P9DwPvgLkuapYmfDm3JWOm0vkNTVF2tI4UrN2r6jH1qM/uc/WtxYY1hYoA2dOKj5w==", 701 | "dev": true, 702 | "requires": { 703 | "has-flag": "^3.0.0" 704 | } 705 | } 706 | } 707 | }, 708 | "mongodb": { 709 | "version": "2.1.10", 710 | "resolved": "http://registry.npmjs.org/mongodb/-/mongodb-2.1.10.tgz", 711 | "integrity": "sha1-0kp6tYUWy77ufCVtT7AKd0+OTU8=", 712 | "dev": true, 713 | "requires": { 714 | "es6-promise": "3.0.2", 715 | "mongodb-core": "1.3.9", 716 | "readable-stream": "1.0.31" 717 | } 718 | }, 719 | "mongodb-core": { 720 | "version": "1.3.9", 721 | "resolved": "http://registry.npmjs.org/mongodb-core/-/mongodb-core-1.3.9.tgz", 722 | "integrity": "sha1-OdsvUhH+j8inphiSaweQgRR9Tm4=", 723 | "dev": true, 724 | "requires": { 725 | "bson": "~0.4.21", 726 | "require_optional": "~1.0.0" 727 | } 728 | }, 729 | "ms": { 730 | "version": "2.0.0", 731 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 732 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", 733 | "dev": true 734 | }, 735 | "mysql": { 736 | "version": "2.16.0", 737 | "resolved": "https://registry.npmjs.org/mysql/-/mysql-2.16.0.tgz", 738 | "integrity": "sha512-dPbN2LHonQp7D5ja5DJXNbCLe/HRdu+f3v61aguzNRQIrmZLOeRoymBYyeThrR6ug+FqzDL95Gc9maqZUJS+Gw==", 739 | "dev": true, 740 | "requires": { 741 | "bignumber.js": "4.1.0", 742 | "readable-stream": "2.3.6", 743 | "safe-buffer": "5.1.2", 744 | "sqlstring": "2.3.1" 745 | }, 746 | "dependencies": { 747 | "isarray": { 748 | "version": "1.0.0", 749 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 750 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=", 751 | "dev": true 752 | }, 753 | "readable-stream": { 754 | "version": "2.3.6", 755 | "resolved": "http://registry.npmjs.org/readable-stream/-/readable-stream-2.3.6.tgz", 756 | "integrity": "sha512-tQtKA9WIAhBF3+VLAseyMqZeBjW0AHJoxOtYqSUZNJxauErmLbVm2FW1y+J/YA9dUrAC39ITejlZWhVIwawkKw==", 757 | "dev": true, 758 | "requires": { 759 | "core-util-is": "~1.0.0", 760 | "inherits": "~2.0.3", 761 | "isarray": "~1.0.0", 762 | "process-nextick-args": "~2.0.0", 763 | "safe-buffer": "~5.1.1", 764 | "string_decoder": "~1.1.1", 765 | "util-deprecate": "~1.0.1" 766 | } 767 | }, 768 | "string_decoder": { 769 | "version": "1.1.1", 770 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", 771 | "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", 772 | "dev": true, 773 | "requires": { 774 | "safe-buffer": "~5.1.0" 775 | } 776 | } 777 | } 778 | }, 779 | "needle": { 780 | "version": "2.2.4", 781 | "resolved": "https://registry.npmjs.org/needle/-/needle-2.2.4.tgz", 782 | "integrity": "sha512-HyoqEb4wr/rsoaIDfTH2aVL9nWtQqba2/HvMv+++m8u0dz808MaagKILxtfeSN7QU7nvbQ79zk3vYOJp9zsNEA==", 783 | "dev": true, 784 | "requires": { 785 | "debug": "^2.1.2", 786 | "iconv-lite": "^0.4.4", 787 | "sax": "^1.2.4" 788 | }, 789 | "dependencies": { 790 | "debug": { 791 | "version": "2.6.9", 792 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 793 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 794 | "dev": true, 795 | "requires": { 796 | "ms": "2.0.0" 797 | } 798 | }, 799 | "ms": { 800 | "version": "2.0.0", 801 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 802 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", 803 | "dev": true 804 | } 805 | } 806 | }, 807 | "node-pre-gyp": { 808 | "version": "0.10.3", 809 | "resolved": "https://registry.npmjs.org/node-pre-gyp/-/node-pre-gyp-0.10.3.tgz", 810 | "integrity": "sha512-d1xFs+C/IPS8Id0qPTZ4bUT8wWryfR/OzzAFxweG+uLN85oPzyo2Iw6bVlLQ/JOdgNonXLCoRyqDzDWq4iw72A==", 811 | "dev": true, 812 | "requires": { 813 | "detect-libc": "^1.0.2", 814 | "mkdirp": "^0.5.1", 815 | "needle": "^2.2.1", 816 | "nopt": "^4.0.1", 817 | "npm-packlist": "^1.1.6", 818 | "npmlog": "^4.0.2", 819 | "rc": "^1.2.7", 820 | "rimraf": "^2.6.1", 821 | "semver": "^5.3.0", 822 | "tar": "^4" 823 | }, 824 | "dependencies": { 825 | "mkdirp": { 826 | "version": "0.5.1", 827 | "resolved": "http://registry.npmjs.org/mkdirp/-/mkdirp-0.5.1.tgz", 828 | "integrity": "sha1-MAV0OOrGz3+MR2fzhkjWaX11yQM=", 829 | "dev": true, 830 | "requires": { 831 | "minimist": "0.0.8" 832 | } 833 | } 834 | } 835 | }, 836 | "nopt": { 837 | "version": "4.0.1", 838 | "resolved": "https://registry.npmjs.org/nopt/-/nopt-4.0.1.tgz", 839 | "integrity": "sha1-0NRoWv1UFRk8jHUFYC0NF81kR00=", 840 | "dev": true, 841 | "requires": { 842 | "abbrev": "1", 843 | "osenv": "^0.1.4" 844 | } 845 | }, 846 | "npm-bundled": { 847 | "version": "1.0.5", 848 | "resolved": "https://registry.npmjs.org/npm-bundled/-/npm-bundled-1.0.5.tgz", 849 | "integrity": "sha512-m/e6jgWu8/v5niCUKQi9qQl8QdeEduFA96xHDDzFGqly0OOjI7c+60KM/2sppfnUU9JJagf+zs+yGhqSOFj71g==", 850 | "dev": true 851 | }, 852 | "npm-packlist": { 853 | "version": "1.1.12", 854 | "resolved": "https://registry.npmjs.org/npm-packlist/-/npm-packlist-1.1.12.tgz", 855 | "integrity": "sha512-WJKFOVMeAlsU/pjXuqVdzU0WfgtIBCupkEVwn+1Y0ERAbUfWw8R4GjgVbaKnUjRoD2FoQbHOCbOyT5Mbs9Lw4g==", 856 | "dev": true, 857 | "requires": { 858 | "ignore-walk": "^3.0.1", 859 | "npm-bundled": "^1.0.1" 860 | } 861 | }, 862 | "npmlog": { 863 | "version": "4.1.2", 864 | "resolved": "https://registry.npmjs.org/npmlog/-/npmlog-4.1.2.tgz", 865 | "integrity": "sha512-2uUqazuKlTaSI/dC8AzicUck7+IrEaOnN/e0jd3Xtt1KcGpwx30v50mL7oPyr/h9bL3E4aZccVwpwP+5W9Vjkg==", 866 | "dev": true, 867 | "requires": { 868 | "are-we-there-yet": "~1.1.2", 869 | "console-control-strings": "~1.1.0", 870 | "gauge": "~2.7.3", 871 | "set-blocking": "~2.0.0" 872 | } 873 | }, 874 | "number-is-nan": { 875 | "version": "1.0.1", 876 | "resolved": "https://registry.npmjs.org/number-is-nan/-/number-is-nan-1.0.1.tgz", 877 | "integrity": "sha1-CXtgK1NCKlIsGvuHkDGDNpQaAR0=", 878 | "dev": true 879 | }, 880 | "oauth-sign": { 881 | "version": "0.9.0", 882 | "resolved": "https://registry.npmjs.org/oauth-sign/-/oauth-sign-0.9.0.tgz", 883 | "integrity": "sha512-fexhUFFPTGV8ybAtSIGbV6gOkSv8UtRbDBnAyLQw4QPKkgNlsH2ByPGtMUqdWkos6YCRmAqViwgZrJc/mRDzZQ==", 884 | "dev": true 885 | }, 886 | "object-assign": { 887 | "version": "4.1.1", 888 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 889 | "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=", 890 | "dev": true 891 | }, 892 | "once": { 893 | "version": "1.4.0", 894 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 895 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 896 | "dev": true, 897 | "requires": { 898 | "wrappy": "1" 899 | } 900 | }, 901 | "os-homedir": { 902 | "version": "1.0.2", 903 | "resolved": "http://registry.npmjs.org/os-homedir/-/os-homedir-1.0.2.tgz", 904 | "integrity": "sha1-/7xJiDNuDoM94MFox+8VISGqf7M=", 905 | "dev": true 906 | }, 907 | "os-tmpdir": { 908 | "version": "1.0.2", 909 | "resolved": "http://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz", 910 | "integrity": "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ=", 911 | "dev": true 912 | }, 913 | "osenv": { 914 | "version": "0.1.5", 915 | "resolved": "https://registry.npmjs.org/osenv/-/osenv-0.1.5.tgz", 916 | "integrity": "sha512-0CWcCECdMVc2Rw3U5w9ZjqX6ga6ubk1xDVKxtBQPK7wis/0F2r9T6k4ydGYhecl7YUBxBVxhL5oisPsNxAPe2g==", 917 | "dev": true, 918 | "requires": { 919 | "os-homedir": "^1.0.0", 920 | "os-tmpdir": "^1.0.0" 921 | } 922 | }, 923 | "packet-reader": { 924 | "version": "0.3.1", 925 | "resolved": "https://registry.npmjs.org/packet-reader/-/packet-reader-0.3.1.tgz", 926 | "integrity": "sha1-zWLmCvjX/qinBexP+ZCHHEaHHyc=", 927 | "dev": true 928 | }, 929 | "path-is-absolute": { 930 | "version": "1.0.1", 931 | "resolved": "http://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 932 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 933 | "dev": true 934 | }, 935 | "performance-now": { 936 | "version": "2.1.0", 937 | "resolved": "https://registry.npmjs.org/performance-now/-/performance-now-2.1.0.tgz", 938 | "integrity": "sha1-Ywn04OX6kT7BxpMHrjZLSzd8nns=", 939 | "dev": true 940 | }, 941 | "pg": { 942 | "version": "7.6.1", 943 | "resolved": "https://registry.npmjs.org/pg/-/pg-7.6.1.tgz", 944 | "integrity": "sha512-rAItIkYrRaNGinZN/Hs8F9R5mQjQSPlnzxPF+eCimSl92qnuNGR42gkpOQKP1bnvTwkSjRTBL+VNC5EcFhtCuQ==", 945 | "dev": true, 946 | "requires": { 947 | "buffer-writer": "2.0.0", 948 | "packet-reader": "0.3.1", 949 | "pg-connection-string": "0.1.3", 950 | "pg-pool": "~2.0.3", 951 | "pg-types": "~1.12.1", 952 | "pgpass": "1.x", 953 | "semver": "4.3.2" 954 | }, 955 | "dependencies": { 956 | "semver": { 957 | "version": "4.3.2", 958 | "resolved": "http://registry.npmjs.org/semver/-/semver-4.3.2.tgz", 959 | "integrity": "sha1-x6BxWKgL7dBSNVt3DYLWZA+AO+c=", 960 | "dev": true 961 | } 962 | } 963 | }, 964 | "pg-connection-string": { 965 | "version": "0.1.3", 966 | "resolved": "https://registry.npmjs.org/pg-connection-string/-/pg-connection-string-0.1.3.tgz", 967 | "integrity": "sha1-2hhHsglA5C7hSSvq9l1J2RskXfc=", 968 | "dev": true 969 | }, 970 | "pg-pool": { 971 | "version": "2.0.4", 972 | "resolved": "https://registry.npmjs.org/pg-pool/-/pg-pool-2.0.4.tgz", 973 | "integrity": "sha512-Mi2AsmlFkVMpI28NreaDkz5DkfxLOG16C/HNwi091LDlOiDiQACtAroLxSd1vIS2imBqxdjjO9cQZg2CwsOPbw==", 974 | "dev": true 975 | }, 976 | "pg-types": { 977 | "version": "1.12.1", 978 | "resolved": "https://registry.npmjs.org/pg-types/-/pg-types-1.12.1.tgz", 979 | "integrity": "sha1-1kCH45A7WP+q0nnnWVxSIIoUw9I=", 980 | "dev": true, 981 | "requires": { 982 | "postgres-array": "~1.0.0", 983 | "postgres-bytea": "~1.0.0", 984 | "postgres-date": "~1.0.0", 985 | "postgres-interval": "^1.1.0" 986 | } 987 | }, 988 | "pgpass": { 989 | "version": "1.0.2", 990 | "resolved": "https://registry.npmjs.org/pgpass/-/pgpass-1.0.2.tgz", 991 | "integrity": "sha1-Knu0G2BltnkH6R2hsHwYR8h3swY=", 992 | "dev": true, 993 | "requires": { 994 | "split": "^1.0.0" 995 | } 996 | }, 997 | "postgres-array": { 998 | "version": "1.0.3", 999 | "resolved": "https://registry.npmjs.org/postgres-array/-/postgres-array-1.0.3.tgz", 1000 | "integrity": "sha512-5wClXrAP0+78mcsNX3/ithQ5exKvCyK5lr5NEEEeGwwM6NJdQgzIJBVxLvRW+huFpX92F2QnZ5CcokH0VhK2qQ==", 1001 | "dev": true 1002 | }, 1003 | "postgres-bytea": { 1004 | "version": "1.0.0", 1005 | "resolved": "https://registry.npmjs.org/postgres-bytea/-/postgres-bytea-1.0.0.tgz", 1006 | "integrity": "sha1-AntTPAqokOJtFy1Hz5zOzFIazTU=", 1007 | "dev": true 1008 | }, 1009 | "postgres-date": { 1010 | "version": "1.0.3", 1011 | "resolved": "https://registry.npmjs.org/postgres-date/-/postgres-date-1.0.3.tgz", 1012 | "integrity": "sha1-4tiXAu/bJY/52c7g/pG9BpdSV6g=", 1013 | "dev": true 1014 | }, 1015 | "postgres-interval": { 1016 | "version": "1.1.2", 1017 | "resolved": "https://registry.npmjs.org/postgres-interval/-/postgres-interval-1.1.2.tgz", 1018 | "integrity": "sha512-fC3xNHeTskCxL1dC8KOtxXt7YeFmlbTYtn7ul8MkVERuTmf7pI4DrkAxcw3kh1fQ9uz4wQmd03a1mRiXUZChfQ==", 1019 | "dev": true, 1020 | "requires": { 1021 | "xtend": "^4.0.0" 1022 | } 1023 | }, 1024 | "process-nextick-args": { 1025 | "version": "2.0.0", 1026 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.0.tgz", 1027 | "integrity": "sha512-MtEC1TqN0EU5nephaJ4rAtThHtC86dNN9qCuEhtshvpVBkAW5ZO7BASN9REnF9eoXGcRub+pFuKEpOHE+HbEMw==", 1028 | "dev": true 1029 | }, 1030 | "psl": { 1031 | "version": "1.1.29", 1032 | "resolved": "https://registry.npmjs.org/psl/-/psl-1.1.29.tgz", 1033 | "integrity": "sha512-AeUmQ0oLN02flVHXWh9sSJF7mcdFq0ppid/JkErufc3hGIV/AMa8Fo9VgDo/cT2jFdOWoFvHp90qqBH54W+gjQ==", 1034 | "dev": true 1035 | }, 1036 | "punycode": { 1037 | "version": "2.1.1", 1038 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", 1039 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", 1040 | "dev": true 1041 | }, 1042 | "qs": { 1043 | "version": "6.5.2", 1044 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.5.2.tgz", 1045 | "integrity": "sha512-N5ZAX4/LxJmF+7wN74pUD6qAh9/wnvdQcjq9TZjevvXzSUo7bfmw91saqMjzGS2xq91/odN2dW/WOl7qQHNDGA==", 1046 | "dev": true 1047 | }, 1048 | "rc": { 1049 | "version": "1.2.8", 1050 | "resolved": "https://registry.npmjs.org/rc/-/rc-1.2.8.tgz", 1051 | "integrity": "sha512-y3bGgqKj3QBdxLbLkomlohkvsA8gdAiUQlSBJnBhfn+BPxg4bc62d8TcBW15wavDfgexCgccckhcZvywyQYPOw==", 1052 | "dev": true, 1053 | "requires": { 1054 | "deep-extend": "^0.6.0", 1055 | "ini": "~1.3.0", 1056 | "minimist": "^1.2.0", 1057 | "strip-json-comments": "~2.0.1" 1058 | }, 1059 | "dependencies": { 1060 | "minimist": { 1061 | "version": "1.2.0", 1062 | "resolved": "http://registry.npmjs.org/minimist/-/minimist-1.2.0.tgz", 1063 | "integrity": "sha1-o1AIsg9BOD7sH7kU9M1d95omQoQ=", 1064 | "dev": true 1065 | } 1066 | } 1067 | }, 1068 | "readable-stream": { 1069 | "version": "1.0.31", 1070 | "resolved": "http://registry.npmjs.org/readable-stream/-/readable-stream-1.0.31.tgz", 1071 | "integrity": "sha1-jyUC4LyeOw2huUUgqrtOJgPsr64=", 1072 | "dev": true, 1073 | "requires": { 1074 | "core-util-is": "~1.0.0", 1075 | "inherits": "~2.0.1", 1076 | "isarray": "0.0.1", 1077 | "string_decoder": "~0.10.x" 1078 | } 1079 | }, 1080 | "redis": { 1081 | "version": "0.12.1", 1082 | "resolved": "https://registry.npmjs.org/redis/-/redis-0.12.1.tgz", 1083 | "integrity": "sha1-ZN92rQ/IrOuuvSoGReikj6xJGF4=", 1084 | "dev": true 1085 | }, 1086 | "request": { 1087 | "version": "2.88.0", 1088 | "resolved": "https://registry.npmjs.org/request/-/request-2.88.0.tgz", 1089 | "integrity": "sha512-NAqBSrijGLZdM0WZNsInLJpkJokL72XYjUpnB0iwsRgxh7dB6COrHnTBNwN0E+lHDAJzu7kLAkDeY08z2/A0hg==", 1090 | "dev": true, 1091 | "requires": { 1092 | "aws-sign2": "~0.7.0", 1093 | "aws4": "^1.8.0", 1094 | "caseless": "~0.12.0", 1095 | "combined-stream": "~1.0.6", 1096 | "extend": "~3.0.2", 1097 | "forever-agent": "~0.6.1", 1098 | "form-data": "~2.3.2", 1099 | "har-validator": "~5.1.0", 1100 | "http-signature": "~1.2.0", 1101 | "is-typedarray": "~1.0.0", 1102 | "isstream": "~0.1.2", 1103 | "json-stringify-safe": "~5.0.1", 1104 | "mime-types": "~2.1.19", 1105 | "oauth-sign": "~0.9.0", 1106 | "performance-now": "^2.1.0", 1107 | "qs": "~6.5.2", 1108 | "safe-buffer": "^5.1.2", 1109 | "tough-cookie": "~2.4.3", 1110 | "tunnel-agent": "^0.6.0", 1111 | "uuid": "^3.3.2" 1112 | } 1113 | }, 1114 | "require_optional": { 1115 | "version": "1.0.1", 1116 | "resolved": "https://registry.npmjs.org/require_optional/-/require_optional-1.0.1.tgz", 1117 | "integrity": "sha512-qhM/y57enGWHAe3v/NcwML6a3/vfESLe/sGM2dII+gEO0BpKRUkWZow/tyloNqJyN6kXSl3RyyM8Ll5D/sJP8g==", 1118 | "dev": true, 1119 | "requires": { 1120 | "resolve-from": "^2.0.0", 1121 | "semver": "^5.1.0" 1122 | } 1123 | }, 1124 | "resolve-from": { 1125 | "version": "2.0.0", 1126 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-2.0.0.tgz", 1127 | "integrity": "sha1-lICrIOlP+h2egKgEx+oUdhGWa1c=", 1128 | "dev": true 1129 | }, 1130 | "rimraf": { 1131 | "version": "2.6.2", 1132 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.6.2.tgz", 1133 | "integrity": "sha512-lreewLK/BlghmxtfH36YYVg1i8IAce4TI7oao75I1g245+6BctqTVQiBP3YUJ9C6DQOXJmkYR9X9fCLtCOJc5w==", 1134 | "dev": true, 1135 | "requires": { 1136 | "glob": "^7.0.5" 1137 | }, 1138 | "dependencies": { 1139 | "glob": { 1140 | "version": "7.1.3", 1141 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.3.tgz", 1142 | "integrity": "sha512-vcfuiIxogLV4DlGBHIUOwI0IbrJ8HWPc4MU7HzviGeNho/UJDfi6B5p3sHeWIQ0KGIU0Jpxi5ZHxemQfLkkAwQ==", 1143 | "dev": true, 1144 | "requires": { 1145 | "fs.realpath": "^1.0.0", 1146 | "inflight": "^1.0.4", 1147 | "inherits": "2", 1148 | "minimatch": "^3.0.4", 1149 | "once": "^1.3.0", 1150 | "path-is-absolute": "^1.0.0" 1151 | } 1152 | }, 1153 | "minimatch": { 1154 | "version": "3.0.4", 1155 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 1156 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 1157 | "dev": true, 1158 | "requires": { 1159 | "brace-expansion": "^1.1.7" 1160 | } 1161 | } 1162 | } 1163 | }, 1164 | "safe-buffer": { 1165 | "version": "5.1.2", 1166 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 1167 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==", 1168 | "dev": true 1169 | }, 1170 | "safer-buffer": { 1171 | "version": "2.1.2", 1172 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 1173 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==", 1174 | "dev": true 1175 | }, 1176 | "sax": { 1177 | "version": "1.2.4", 1178 | "resolved": "https://registry.npmjs.org/sax/-/sax-1.2.4.tgz", 1179 | "integrity": "sha512-NqVDv9TpANUjFm0N8uM5GxL36UgKi9/atZw+x7YFnQ8ckwFGKrl4xX4yWtrey3UJm5nP1kUbnYgLopqWNSRhWw==", 1180 | "dev": true 1181 | }, 1182 | "semver": { 1183 | "version": "5.6.0", 1184 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.6.0.tgz", 1185 | "integrity": "sha512-RS9R6R35NYgQn++fkDWaOmqGoj4Ek9gGs+DPxNUZKuwE183xjJroKvyo1IzVFeXvUrvmALy6FWD5xrdJT25gMg==", 1186 | "dev": true 1187 | }, 1188 | "set-blocking": { 1189 | "version": "2.0.0", 1190 | "resolved": "https://registry.npmjs.org/set-blocking/-/set-blocking-2.0.0.tgz", 1191 | "integrity": "sha1-BF+XgtARrppoA93TgrJDkrPYkPc=", 1192 | "dev": true 1193 | }, 1194 | "should": { 1195 | "version": "4.0.4", 1196 | "resolved": "https://registry.npmjs.org/should/-/should-4.0.4.tgz", 1197 | "integrity": "sha1-jvqjBPHxSM89LpVYYpkPmrnqYo8=", 1198 | "dev": true 1199 | }, 1200 | "signal-exit": { 1201 | "version": "3.0.2", 1202 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.2.tgz", 1203 | "integrity": "sha1-tf3AjxKH6hF4Yo5BXiUTK3NkbG0=", 1204 | "dev": true 1205 | }, 1206 | "split": { 1207 | "version": "1.0.1", 1208 | "resolved": "https://registry.npmjs.org/split/-/split-1.0.1.tgz", 1209 | "integrity": "sha512-mTyOoPbrivtXnwnIxZRFYRrPNtEFKlpB2fvjSnCQUiAA6qAZzqwna5envK4uk6OIeP17CsdF3rSBGYVBsU0Tkg==", 1210 | "dev": true, 1211 | "requires": { 1212 | "through": "2" 1213 | } 1214 | }, 1215 | "sqlite3": { 1216 | "version": "4.0.4", 1217 | "resolved": "https://registry.npmjs.org/sqlite3/-/sqlite3-4.0.4.tgz", 1218 | "integrity": "sha512-CO8vZMyUXBPC+E3iXOCc7Tz2pAdq5BWfLcQmOokCOZW5S5sZ/paijiPOCdvzpdP83RroWHYa5xYlVqCxSqpnQg==", 1219 | "dev": true, 1220 | "requires": { 1221 | "nan": "~2.10.0", 1222 | "node-pre-gyp": "^0.10.3", 1223 | "request": "^2.87.0" 1224 | }, 1225 | "dependencies": { 1226 | "nan": { 1227 | "version": "2.10.0", 1228 | "resolved": "http://registry.npmjs.org/nan/-/nan-2.10.0.tgz", 1229 | "integrity": "sha512-bAdJv7fBLhWC+/Bls0Oza+mvTaNQtP+1RyhhhvD95pgUJz6XM5IzgmxOkItJ9tkoCiplvAnXI1tNmmUD/eScyA==", 1230 | "dev": true 1231 | } 1232 | } 1233 | }, 1234 | "sqlstring": { 1235 | "version": "2.3.1", 1236 | "resolved": "https://registry.npmjs.org/sqlstring/-/sqlstring-2.3.1.tgz", 1237 | "integrity": "sha1-R1OT/56RR5rqYtyvDKPRSYOn+0A=", 1238 | "dev": true 1239 | }, 1240 | "sshpk": { 1241 | "version": "1.15.2", 1242 | "resolved": "https://registry.npmjs.org/sshpk/-/sshpk-1.15.2.tgz", 1243 | "integrity": "sha512-Ra/OXQtuh0/enyl4ETZAfTaeksa6BXks5ZcjpSUNrjBr0DvrJKX+1fsKDPpT9TBXgHAFsa4510aNVgI8g/+SzA==", 1244 | "dev": true, 1245 | "requires": { 1246 | "asn1": "~0.2.3", 1247 | "assert-plus": "^1.0.0", 1248 | "bcrypt-pbkdf": "^1.0.0", 1249 | "dashdash": "^1.12.0", 1250 | "ecc-jsbn": "~0.1.1", 1251 | "getpass": "^0.1.1", 1252 | "jsbn": "~0.1.0", 1253 | "safer-buffer": "^2.0.2", 1254 | "tweetnacl": "~0.14.0" 1255 | } 1256 | }, 1257 | "string-width": { 1258 | "version": "1.0.2", 1259 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-1.0.2.tgz", 1260 | "integrity": "sha1-EYvfW4zcUaKn5w0hHgfisLmxB9M=", 1261 | "dev": true, 1262 | "requires": { 1263 | "code-point-at": "^1.0.0", 1264 | "is-fullwidth-code-point": "^1.0.0", 1265 | "strip-ansi": "^3.0.0" 1266 | } 1267 | }, 1268 | "string_decoder": { 1269 | "version": "0.10.31", 1270 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-0.10.31.tgz", 1271 | "integrity": "sha1-YuIDvEF2bGwoyfyEMB2rHFMQ+pQ=", 1272 | "dev": true 1273 | }, 1274 | "strip-ansi": { 1275 | "version": "3.0.1", 1276 | "resolved": "http://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz", 1277 | "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=", 1278 | "dev": true, 1279 | "requires": { 1280 | "ansi-regex": "^2.0.0" 1281 | } 1282 | }, 1283 | "strip-json-comments": { 1284 | "version": "2.0.1", 1285 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz", 1286 | "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=", 1287 | "dev": true 1288 | }, 1289 | "supports-color": { 1290 | "version": "2.0.0", 1291 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-2.0.0.tgz", 1292 | "integrity": "sha1-U10EXOa2Nj+kARcIRimZXp3zJMc=", 1293 | "dev": true 1294 | }, 1295 | "tar": { 1296 | "version": "4.4.8", 1297 | "resolved": "https://registry.npmjs.org/tar/-/tar-4.4.8.tgz", 1298 | "integrity": "sha512-LzHF64s5chPQQS0IYBn9IN5h3i98c12bo4NCO7e0sGM2llXQ3p2FGC5sdENN4cTW48O915Sh+x+EXx7XW96xYQ==", 1299 | "dev": true, 1300 | "requires": { 1301 | "chownr": "^1.1.1", 1302 | "fs-minipass": "^1.2.5", 1303 | "minipass": "^2.3.4", 1304 | "minizlib": "^1.1.1", 1305 | "mkdirp": "^0.5.0", 1306 | "safe-buffer": "^5.1.2", 1307 | "yallist": "^3.0.2" 1308 | }, 1309 | "dependencies": { 1310 | "mkdirp": { 1311 | "version": "0.5.1", 1312 | "resolved": "http://registry.npmjs.org/mkdirp/-/mkdirp-0.5.1.tgz", 1313 | "integrity": "sha1-MAV0OOrGz3+MR2fzhkjWaX11yQM=", 1314 | "dev": true, 1315 | "requires": { 1316 | "minimist": "0.0.8" 1317 | } 1318 | } 1319 | } 1320 | }, 1321 | "through": { 1322 | "version": "2.3.8", 1323 | "resolved": "http://registry.npmjs.org/through/-/through-2.3.8.tgz", 1324 | "integrity": "sha1-DdTJ/6q8NXlgsbckEV1+Doai4fU=", 1325 | "dev": true 1326 | }, 1327 | "tough-cookie": { 1328 | "version": "2.4.3", 1329 | "resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-2.4.3.tgz", 1330 | "integrity": "sha512-Q5srk/4vDM54WJsJio3XNn6K2sCG+CQ8G5Wz6bZhRZoAe/+TxjWB/GlFAnYEbkYVlON9FMk/fE3h2RLpPXo4lQ==", 1331 | "dev": true, 1332 | "requires": { 1333 | "psl": "^1.1.24", 1334 | "punycode": "^1.4.1" 1335 | }, 1336 | "dependencies": { 1337 | "punycode": { 1338 | "version": "1.4.1", 1339 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-1.4.1.tgz", 1340 | "integrity": "sha1-wNWmOycYgArY4esPpSachN1BhF4=", 1341 | "dev": true 1342 | } 1343 | } 1344 | }, 1345 | "tunnel-agent": { 1346 | "version": "0.6.0", 1347 | "resolved": "https://registry.npmjs.org/tunnel-agent/-/tunnel-agent-0.6.0.tgz", 1348 | "integrity": "sha1-J6XeoGs2sEoKmWZ3SykIaPD8QP0=", 1349 | "dev": true, 1350 | "requires": { 1351 | "safe-buffer": "^5.0.1" 1352 | } 1353 | }, 1354 | "tweetnacl": { 1355 | "version": "0.14.5", 1356 | "resolved": "https://registry.npmjs.org/tweetnacl/-/tweetnacl-0.14.5.tgz", 1357 | "integrity": "sha1-WuaBd/GS1EViadEIr6k/+HQ/T2Q=", 1358 | "dev": true 1359 | }, 1360 | "uri-js": { 1361 | "version": "4.2.2", 1362 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.2.2.tgz", 1363 | "integrity": "sha512-KY9Frmirql91X2Qgjry0Wd4Y+YTdrdZheS8TFwvkbLWf/G5KNJDCh6pKL5OZctEW4+0Baa5idK2ZQuELRwPznQ==", 1364 | "dev": true, 1365 | "requires": { 1366 | "punycode": "^2.1.0" 1367 | } 1368 | }, 1369 | "util-deprecate": { 1370 | "version": "1.0.2", 1371 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 1372 | "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=", 1373 | "dev": true 1374 | }, 1375 | "uuid": { 1376 | "version": "3.3.2", 1377 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-3.3.2.tgz", 1378 | "integrity": "sha512-yXJmeNaw3DnnKAOKJE51sL/ZaYfWJRl1pK9dr19YFCu0ObS231AB1/LbqTKRAQ5kw8A90rA6fr4riOUpTZvQZA==", 1379 | "dev": true 1380 | }, 1381 | "vargs": { 1382 | "version": "0.1.0", 1383 | "resolved": "https://registry.npmjs.org/vargs/-/vargs-0.1.0.tgz", 1384 | "integrity": "sha1-a2GE2mUgzDIEzhtAfKwm2SYJ6/8=", 1385 | "dev": true 1386 | }, 1387 | "verror": { 1388 | "version": "1.10.0", 1389 | "resolved": "https://registry.npmjs.org/verror/-/verror-1.10.0.tgz", 1390 | "integrity": "sha1-OhBcoXBTr1XW4nDB+CiGguGNpAA=", 1391 | "dev": true, 1392 | "requires": { 1393 | "assert-plus": "^1.0.0", 1394 | "core-util-is": "1.0.2", 1395 | "extsprintf": "^1.2.0" 1396 | } 1397 | }, 1398 | "wide-align": { 1399 | "version": "1.1.3", 1400 | "resolved": "https://registry.npmjs.org/wide-align/-/wide-align-1.1.3.tgz", 1401 | "integrity": "sha512-QGkOQc8XL6Bt5PwnsExKBPuMKBxnGxWWW3fU55Xt4feHozMUhdUMaBCk290qpm/wG5u/RSKzwdAC4i51YigihA==", 1402 | "dev": true, 1403 | "requires": { 1404 | "string-width": "^1.0.2 || 2" 1405 | } 1406 | }, 1407 | "wrappy": { 1408 | "version": "1.0.2", 1409 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 1410 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 1411 | "dev": true 1412 | }, 1413 | "xtend": { 1414 | "version": "4.0.1", 1415 | "resolved": "https://registry.npmjs.org/xtend/-/xtend-4.0.1.tgz", 1416 | "integrity": "sha1-pcbVMr5lbiPbgg77lDofBJmNY68=", 1417 | "dev": true 1418 | }, 1419 | "yallist": { 1420 | "version": "3.0.2", 1421 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-3.0.2.tgz", 1422 | "integrity": "sha1-hFK0u36Dx8GI2AQcGoN8dz1ti7k=", 1423 | "dev": true 1424 | } 1425 | } 1426 | } 1427 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "database-cleaner", 3 | "description": "Database Cleaner for node.js", 4 | "keywords": [ 5 | "database", 6 | "cleaner", 7 | "mongodb", 8 | "redis", 9 | "couchdb", 10 | "tests", 11 | "package.json", 12 | "elasticsearch" 13 | ], 14 | "version": "1.3.0", 15 | "author": "Emerson Macedo ", 16 | "repository": { 17 | "type": "git", 18 | "url": "git://github.com/emerleite/node-database-cleaner.git" 19 | }, 20 | "dependencies": {}, 21 | "devDependencies": { 22 | "async": "1.5.0", 23 | "cradle": "0.5.8", 24 | "elasticsearch": "^15.2.0", 25 | "lodash": "^4.17.11", 26 | "mocha": "^5.2.0", 27 | "mongodb": "2.1.10", 28 | "mysql": "^2.16.0", 29 | "pg": "^7.6.1", 30 | "redis": "0.12.1", 31 | "should": "4.0.4", 32 | "sqlite3": "^4.0.4" 33 | }, 34 | "main": "index", 35 | "scripts": { 36 | "test": "node_modules/mocha/bin/mocha -R spec --timeout 5000 --globals config,currentObjectStored" 37 | }, 38 | "engines": { 39 | "node": ">=0.10.0" 40 | } 41 | } 42 | -------------------------------------------------------------------------------- /test/couchdb.test.js: -------------------------------------------------------------------------------- 1 | var should = require('should'), 2 | DatabaseCleaner = require('../lib/database-cleaner'), 3 | databaseCleaner = new DatabaseCleaner('couchdb'), 4 | cradle = require('cradle'), 5 | db = new(cradle.Connection)(process.env.COUCHDB_HOST || '127.0.0.1').database('database_cleaner');; 6 | 7 | describe('couchdb', function() { 8 | beforeEach(function(done) { 9 | db.create(); 10 | db.save({nodejs: 'is', realy: 'awesome'}, done); 11 | }); 12 | 13 | it('should have 0 docs after drop and create', function(done) { 14 | databaseCleaner.clean(db, function() { 15 | db.all(function(err, res) { 16 | res.total_rows.should.equal(0); 17 | done(); 18 | }); 19 | }); 20 | }); 21 | }); 22 | -------------------------------------------------------------------------------- /test/elasticsearch.test.js: -------------------------------------------------------------------------------- 1 | var should = require('should'), 2 | DatabaseCleaner = require('../lib/database-cleaner'), 3 | databaseCleaner = new DatabaseCleaner('elasticsearch'); 4 | var elasticsearch = require('elasticsearch'); 5 | 6 | var elasticsearchHost = process.env.ELASTICSEARCH_HOST || 'localhost'; 7 | var elasticsearchPort = process.env.ELASTICSEARCH_PORT || 9200; 8 | 9 | describe('elasticsearch', function() { 10 | var client = null; 11 | 12 | beforeEach(function(done) { 13 | client = new elasticsearch.Client({ 14 | host: { 15 | host: elasticsearchHost, 16 | port: elasticsearchPort 17 | } 18 | }); 19 | client.index({ 20 | index: 'myindex', 21 | type: 'mytype', 22 | id: '1', 23 | body: { 24 | title: 'Test 1' 25 | } 26 | }, done); 27 | }); 28 | 29 | it('should delete all indices', function(done) { 30 | 31 | databaseCleaner.clean(client, function () { 32 | client.search({index: '*'}, function (error, response) { 33 | response.hits.total.should.be.equal(0); 34 | done(); 35 | }); 36 | }); 37 | 38 | }); 39 | 40 | }); 41 | -------------------------------------------------------------------------------- /test/mongodb.test.js: -------------------------------------------------------------------------------- 1 | var should = require('should'), 2 | DatabaseCleaner = require('../lib/database-cleaner'), 3 | databaseCleaner = new DatabaseCleaner('mongodb'), 4 | connect = require('mongodb').connect; 5 | 6 | var dbHost = process.env.MONGO_HOST || 'localhost'; 7 | 8 | function setUp(callback) { 9 | connect('mongodb://' + dbHost + '/database_cleaner', function(err, db) { 10 | db.createCollection("database_cleaner_collection", null, function (err, collection) { 11 | db.createCollection("schema_migrations", null, function (err, collection) { 12 | collection.insert([{a:1}, {b:2}], function() { 13 | callback(db); 14 | }); 15 | }); 16 | }); 17 | }); 18 | } 19 | 20 | function setUpEmptyDb(callback) { 21 | connect('mongodb://' + dbHost + '/database_cleaner_empty', function(err, db) { 22 | callback(db); 23 | }); 24 | } 25 | 26 | function tearDown(db) { 27 | db.close(); 28 | } 29 | 30 | describe('mongodb', function() { 31 | it('should delete all collections except the skipped and system.indexes', function(done) { 32 | setUp(function(db) { 33 | databaseCleaner.clean(db, function () { 34 | db.collections( function (skip, collections) { 35 | collections.length.should.equal(2); 36 | tearDown(db); 37 | done(); 38 | }); 39 | }); 40 | }); 41 | }); 42 | 43 | it('should invoke callback even if database has no collections', function(done) { 44 | setUpEmptyDb(function(db) { 45 | databaseCleaner.clean(db, function () { 46 | done(); 47 | }); 48 | }); 49 | }); 50 | }); 51 | -------------------------------------------------------------------------------- /test/mysql.test.js: -------------------------------------------------------------------------------- 1 | var should = require('should'), 2 | DatabaseCleaner = require('../lib/database-cleaner'), 3 | _ = require('lodash'), 4 | async = require('async'), 5 | databaseCleaner; 6 | 7 | var mysql = require('mysql'), 8 | client = new mysql.createConnection({ 9 | host: process.env.MYSQL_HOST || 'localhost', 10 | user: 'root', 11 | database: 'database_cleaner' 12 | }), 13 | pool = new mysql.createPool({ 14 | host: process.env.MYSQL_HOST || 'localhost', 15 | user: 'root', 16 | database: 'database_cleaner' 17 | }); 18 | 19 | var queryClient = _.curry(function(query, values, next) { 20 | client.query(query, values, next); 21 | }); 22 | 23 | describe('mysql', function() { 24 | beforeEach(function(done) { 25 | client.query('CREATE DATABASE database_cleaner', function(err) { 26 | if (err && err.number != mysql.ERROR_DB_CREATE_EXISTS) { 27 | throw err; 28 | } 29 | }); 30 | 31 | async.series([ 32 | queryClient('CREATE TABLE test1 (id INTEGER NOT NULL AUTO_INCREMENT, title VARCHAR(255) NOT NULL, PRIMARY KEY(id));', []), 33 | queryClient('CREATE TABLE test2 (id INTEGER NOT NULL AUTO_INCREMENT, title VARCHAR(255) NOT NULL, PRIMARY KEY(id))', []), 34 | queryClient('INSERT INTO test1(title) VALUES(?)', ["foobar"]), 35 | queryClient('INSERT INTO test2(title) VALUES(?)', ["foobar"]), 36 | queryClient('CREATE TABLE schema_migrations (id INTEGER NOT NULL AUTO_INCREMENT, version VARCHAR(255) NOT NULL, PRIMARY KEY(id));', []), 37 | queryClient('INSERT INTO schema_migrations(version) VALUES(?)', ["20150716190240"]) 38 | ], done); 39 | }); 40 | 41 | afterEach(function(done) { 42 | async.parallel([ 43 | queryClient("DROP TABLE test1", []), 44 | queryClient("DROP TABLE test2", []), 45 | queryClient("DROP TABLE schema_migrations", []) 46 | ], done); 47 | }); 48 | 49 | describe('with default config', function() { 50 | before(function(done) { 51 | databaseCleaner = new DatabaseCleaner('mysql'); 52 | done(); 53 | }); 54 | 55 | it('should delete all not skippedTables records', function(done) { 56 | databaseCleaner.clean(client, function() { 57 | async.parallel([ 58 | queryClient("SELECT * FROM test1", []), 59 | queryClient("SELECT * FROM test2", []) 60 | ], function(err, results) { 61 | if (err) return done(err); 62 | 63 | results[0][0].length.should.equal(0); 64 | results[1][0].length.should.equal(0); 65 | 66 | done(); 67 | }); 68 | }); 69 | }); 70 | 71 | it('should retain schema_migrations', function(done) { 72 | databaseCleaner.clean(client, function() { 73 | client.query("SELECT * FROM schema_migrations", function(err, result) { 74 | result.length.should.equal(1); 75 | done(); 76 | }); 77 | }); 78 | }); 79 | 80 | it('should retain schema_migrations', function(done) { 81 | databaseCleaner.clean(client, function() { 82 | client.query("SELECT * FROM schema_migrations", function(err, result) { 83 | result.length.should.equal(1); 84 | done(); 85 | }); 86 | }); 87 | }); 88 | }); 89 | 90 | describe('with provided config', function() { 91 | before(function(done) { 92 | var config = { mysql: { skipTables: [] } }; 93 | 94 | databaseCleaner = new DatabaseCleaner('mysql', config); 95 | done(); 96 | }); 97 | 98 | it('should NOT retain schema_migrations since the config did not have any tables to skip', function(done) { 99 | databaseCleaner.clean(client, function() { 100 | client.query("SELECT * FROM schema_migrations", function(err, result) { 101 | result.length.should.equal(0); 102 | done(); 103 | }); 104 | }); 105 | }); 106 | 107 | }); 108 | 109 | describe('truncation strategy', function() { 110 | before(function(done) { 111 | var config = { mysql: { strategy: 'truncation', skipTables: [] } }; 112 | 113 | databaseCleaner = new DatabaseCleaner('mysql', config); 114 | done(); 115 | }); 116 | 117 | it('should truncate all not skippedTables records', function(done) { 118 | databaseCleaner.clean(client, function() { 119 | async.parallel([ 120 | queryClient("SELECT * FROM test1", []), 121 | queryClient("SELECT * FROM test2", []) 122 | ], function(err, results) { 123 | if (err) return done(err); 124 | 125 | results[0][0].length.should.equal(0); 126 | results[1][0].length.should.equal(0); 127 | 128 | done(); 129 | }); 130 | }); 131 | }); 132 | }); 133 | 134 | describe('with pooled connection', function() { 135 | before(function(done) { 136 | databaseCleaner = new DatabaseCleaner('mysql'); 137 | done(); 138 | }); 139 | 140 | it('should not error with a pooled connection', function(done) { 141 | databaseCleaner.clean(pool, done); 142 | }); 143 | }); 144 | }); 145 | 146 | describe('mysql empty', function() { 147 | beforeEach(function(done) { 148 | client.query('CREATE DATABASE database_cleaner', function(err) { 149 | if (err && err.number != mysql.ERROR_DB_CREATE_EXISTS) { 150 | throw err; 151 | } 152 | done(); 153 | }); 154 | }); 155 | 156 | it('should not stuck if database is empty', function(done) { 157 | databaseCleaner.clean(client, done); 158 | }); 159 | }); 160 | -------------------------------------------------------------------------------- /test/postgresql.test.js: -------------------------------------------------------------------------------- 1 | var should = require('should'), 2 | pg = require('pg'), 3 | _ = require('lodash'), 4 | async = require('async'); 5 | DatabaseCleaner = require('../lib/database-cleaner'), 6 | databaseCleaner = new DatabaseCleaner('postgresql'); 7 | 8 | var dbHost = process.env.POSTGRES_HOST || 'localhost'; 9 | var connectionString = 'postgres://postgres@' + dbHost + '/database_cleaner'; 10 | 11 | var queryClient = _.curry(function(client, query, values, next) { 12 | client.query(query, values, next); 13 | }); 14 | 15 | describe('pg', function() { 16 | beforeEach(function(done) { 17 | pg.connect(connectionString, function(err, client, release) { 18 | if (err) return done(err); 19 | 20 | client.query('CREATE DATABASE database_cleaner', function(err) { 21 | if (err && err.code != '42P04') { 22 | throw err; 23 | } 24 | }); 25 | 26 | async.series([ 27 | queryClient(client, 'CREATE SCHEMA other_schema', []), 28 | queryClient(client, 'CREATE TABLE other_schema.test1 (id SERIAL, title VARCHAR(255) NOT NULL, PRIMARY KEY(id));', []), 29 | queryClient(client, 'CREATE TABLE other_schema.test2 (id SERIAL, title VARCHAR(255) NOT NULL, PRIMARY KEY(id));', []), 30 | queryClient(client, 'CREATE TABLE test1 (id SERIAL, title VARCHAR(255) NOT NULL, PRIMARY KEY(id));', []), 31 | queryClient(client, 'CREATE TABLE test2 (id SERIAL, title VARCHAR(255) NOT NULL, PRIMARY KEY(id));', []), 32 | queryClient(client, 'CREATE TABLE "Test3" (id SERIAL, title VARCHAR(255) NOT NULL, PRIMARY KEY(id));', []), 33 | queryClient(client, 'CREATE TABLE schema_migrations (id SERIAL, version VARCHAR(255) NOT NULL, PRIMARY KEY(id));', []), 34 | queryClient(client, 'INSERT INTO other_schema.test1 (title) VALUES ($1);', ["foo"]), 35 | queryClient(client, 'INSERT INTO other_schema.test1 (title) VALUES ($1);', ["bar"]), 36 | queryClient(client, 'INSERT INTO other_schema.test2 (title) VALUES ($1);', ["foo"]), 37 | queryClient(client, 'INSERT INTO other_schema.test2 (title) VALUES ($1);', ["bar"]), 38 | queryClient(client, 'INSERT INTO test1 (title) VALUES ($1);', ["foo"]), 39 | queryClient(client, 'INSERT INTO test1 (title) VALUES ($1);', ["bar"]), 40 | queryClient(client, 'INSERT INTO test2 (title) VALUES ($1);', ["foo"]), 41 | queryClient(client, 'INSERT INTO test2 (title) VALUES ($1);', ["bar"]), 42 | queryClient(client, 'INSERT INTO "Test3" (title) VALUES ($1);', ["foobar"]), 43 | queryClient(client, 'INSERT INTO schema_migrations (version) VALUES ($1);', ["20150716190240"]), 44 | function(next) { release(); next(); }, 45 | ], done); 46 | }); 47 | }); 48 | 49 | afterEach(function(done) { 50 | pg.connect(connectionString, function(err, client, release) { 51 | if (err) return done(err); 52 | 53 | async.parallel([ 54 | queryClient(client, 'DROP SCHEMA other_schema CASCADE', []), 55 | queryClient(client, 'DROP TABLE test1 CASCADE', []), 56 | queryClient(client, 'DROP TABLE test2 CASCADE', []), 57 | queryClient(client, 'DROP TABLE "Test3" CASCADE', []), 58 | queryClient(client, 'DROP TABLE schema_migrations CASCADE', []), 59 | function(next) { release(); next(); }, 60 | ], done); 61 | }); 62 | }); 63 | 64 | it('should delete all non skippedTable records in default schema', function(done) { 65 | pg.connect(connectionString, function(err, client, release) { 66 | if (err) return done(err); 67 | 68 | databaseCleaner.clean(client, function() { 69 | async.parallel([ 70 | queryClient(client, "SELECT * FROM other_schema.test1", []), 71 | queryClient(client, "SELECT * FROM other_schema.test2", []), 72 | queryClient(client, "SELECT * FROM test1", []), 73 | queryClient(client, "SELECT * FROM test2", []) 74 | ], function(err, results) { 75 | results[0].rows.length.should.equal(2); 76 | results[1].rows.length.should.equal(2); 77 | results[2].rows.length.should.equal(0); 78 | results[3].rows.length.should.equal(0); 79 | 80 | release(); 81 | done(); 82 | }); 83 | }); 84 | }); 85 | }); 86 | 87 | describe('specifying a different schema', function() { 88 | before(function() { 89 | var config = { postgresql: { strategy: 'truncation', skipTables: [], schema: 'other_schema' } }; 90 | 91 | databaseCleaner = new DatabaseCleaner('postgresql', config); 92 | }); 93 | 94 | it('should delete all non skippedTable records in specified schema', function(done) { 95 | pg.connect(connectionString, function(err, client, release) { 96 | if (err) return done(err); 97 | 98 | databaseCleaner.clean(client, function() { 99 | async.parallel([ 100 | queryClient(client, "SELECT * FROM other_schema.test1", []), 101 | queryClient(client, "SELECT * FROM other_schema.test2", []), 102 | queryClient(client, "SELECT * FROM test1", []), 103 | queryClient(client, "SELECT * FROM test2", []) 104 | ], function(err, results) { 105 | results[0].rows.length.should.equal(0); 106 | results[1].rows.length.should.equal(0); 107 | results[2].rows.length.should.equal(2); 108 | results[3].rows.length.should.equal(2); 109 | 110 | release(); 111 | done(); 112 | }); 113 | }); 114 | }); 115 | }); 116 | }); 117 | 118 | it('should delete all records when table name is capitalized', function(done) { 119 | pg.connect(connectionString, function(err, client, release) { 120 | if (err) return done(err); 121 | 122 | databaseCleaner.clean(client, function() { 123 | async.parallel([ 124 | queryClient(client, "SELECT * FROM test1", []), 125 | queryClient(client, "SELECT * FROM test2", []), 126 | queryClient(client, "SELECT * FROM \"Test3\"", []) 127 | ], function(err, results) { 128 | results[0].rows.length.should.equal(0); 129 | results[1].rows.length.should.equal(0); 130 | results[2].rows.length.should.equal(0); 131 | 132 | release(); 133 | done(); 134 | }); 135 | }); 136 | }); 137 | }); 138 | 139 | it('should retain schema_migrations', function(done) { 140 | pg.connect(connectionString, function(err, client, release) { 141 | if (err) return done(err); 142 | 143 | databaseCleaner.clean(client, function() { 144 | client.query("SELECT * FROM schema_migrations", function(err, result) { 145 | result.rows.length.should.equal(1); 146 | 147 | release(); 148 | done(); 149 | }); 150 | }); 151 | }); 152 | }); 153 | 154 | describe('truncation strategy', function() { 155 | before(function() { 156 | var config = { postgresql: { strategy: 'truncation', skipTables: [] } }; 157 | 158 | databaseCleaner = new DatabaseCleaner('postgresql', config); 159 | }); 160 | 161 | it('should truncate all not skippedTables records', function(done) { 162 | pg.connect(connectionString, function(err, client, release) { 163 | if (err) return done(err); 164 | 165 | databaseCleaner.clean(client, function() { 166 | async.parallel([ 167 | queryClient(client, "SELECT * FROM test1", []), 168 | queryClient(client, "SELECT * FROM test2", []), 169 | queryClient(client, "SELECT * FROM other_schema.test2", []), 170 | queryClient(client, "SELECT * FROM other_schema.test2", []), 171 | queryClient(client, "SELECT last_value FROM test1_id_seq", []), 172 | queryClient(client, "SELECT last_value FROM test2_id_seq", []) 173 | ], function(err, results) { 174 | results[0].rows.length.should.equal(0); 175 | results[1].rows.length.should.equal(0); 176 | results[2].rows.length.should.equal(2); 177 | results[3].rows.length.should.equal(2); 178 | results[4].rows[0].last_value.should.equal('1'); 179 | results[5].rows[0].last_value.should.equal('1'); 180 | 181 | release(); 182 | done(); 183 | }); 184 | }); 185 | }); 186 | }); 187 | 188 | it('should not try to truncate views', function(done) { 189 | pg.connect(connectionString, function(err, client, release) { 190 | if (err) return done(err); 191 | 192 | queryClient(client, 'CREATE VIEW public.test1_test2_view AS SELECT t1.id as t1, t2.id as t2, t1.title as t1_title, t2.title as t2_title FROM test1 t1, test2 t2;', [], function(err) { 193 | if (err) return done(err); 194 | 195 | databaseCleaner.clean(client, function(err) { 196 | if (err) return done(err); 197 | 198 | client.query("SELECT * FROM test1_test2_view", function(err, result) { 199 | if (err) return done(err); 200 | 201 | queryClient(client, 'DROP VIEW test1_test2_view;', [], function(err) { 202 | if (err) return done(err); 203 | 204 | release(); 205 | done(); 206 | }); 207 | }); 208 | }); 209 | }); 210 | }); 211 | }); 212 | }); 213 | }); 214 | 215 | describe('pg empty', function() { 216 | beforeEach(function(done) { 217 | 218 | _done = done; 219 | 220 | pg.connect(connectionString, function(err, client, done) { 221 | if (err) { 222 | return console.error('could not connect to postgresql', err); 223 | } 224 | 225 | client.query('CREATE DATABASE database_cleaner', function(err) { 226 | if (err && err.code != '42P04') { 227 | throw err; 228 | } 229 | done(); 230 | _done(); 231 | }); 232 | }); 233 | }); 234 | 235 | it('should not struck if db is empty', function(done) { 236 | _done = done; 237 | 238 | pg.connect(connectionString, function(err, client, done) { 239 | databaseCleaner.clean(client, function() { 240 | done(); 241 | _done(); 242 | }); 243 | }); 244 | }); 245 | }); 246 | -------------------------------------------------------------------------------- /test/redis.test.js: -------------------------------------------------------------------------------- 1 | var should = require('should'), 2 | DatabaseCleaner = require('../lib/database-cleaner'), 3 | databaseCleaner = new DatabaseCleaner('redis'); 4 | var redis = require('redis'); 5 | 6 | var redisHost = process.env.REDIS_HOST || 'localhost'; 7 | 8 | describe('redis', function() { 9 | var client = null; 10 | 11 | beforeEach(function(done) { 12 | client = redis.createClient(6379, redisHost, {}); 13 | client.select(1); 14 | client.mset("name", "emerson", "email", "emerleite@gmail.com", "site", "codificando.com", "github", "github.com/emerleite", done); 15 | }); 16 | 17 | afterEach(function() { 18 | client.end(); 19 | client = null; 20 | }); 21 | 22 | it('should delete all keys', function() { 23 | databaseCleaner.clean(client, function () { 24 | client.keys('*', function (err, results) { 25 | results.length.should.equal(0); 26 | done() 27 | }); 28 | }); 29 | }); 30 | }); 31 | -------------------------------------------------------------------------------- /test/sqlite.test.js: -------------------------------------------------------------------------------- 1 | var should = require('should'), 2 | sqlite3 = require('sqlite3'), 3 | _ = require('lodash'), 4 | async = require('async'); 5 | DatabaseCleaner = require('../lib/database-cleaner'), 6 | databaseCleaner = new DatabaseCleaner('sqlite'); 7 | 8 | describe.only('sqlite', function() { 9 | var client; 10 | var queryClient; 11 | 12 | beforeEach(function(done) { 13 | client = new sqlite3.Database(':memory:'); 14 | queryClient = _.curry(function(query, values, next) { 15 | client.all(query, values, next); 16 | }); 17 | 18 | async.series([ 19 | queryClient('CREATE TABLE test1 (id INTEGER PRIMARY KEY AUTOINCREMENT, title VARCHAR(255) NOT NULL);', []), 20 | queryClient('CREATE TABLE test2 (id INTEGER PRIMARY KEY AUTOINCREMENT, title VARCHAR(255) NOT NULL)', []), 21 | queryClient('INSERT INTO test1(title) VALUES(?)', ["foobar"]), 22 | queryClient('INSERT INTO test2(title) VALUES(?)', ["foobar"]), 23 | queryClient('CREATE TABLE schema_migrations (id INTEGER PRIMARY KEY AUTOINCREMENT, version VARCHAR(255) NOT NULL);', []), 24 | queryClient('INSERT INTO schema_migrations(version) VALUES(?)', ["20150716190240"]) 25 | ], done); 26 | }); 27 | 28 | context('with default config', function() { 29 | beforeEach(function() { 30 | databaseCleaner = new DatabaseCleaner('sqlite'); 31 | }); 32 | 33 | it('should delete all not skippedTables records', function(done) { 34 | databaseCleaner.clean(client, function() { 35 | async.parallel([ 36 | queryClient("SELECT * FROM test1", []), 37 | queryClient("SELECT * FROM test2", []) 38 | ], function(err, results) { 39 | should.not.exist(err); 40 | 41 | results[0].should.have.length(0); 42 | results[1].should.have.length(0); 43 | 44 | done(); 45 | }); 46 | }); 47 | }); 48 | 49 | it('should retain schema_migrations', function(done) { 50 | databaseCleaner.clean(client, function() { 51 | queryClient("SELECT * FROM schema_migrations", [], function(err, result) { 52 | should.not.exist(err); 53 | result.should.have.length(1); 54 | done(); 55 | }); 56 | }); 57 | }); 58 | 59 | it('should leave sqlite_sequence intact', function(done) { 60 | databaseCleaner.clean(client, function() { 61 | queryClient("SELECT * FROM sqlite_sequence", [], function(err, result) { 62 | should.not.exist(err); 63 | result.should.have.length(3); 64 | done(); 65 | }); 66 | }); 67 | }); 68 | 69 | context('when the db is empty', function() { 70 | beforeEach(function() { 71 | client = new sqlite3.Database(':memory:'); 72 | }); 73 | 74 | it('should return without timing out', function(done) { 75 | databaseCleaner.clean(client, done); 76 | }); 77 | }); 78 | }); 79 | 80 | context('with provided config', function() { 81 | beforeEach(function() { 82 | var config = { sqlite: { skipTables: [] } }; 83 | 84 | databaseCleaner = new DatabaseCleaner('sqlite', config); 85 | }); 86 | 87 | it('should NOT retain schema_migrations since the config did not have any tables to skip', function(done) { 88 | databaseCleaner.clean(client, function() { 89 | queryClient("SELECT * FROM schema_migrations", [], function(err, result) { 90 | result.should.have.length(0); 91 | done(); 92 | }); 93 | }); 94 | }); 95 | 96 | it('should leave sqlite_sequence intact', function(done) { 97 | databaseCleaner.clean(client, function() { 98 | queryClient("SELECT * FROM sqlite_sequence", [], function(err, result) { 99 | should.not.exist(err); 100 | result.should.have.length(3); 101 | done(); 102 | }); 103 | }); 104 | }); 105 | 106 | context('when the db is empty', function() { 107 | beforeEach(function() { 108 | client = new sqlite3.Database(':memory:'); 109 | }); 110 | 111 | it('should return without timing out', function(done) { 112 | databaseCleaner.clean(client, done); 113 | }); 114 | }); 115 | }); 116 | }); 117 | --------------------------------------------------------------------------------