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' ) ;
2018-01-19 21:13:20 -05:00
var Engine = require ( '../core/engine.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-05-16 19:40:24 -03:00
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 19:40:24 -03:00
} ;
2018-05-16 20:24:08 -03:00
Test . prototype . getAccounts = function ( cb ) {
this . web3 . eth . getAccounts ( function ( err , accounts ) {
2018-05-18 20:44:14 -03:00
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
2018-05-16 19:40:24 -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" ) ;
2018-05-23 11:16:56 -04:00
self . engine . startService ( "codeRunner" ) ;
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
} ) ;
2018-05-23 11:16:13 -04:00
self . engine . startService ( "codeGenerator" ) ;
2017-06-26 09:01:54 -04:00
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 ;
2018-02-21 18:43:34 -05:00
self . engine . contractsManager . gasLimit = 6000000 ;
2018-01-13 11:38:10 -05:00
self . engine . deployManager . fatalErrors = true ;
2018-03-11 08:28:03 -04:00
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 ] ;
2018-05-23 11:16:56 -04:00
self . engine . events . request ( 'runcode:eval' , result ) ;
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 ;