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 = {
|
2018-06-13 09:44:19 -04:00
|
|
|
run: function (options) {
|
2018-06-01 13:44:49 -04:00
|
|
|
process.env.isTest = true;
|
|
|
|
let failures = 0;
|
2018-06-13 09:44:19 -04:00
|
|
|
let filePath = options.file;
|
|
|
|
const loglevel = options.loglevel || 'warn';
|
2018-05-29 09:24:45 -04:00
|
|
|
if (!filePath) {
|
|
|
|
filePath = 'test/';
|
2017-07-02 11:32:16 -04:00
|
|
|
}
|
2018-01-15 09:51:45 -05:00
|
|
|
|
2018-05-29 09:24:45 -04:00
|
|
|
async.waterfall([
|
2018-06-19 10:58:09 -04:00
|
|
|
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);
|
2018-06-12 15:12:50 -04:00
|
|
|
}
|
|
|
|
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
|
2018-06-13 09:44:19 -04:00
|
|
|
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
|
|
|
|
2018-06-19 10:58:09 -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;
|
2018-06-19 10:58:09 -04:00
|
|
|
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
|
|
|
|
2018-05-30 16:17:17 -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);
|
2018-06-07 19:57:56 -04:00
|
|
|
|
|
|
|
mocha.suite.beforeAll('Wait for deploy', (done) => {
|
2018-06-08 06:14:46 -04:00
|
|
|
global.embark.onReady((err) => {
|
|
|
|
done(err);
|
2018-06-01 13:44:49 -04:00
|
|
|
});
|
|
|
|
});
|
2018-06-19 10:58:09 -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
|
|
|
};
|