117 lines
3.9 KiB
JavaScript
Raw Normal View History

2017-06-26 09:01:54 -04:00
var async = require('async');
2018-01-05 15:10:47 -05:00
//require("../utils/debug_util.js")(__filename, async);
2017-06-26 09:01:54 -04:00
var Web3 = require('web3');
var Engine = require('../core/engine.js');
var RunCode = require('../core/runCode.js');
2017-06-26 09:01:54 -04:00
var TestLogger = require('./test_logger.js');
var getSimulator = function() {
2017-03-03 21:06:44 -05:00
try {
2017-06-26 09:01:54 -04:00
var sim = require('ethereumjs-testrpc');
return sim;
2017-03-03 21:06:44 -05:00
} catch (e) {
if (e.code === 'MODULE_NOT_FOUND') {
2018-05-08 17:49:46 -04:00
console.log(__('Simulator not found; Please install it with "%s"', '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 "%s"', 'npm install ethereumjs-testrpc@2.0 --save'));
2017-03-03 21:06:44 -05:00
console.log('For more information see https://github.com/ethereumjs/testrpc');
// TODO: should throw exception instead
return process.exit();
}
console.log("==============");
2018-05-08 17:49:46 -04:00
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 "%s". Alternatively install node 6.9.1 and the testrpc 3.0', 'npm install ethereumjs-testrpc@2.0 --save'));
2017-03-03 21:06:44 -05:00
console.log("==============");
throw e;
}
};
2017-06-26 09:01:54 -04:00
var Test = function(options) {
this.options = options || {};
2018-01-15 09:51:45 -05:00
this.simOptions = this.options.simulatorOptions || {};
2017-03-03 21:06:44 -05:00
2017-06-26 09:01:54 -04:00
this.engine = new Engine({
env: this.options.env || 'test',
// TODO: confi will need to detect if this is a obj
embarkConfig: this.options.embarkConfig || 'embark.json',
interceptLogs: false
});
2017-03-30 20:12:39 +09:00
2017-06-26 09:01:54 -04:00
this.engine.init({
logger: new TestLogger({logLevel: 'debug'})
});
this.web3 = new Web3();
2018-01-15 09:51:45 -05:00
if (this.simOptions.node) {
this.web3.setProvider(new this.web3.providers.HttpProvider(this.simOptions.node));
} else {
this.sim = getSimulator();
this.web3.setProvider(this.sim.provider(this.simOptions));
}
};
2018-05-16 20:24:08 -03:00
Test.prototype.getAccounts = function(cb) {
this.web3.eth.getAccounts(function(err, accounts) {
cb(err, accounts);
2018-05-16 20:24:08 -03:00
});
2018-05-17 03:00:23 -03:00
};
2018-05-16 20:24:08 -03:00
Test.prototype.deployAll = function(contractsConfig, cb) {
var self = this;
2018-05-16 20:24:08 -03:00
2017-06-26 09:01:54 -04:00
async.waterfall([
function getConfig(callback) {
2017-12-16 17:55:27 -05:00
let _versions_default = self.engine.config.contractsConfig.versions;
self.engine.config.contractsConfig = {contracts: contractsConfig, versions: _versions_default};
2017-06-26 09:01:54 -04:00
callback();
},
function startServices(callback) {
//{abiType: 'contracts', embarkJS: false}
2017-12-30 17:07:13 -05:00
self.engine.startService("libraryManager");
2017-10-13 05:56:42 -04:00
self.engine.startService("codeGenerator");
2018-05-18 18:31:47 -04:00
self.engine.startService("web3", {
web3: self.web3
});
2017-06-26 09:01:54 -04:00
self.engine.startService("deployment", {
trackContracts: false
});
callback();
},
function deploy(callback) {
2017-10-13 05:56:42 -04:00
self.engine.events.on('code-generator-ready', function () {
2017-10-17 07:03:13 -04:00
self.engine.events.request('code-contracts-vanila', function(vanillaABI) {
2017-10-13 05:56:42 -04:00
callback(null, vanillaABI);
});
2017-06-26 09:01:54 -04:00
});
2017-10-13 05:56:42 -04:00
2018-01-13 11:38:10 -05:00
self.engine.deployManager.gasLimit = 6000000;
self.engine.contractsManager.gasLimit = 6000000;
2018-01-13 11:38:10 -05:00
self.engine.deployManager.fatalErrors = true;
self.engine.deployManager.deployOnlyOnConfig = true;
2017-12-13 20:15:57 -05:00
self.engine.deployManager.deployContracts(function(err, _result) {
2017-06-26 09:01:54 -04:00
if (err) {
callback(err);
}
});
}
], function(err, result) {
if (err) {
2018-05-08 17:49:46 -04:00
console.log(__('terminating due to error'));
2018-04-24 10:19:01 -04:00
process.exit(1);
2017-03-12 12:23:30 +09:00
}
2017-06-26 09:01:54 -04:00
// this should be part of the waterfall and not just something done at the
// end
2017-12-13 20:15:57 -05:00
self.web3.eth.getAccounts(function(err, accounts) {
2017-06-26 09:01:54 -04:00
if (err) {
throw new Error(err);
}
self.web3.eth.defaultAccount = accounts[0];
RunCode.doEval(result, {web3: self.web3});
2017-12-22 13:07:43 -05:00
//cb();
cb(accounts);
2017-06-26 09:01:54 -04:00
});
});
};
2016-08-21 18:05:35 -04:00
module.exports = Test;