93 lines
3.2 KiB
JavaScript
Raw Normal View History

2016-10-02 16:57:13 -04:00
var async = require('async');
2016-08-21 18:05:35 -04:00
var Web3 = require('web3');
2016-10-02 16:57:13 -04:00
var Embark = require('./index.js');
2016-08-21 18:05:35 -04:00
var ContractsManager = require('./contracts.js');
2016-10-02 16:57:13 -04:00
var Deploy = require('./deploy.js');
2016-10-02 17:26:48 -04:00
var TestLogger = require('./test_logger.js');
2016-10-02 16:57:13 -04:00
var Config = require('./config.js');
var ABIGenerator = require('./abi.js');
2016-08-21 18:05:35 -04:00
var Test = function(_options) {
var options = _options || {};
var simOptions = options.simulatorOptions || {};
2017-02-06 06:42:58 -05:00
try {
2016-10-02 16:57:13 -04:00
this.sim = require('ethereumjs-testrpc');
2017-02-06 06:42:58 -05:00
} catch (e) {
if (e.code === 'MODULE_NOT_FOUND') {
console.log('Simulator not found; Please install it with "npm install ethereumjs-testrpc --save"');
console.log('IMPORTANT: if you using a NodeJS version older than 6.9.1 then you need to install an older version of testrpc "npm install ethereumjs-testrpc@2.0 --save"');
console.log('For more information see https://github.com/ethereumjs/testrpc');
exit();
} else {
console.log("==============");
console.log("Tried to load testrpc but an error occurred. This is a problem with testrpc");
console.log('IMPORTANT: if you using a NodeJS version older than 6.9.1 then you need to install an older version of testrpc "npm install ethereumjs-testrpc@2.0 --save". Alternatively install node 6.9.1 and the testrpc 3.0');
console.log("==============");
throw e;
}
}
2016-08-21 18:05:35 -04:00
this.web3 = new Web3();
this.web3.setProvider(this.sim.provider(simOptions));
2016-08-21 18:05:35 -04:00
};
2016-10-02 16:57:13 -04:00
Test.prototype.deployAll = function(contractsConfig, cb) {
2016-08-21 18:05:35 -04:00
var self = this;
2016-10-02 16:57:13 -04:00
var logger = new TestLogger({logLevel: 'debug'});
async.waterfall([
2017-02-03 06:30:08 -05:00
function getConfig(callback) {
var config = new Config({env: 'test', logger: logger});
2017-02-06 06:42:58 -05:00
config.loadConfigFiles({embarkConfig: 'embark.json', interceptLogs: false});
config.contractsConfig = {contracts: contractsConfig};
2017-02-03 06:30:08 -05:00
callback(null, config);
},
2017-02-06 06:42:58 -05:00
function buildContracts(config, callback) {
2016-10-02 16:57:13 -04:00
var contractsManager = new ContractsManager({
contractFiles: config.contractsFiles,
contractsConfig: config.contractsConfig,
2017-02-03 06:30:08 -05:00
logger: logger,
plugins: config.plugins
2016-10-02 16:57:13 -04:00
});
2017-02-06 06:42:58 -05:00
contractsManager.build(function() {
callback(null, contractsManager);
});
2016-10-02 16:57:13 -04:00
},
function deployContracts(contractsManager, callback) {
var deploy = new Deploy({
web3: self.web3,
contractsManager: contractsManager,
logger: logger,
chainConfig: false,
env: 'test'
});
deploy.deployAll(function() {
callback(null, contractsManager);
});
},
function generateABI(contractsManager, callback) {
var abiGenerator = new ABIGenerator({contractsManager: contractsManager});
2016-10-02 16:57:13 -04:00
var ABI = abiGenerator.generateContracts(false);
callback(null, ABI);
}
], function(err, result) {
2016-10-30 21:35:08 -04:00
if (err) {
throw new Error(err);
}
2016-10-02 16:57:13 -04:00
self.web3.eth.getAccounts(function(err, accounts) {
2016-10-30 21:35:08 -04:00
if (err) {
throw new Error(err);
}
2016-10-02 16:57:13 -04:00
var web3 = self.web3;
web3.eth.defaultAccount = accounts[0];
2016-10-22 17:29:06 -04:00
// TODO: replace evals with separate process so it's isolated and with
// a callback
2017-02-06 06:42:58 -05:00
eval(result); // jshint ignore:line
2016-10-02 16:57:13 -04:00
cb();
2016-08-21 18:05:35 -04:00
});
});
};
module.exports = Test;