aboutsummaryrefslogtreecommitdiffstats
path: root/vm.cpp
diff options
context:
space:
mode:
authorPaweł Bylica <pawel.bylica@imapp.pl>2014-12-08 18:48:26 +0800
committerPaweł Bylica <pawel.bylica@imapp.pl>2014-12-08 18:48:26 +0800
commiteafe303e083a77216c6ef4a96a99d50c9718dae8 (patch)
tree1bf1024e2d1b4b25dfa22112906e37d8239e00a7 /vm.cpp
parentbb6fcfe3f939fe81c12d6c772f4b84c3ca9cffc0 (diff)
parentfe790a3221dee0faefa9c303002a45875e08765a (diff)
downloaddexon-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.cpp59
1 files changed, 22 insertions, 37 deletions
diff --git a/vm.cpp b/vm.cpp
index 67102dcd..45034b71 100644
--- a/vm.cpp
+++ b/vm.cpp
@@ -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();