From c7876bc7cdc6c83c586a05464fae60df3ddbd827 Mon Sep 17 00:00:00 2001 From: Jonathan Rainville Date: Thu, 28 Jun 2018 14:01:44 -0400 Subject: [PATCH] add reporter with event to get receipt --- lib/contracts/contract_deployer.js | 1 + lib/tests/reporter.js | 72 ++++++++++++++++++++++++++++++ lib/tests/run_tests.js | 2 + 3 files changed, 75 insertions(+) create mode 100644 lib/tests/reporter.js diff --git a/lib/contracts/contract_deployer.js b/lib/contracts/contract_deployer.js index b97bb475..50140085 100644 --- a/lib/contracts/contract_deployer.js +++ b/lib/contracts/contract_deployer.js @@ -242,6 +242,7 @@ class ContractDeployer { self.logger.info(contract.className.bold.cyan + " " + __("deployed at").green + " " + receipt.contractAddress.bold.cyan); contract.deployedAddress = receipt.contractAddress; contract.transactionHash = receipt.transactionHash; + receipt.className = contract.className; self.events.emit("deploy:contract:receipt", receipt); self.events.emit("deploy:contract:deployed", contract); diff --git a/lib/tests/reporter.js b/lib/tests/reporter.js new file mode 100644 index 00000000..91cfbfcc --- /dev/null +++ b/lib/tests/reporter.js @@ -0,0 +1,72 @@ +const Base = require('mocha/lib/reporters/base'); +const color = Base.color; + +class EmbarkSpec extends Base { + constructor(runner, options) { + super(runner, options); + + const self = this; + self.embarkEvents = options.reporterOptions.events; + let indents = 0; + let n = 0; + + function onContractReceipt(receipt) { + console.log(receipt.className, receipt.gasUsed); + } + self.embarkEvents.on("deploy:contract:receipt", onContractReceipt); + + function indent() { + return Array(indents).join(' '); + } + + runner.on('start', function () { + console.log(); + }); + + runner.on('suite', function (suite) { + ++indents; + console.log(color('suite', '%s%s'), indent(), suite.title); + }); + + runner.on('suite end', function () { + --indents; + if (indents === 1) { + console.log(); + } + }); + + runner.on('pending', function (test) { + const fmt = indent() + color('pending', ' - %s'); + console.log(fmt, test.title); + }); + + runner.on('pass', function (test) { + let fmt; + if (test.speed === 'fast') { + fmt = + indent() + + color('checkmark', ' ' + Base.symbols.ok) + + color('pass', ' %s'); + console.log(fmt, test.title); + } else { + fmt = + indent() + + color('checkmark', ' ' + Base.symbols.ok) + + color('pass', ' %s') + + color(test.speed, ' (%dms)'); + console.log(fmt, test.title, test.duration); + } + }); + + runner.on('fail', function (test) { + console.log(indent() + color('fail', ' %d) %s'), ++n, test.title); + }); + + runner.once('end', function() { + self.embarkEvents.removeListener("deploy:contract:receipt", onContractReceipt); + self.epilogue(); + }); + } +} + +module.exports = EmbarkSpec; diff --git a/lib/tests/run_tests.js b/lib/tests/run_tests.js index 80d23870..89fe4034 100644 --- a/lib/tests/run_tests.js +++ b/lib/tests/run_tests.js @@ -4,6 +4,7 @@ const Mocha = require('mocha'); const path = require('path'); const assert = require('assert'); const Test = require('./test'); +const EmbarkSpec = require('./reporter'); function getFilesFromDir(filePath, cb) { fs.readdir(filePath, (err, files) => { @@ -100,6 +101,7 @@ module.exports = { function executeForAllFiles(files, next) { async.eachLimit(files, 1, (file, eachCb) => { const mocha = new Mocha(); + mocha.reporter(EmbarkSpec, {events: global.embark.engine.events}); mocha.addFile(file); mocha.suite.timeout(0);