diff options
author | Paweł Bylica <pawel.bylica@imapp.pl> | 2014-12-12 18:48:15 +0800 |
---|---|---|
committer | Paweł Bylica <pawel.bylica@imapp.pl> | 2014-12-12 18:54:44 +0800 |
commit | 49f995a890ee54e90650d839267bd24339c954f8 (patch) | |
tree | f5e87b2b1cc4c230c184e4bf504a6692e46c5b06 | |
parent | b0b14eca7f40e29ce892109b0238cbba752ca236 (diff) | |
download | dexon-solidity-49f995a890ee54e90650d839267bd24339c954f8.tar dexon-solidity-49f995a890ee54e90650d839267bd24339c954f8.tar.gz dexon-solidity-49f995a890ee54e90650d839267bd24339c954f8.tar.bz2 dexon-solidity-49f995a890ee54e90650d839267bd24339c954f8.tar.lz dexon-solidity-49f995a890ee54e90650d839267bd24339c954f8.tar.xz dexon-solidity-49f995a890ee54e90650d839267bd24339c954f8.tar.zst dexon-solidity-49f995a890ee54e90650d839267bd24339c954f8.zip |
Add "--jit" option to State tests
-rw-r--r-- | TestHelper.cpp | 17 | ||||
-rw-r--r-- | TestHelper.h | 1 | ||||
-rw-r--r-- | state.cpp | 2 | ||||
-rw-r--r-- | vm.cpp | 19 |
4 files changed, 25 insertions, 14 deletions
diff --git a/TestHelper.cpp b/TestHelper.cpp index b0935d0b..6f7bf31d 100644 --- a/TestHelper.cpp +++ b/TestHelper.cpp @@ -26,6 +26,7 @@ #include <boost/filesystem/path.hpp> #include <libethereum/Client.h> #include <liblll/Compiler.h> +#include <libevm/VMFactory.h> using namespace std; using namespace dev::eth; @@ -472,4 +473,20 @@ void executeTests(const string& _name, const string& _testPathAppendix, std::fun } } + +void processCommandLineOptions() +{ + auto argc = boost::unit_test::framework::master_test_suite().argc; + auto argv = boost::unit_test::framework::master_test_suite().argv; + + for (auto i = 0; i < argc; ++i) + { + if (std::string(argv[i]) == "--jit") + { + eth::VMFactory::setKind(eth::VMKind::JIT); + break; + } + } +} + } } // namespaces diff --git a/TestHelper.h b/TestHelper.h index 3203eae8..20328c91 100644 --- a/TestHelper.h +++ b/TestHelper.h @@ -76,6 +76,7 @@ void checkLog(eth::LogEntries _resultLogs, eth::LogEntries _expectedLogs); void executeTests(const std::string& _name, const std::string& _testPathAppendix, std::function<void(json_spirit::mValue&, bool)> doTests); std::string getTestPath(); void userDefinedTest(std::string testTypeFlag, std::function<void(json_spirit::mValue&, bool)> doTests); +void processCommandLineOptions(); template<typename mapType> void checkAddresses(mapType& _expectedAddrs, mapType& _resultAddrs) @@ -43,6 +43,8 @@ namespace dev { namespace test { void doStateTests(json_spirit::mValue& v, bool _fillin) { + processCommandLineOptions(); + for (auto& i: v.get_obj()) { cnote << i.first; @@ -277,6 +277,8 @@ namespace dev { namespace test { void doVMTests(json_spirit::mValue& v, bool _fillin) { + processCommandLineOptions(); + for (auto& i: v.get_obj()) { cnote << i.first; @@ -286,20 +288,7 @@ void doVMTests(json_spirit::mValue& v, bool _fillin) BOOST_REQUIRE(o.count("pre") > 0); BOOST_REQUIRE(o.count("exec") > 0); - auto argc = boost::unit_test::framework::master_test_suite().argc; - auto argv = boost::unit_test::framework::master_test_suite().argv; - - for (auto i = 0; i < argc; ++i) - { - if (std::string(argv[i]) == "--jit") - { - VMFactory::setKind(VMKind::JIT); - break; - } - } - - dev::test::FakeExtVM fev; - + FakeExtVM fev; fev.importEnv(o["env"].get_obj()); fev.importState(o["pre"].get_obj()); @@ -340,6 +329,8 @@ void doVMTests(json_spirit::mValue& v, bool _fillin) } auto endTime = std::chrono::high_resolution_clock::now(); + auto argc = boost::unit_test::framework::master_test_suite().argc; + auto argv = boost::unit_test::framework::master_test_suite().argv; for (auto i = 0; i < argc; ++i) { if (std::string(argv[i]) == "--show-times") |