embark/lib/tests/run_tests.js

125 lines
3.6 KiB
JavaScript
Raw Normal View History

2018-05-29 13:24:45 +00:00
const async = require('async');
const fs = require('fs-extra');
const Mocha = require('mocha');
const path = require('path');
2018-06-06 15:00:30 +00:00
const assert = require('assert');
2018-06-01 17:33:11 +00:00
const Test = require('./test');
2017-07-02 04:27:14 +00:00
2018-05-29 13:24:45 +00:00
function getFilesFromDir(filePath, cb) {
fs.readdir(filePath, (err, files) => {
if (err) {
return cb(err);
}
const testFiles = files.filter((file) => {
// Only keep the .js files
// TODO: make this a configuration in embark.json
return file.substr(-3) === '.js';
}).map((file) => {
return path.join(filePath, file);
});
cb(null, testFiles);
});
}
2017-07-02 04:27:14 +00:00
2018-05-29 13:24:45 +00:00
module.exports = {
run: function (options) {
2018-06-01 17:44:49 +00:00
process.env.isTest = true;
let failures = 0;
let filePath = options.file;
const loglevel = options.loglevel || 'warn';
2018-05-29 13:24:45 +00:00
if (!filePath) {
filePath = 'test/';
}
2018-01-15 14:51:45 +00:00
2018-05-29 13:24:45 +00:00
async.waterfall([
function getFiles(next) {
if (filePath.substr(-1) !== '/') {
return fs.access(filePath, (err) => {
if (err) {
return next(`File "${filePath}" doesn't exist or you don't have permission to it`.red);
}
next(null, [filePath]);
});
}
getFilesFromDir(filePath, (err, files) => {
if (err) {
console.error('Error while reading the directory');
return next(err);
}
next(null, files);
});
},
2018-06-12 19:32:38 +00:00
function setupGlobalNamespace(files, next) {
2018-06-01 17:33:11 +00:00
// TODO put default config
const test = new Test({loglevel});
2018-06-01 17:33:11 +00:00
global.embark = test;
2018-06-06 15:00:30 +00:00
global.assert = assert;
2018-06-01 17:33:11 +00:00
global.config = test.config.bind(test);
2018-05-29 13:24:45 +00:00
2018-06-07 15:38:18 +00:00
global.deployAll = function () {
console.error(__('%s is not supported anymore', 'deployAll').red);
console.info(__('You can learn about the new revamped tests here: %s', 'https://embark.status.im/docs/testing.html'.underline));
process.exit();
};
2018-06-07 20:14:42 +00:00
// Override require to enable `require('Embark/contracts/contractName');`
const Module = require('module');
const originalRequire = require('module').prototype.require;
Module.prototype.require = function(requireName) {
if (requireName.startsWith('Embark')) {
return test.require(...arguments);
}
return originalRequire.apply(this, arguments);
};
2018-05-29 13:24:45 +00:00
// TODO: this global here might not be necessary at all
2018-06-01 17:33:11 +00:00
global.web3 = global.embark.web3;
2017-07-03 22:15:43 +00:00
global.contract = function (describeName, callback) {
2018-05-29 13:24:45 +00:00
return Mocha.describe(describeName, callback);
};
2018-06-01 17:43:43 +00:00
2018-06-01 17:44:49 +00:00
console.info('Compiling contracts'.cyan);
2018-06-12 19:32:38 +00:00
test.init((err) => {
next(err, files);
});
2018-06-01 17:44:49 +00:00
},
function executeForAllFiles(files, next) {
async.eachLimit(files, 1, (file, eachCb) => {
const mocha = new Mocha();
mocha.addFile(file);
mocha.suite.timeout(0);
mocha.suite.beforeAll('Wait for deploy', (done) => {
global.embark.onReady((err) => {
done(err);
2018-06-01 17:44:49 +00:00
});
});
mocha.run(function(fails) {
failures += fails;
// Mocha prints the error already
eachCb();
});
}, next);
2018-05-29 13:24:45 +00:00
}
], (err) => {
if (err) {
console.error(err);
process.exit(1);
}
2018-06-01 17:44:49 +00:00
if (failures) {
2018-06-01 14:48:29 +00:00
console.error(` > Total number of failures: ${failures}`.red.bold);
} else {
console.log(' > All tests passed'.green.bold);
2018-06-01 17:44:49 +00:00
}
// Clean contracts folder for next test run
fs.remove('.embark/contracts', (_err) => {
process.exit(failures);
2017-07-02 04:27:14 +00:00
});
});
}
2017-07-02 22:03:14 +00:00
};