embark-area-51/lib/tests/run_tests.js

143 lines
4.2 KiB
JavaScript
Raw Normal View History

2018-05-29 09:24:45 -04:00
const async = require('async');
const fs = require('fs-extra');
const Mocha = require('mocha');
const path = require('path');
2018-06-06 11:00:30 -04:00
const assert = require('assert');
2018-06-01 13:33:11 -04:00
const Test = require('./test');
2018-06-28 14:01:44 -04:00
const EmbarkSpec = require('./reporter');
2017-07-02 00:27:14 -04:00
2018-05-29 09:24:45 -04: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 00:27:14 -04:00
2018-05-29 09:24:45 -04:00
module.exports = {
run: function (options) {
2018-06-01 13:44:49 -04:00
process.env.isTest = true;
let failures = 0;
let filePath = options.file;
const loglevel = options.loglevel || 'warn';
2018-05-29 09:24:45 -04:00
if (!filePath) {
filePath = 'test/';
}
2018-01-15 09:51:45 -05:00
2018-05-29 09:24:45 -04:00
async.waterfall([
function checkIfDir(next) {
if (filePath.substr(-1) === '/') {
return next(null, null);
}
fs.stat(filePath, (err, stats) => {
if (err) {
return next(`File "${filePath}" doesn't exist or you don't have permission to it`.red);
}
if (stats.isDirectory()) {
return next(null, null);
}
next(null, [filePath]);
});
},
function getFiles(files, next) {
if (files) {
return next(null, files);
}
getFilesFromDir(filePath, (err, files) => {
if (err) {
console.error('Error while reading the directory');
return next(err);
}
next(null, files);
});
},
2018-06-12 15:32:38 -04:00
function setupGlobalNamespace(files, next) {
2018-06-01 13:33:11 -04:00
// TODO put default config
const test = new Test({loglevel});
2018-06-01 13:33:11 -04:00
global.embark = test;
2018-06-06 11:00:30 -04:00
global.assert = assert;
2018-06-01 13:33:11 -04:00
global.config = test.config.bind(test);
2018-05-29 09:24:45 -04:00
let deprecatedWarning = function () {
2018-06-18 12:46:39 -04:00
console.error(__('%s are not supported anymore', 'EmbarkSpec & deployAll').red);
2018-06-07 11:38:18 -04:00
console.info(__('You can learn about the new revamped tests here: %s', 'https://embark.status.im/docs/testing.html'.underline));
process.exit();
};
2018-06-18 12:46:39 -04:00
global.deployAll = deprecatedWarning;
global.EmbarkSpec = {};
global.EmbarkSpec.deployAll = deprecatedWarning;
2018-06-07 16:14:42 -04:00
// Override require to enable `require('Embark/contracts/contractName');`
const Module = require('module');
const originalRequire = require('module').prototype.require;
Module.prototype.require = function (requireName) {
2018-06-07 16:14:42 -04:00
if (requireName.startsWith('Embark')) {
return test.require(...arguments);
}
return originalRequire.apply(this, arguments);
};
2018-05-29 09:24:45 -04:00
// TODO: this global here might not be necessary at all
2018-06-01 13:33:11 -04:00
global.web3 = global.embark.web3;
2017-07-03 18:15:43 -04:00
global.contract = function (describeName, callback) {
2018-05-29 09:24:45 -04:00
return Mocha.describe(describeName, callback);
};
2018-06-01 13:43:43 -04:00
2018-06-12 15:32:38 -04:00
test.init((err) => {
next(err, files);
});
2018-06-01 13:44:49 -04:00
},
function executeForAllFiles(files, next) {
async.eachLimit(files, 1, (file, eachCb) => {
const mocha = new Mocha();
2018-06-28 16:14:34 -04:00
mocha.reporter(EmbarkSpec, {
events: global.embark.engine.events,
gasDetails: options.gasDetails,
2018-07-27 13:57:39 -04:00
gasLimit: 6000000
2018-06-28 16:14:34 -04:00
});
2018-06-01 13:44:49 -04:00
mocha.addFile(file);
mocha.suite.timeout(0);
mocha.suite.beforeAll('Wait for deploy', (done) => {
global.embark.onReady((err) => {
done(err);
2018-06-01 13:44:49 -04:00
});
});
mocha.run(function (fails) {
2018-06-01 13:44:49 -04:00
failures += fails;
2018-06-28 15:18:28 -04:00
mocha.suite.removeAllListeners();
2018-06-01 13:44:49 -04:00
// Mocha prints the error already
eachCb();
});
}, next);
2018-05-29 09:24:45 -04:00
}
], (err) => {
if (err) {
console.error(err);
process.exit(1);
}
2018-06-01 13:44:49 -04:00
if (failures) {
2018-06-01 10:48:29 -04:00
console.error(` > Total number of failures: ${failures}`.red.bold);
} else {
console.log(' > All tests passed'.green.bold);
2018-06-01 13:44:49 -04:00
}
// Clean contracts folder for next test run
fs.remove('.embark/contracts', (_err) => {
process.exit(failures);
2017-07-02 00:27:14 -04:00
});
});
}
2017-07-02 18:03:14 -04:00
};