diff options
author | Paweł Bylica <pawel.bylica@imapp.pl> | 2014-12-08 18:48:26 +0800 |
---|---|---|
committer | Paweł Bylica <pawel.bylica@imapp.pl> | 2014-12-08 18:48:26 +0800 |
commit | eafe303e083a77216c6ef4a96a99d50c9718dae8 (patch) | |
tree | 1bf1024e2d1b4b25dfa22112906e37d8239e00a7 /vm.cpp | |
parent | bb6fcfe3f939fe81c12d6c772f4b84c3ca9cffc0 (diff) | |
parent | fe790a3221dee0faefa9c303002a45875e08765a (diff) | |
download | dexon-solidity-eafe303e083a77216c6ef4a96a99d50c9718dae8.tar dexon-solidity-eafe303e083a77216c6ef4a96a99d50c9718dae8.tar.gz dexon-solidity-eafe303e083a77216c6ef4a96a99d50c9718dae8.tar.bz2 dexon-solidity-eafe303e083a77216c6ef4a96a99d50c9718dae8.tar.lz dexon-solidity-eafe303e083a77216c6ef4a96a99d50c9718dae8.tar.xz dexon-solidity-eafe303e083a77216c6ef4a96a99d50c9718dae8.tar.zst dexon-solidity-eafe303e083a77216c6ef4a96a99d50c9718dae8.zip |
Merge branch 'develop' into vm
Diffstat (limited to 'vm.cpp')
-rw-r--r-- | vm.cpp | 59 |
1 files changed, 22 insertions, 37 deletions
@@ -121,41 +121,6 @@ void FakeExtVM::importEnv(mObject& _o) currentBlock.coinbaseAddress = Address(_o["currentCoinbase"].get_str()); } -mObject FakeExtVM::exportLog() -{ - mObject ret; - for (LogEntry const& l: sub.logs) - { - mObject o; - o["address"] = toString(l.address); - mArray topics; - for (auto const& t: l.topics) - topics.push_back(toString(t)); - o["topics"] = topics; - o["data"] = "0x" + toHex(l.data); - ret[toString(l.bloom())] = o; - } - return ret; -} - -void FakeExtVM::importLog(mObject& _o) -{ - for (auto const& l: _o) - { - mObject o = l.second.get_obj(); - // cant use BOOST_REQUIRE, because this function is used outside boost test (createRandomTest) - assert(o.count("address") > 0); - assert(o.count("topics") > 0); - assert(o.count("data") > 0); - LogEntry log; - log.address = Address(o["address"].get_str()); - for (auto const& t: o["topics"].get_array()) - log.topics.push_back(h256(t.get_str())); - log.data = importData(o); - sub.logs.push_back(log); - } -} - mObject FakeExtVM::exportState() { mObject ret; @@ -385,7 +350,7 @@ void doVMTests(json_spirit::mValue& v, bool _fillin) o["callcreates"] = fev.exportCallCreates(); o["out"] = "0x" + toHex(output); fev.push(o, "gas", gas); - o["logs"] = mValue(exportLog(fev.sub.logs)); + o["logs"] = exportLog(fev.sub.logs); } } else @@ -403,7 +368,7 @@ void doVMTests(json_spirit::mValue& v, bool _fillin) dev::test::FakeExtVM test; test.importState(o["post"].get_obj()); test.importCallCreates(o["callcreates"].get_array()); - test.sub.logs = importLog(o["logs"].get_obj()); + test.sub.logs = importLog(o["logs"].get_array()); checkOutput(output, o); @@ -489,6 +454,26 @@ BOOST_AUTO_TEST_CASE(vmLogTest) dev::test::executeTests("vmLogTest", "/VMTests", dev::test::doVMTests); } +BOOST_AUTO_TEST_CASE(vmPerformanceTest) +{ + for (int i = 1; i < boost::unit_test::framework::master_test_suite().argc; ++i) + { + string arg = boost::unit_test::framework::master_test_suite().argv[i]; + if (arg == "--performance") + dev::test::executeTests("vmPerformanceTest", "/VMTests", dev::test::doVMTests); + } +} + +BOOST_AUTO_TEST_CASE(vmArithPerformanceTest) +{ + for (int i = 1; i < boost::unit_test::framework::master_test_suite().argc; ++i) + { + string arg = boost::unit_test::framework::master_test_suite().argv[i]; + if (arg == "--performance") + dev::test::executeTests("vmArithPerformanceTest", "/VMTests", dev::test::doVMTests); + } +} + BOOST_AUTO_TEST_CASE(vmRandom) { string testPath = getTestPath(); |