aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorchriseth <chris@ethereum.org>2018-02-22 21:47:36 +0800
committerchriseth <chris@ethereum.org>2018-03-02 00:19:35 +0800
commit60f7be5d4cee94935ad35e3ebacd419e5b52ecce (patch)
treecd4d7fd04eb790b46c0c0f00f0e86e821bea65b4
parentf75a41132553d073202d8bc2ea65cc287c7085b7 (diff)
downloaddexon-solidity-60f7be5d4cee94935ad35e3ebacd419e5b52ecce.tar
dexon-solidity-60f7be5d4cee94935ad35e3ebacd419e5b52ecce.tar.gz
dexon-solidity-60f7be5d4cee94935ad35e3ebacd419e5b52ecce.tar.bz2
dexon-solidity-60f7be5d4cee94935ad35e3ebacd419e5b52ecce.tar.lz
dexon-solidity-60f7be5d4cee94935ad35e3ebacd419e5b52ecce.tar.xz
dexon-solidity-60f7be5d4cee94935ad35e3ebacd419e5b52ecce.tar.zst
dexon-solidity-60f7be5d4cee94935ad35e3ebacd419e5b52ecce.zip
Some tests.
-rw-r--r--test/Metadata.cpp3
-rw-r--r--test/libsolidity/StandardCompiler.cpp33
2 files changed, 35 insertions, 1 deletions
diff --git a/test/Metadata.cpp b/test/Metadata.cpp
index 1ebfd468..c130d346 100644
--- a/test/Metadata.cpp
+++ b/test/Metadata.cpp
@@ -60,7 +60,8 @@ bool isValidMetadata(string const& _metadata)
!metadata.isMember("compiler") ||
!metadata.isMember("settings") ||
!metadata.isMember("sources") ||
- !metadata.isMember("output")
+ !metadata.isMember("output") ||
+ !metadata["settings"].isMember("evmVersion")
)
return false;
diff --git a/test/libsolidity/StandardCompiler.cpp b/test/libsolidity/StandardCompiler.cpp
index eb2773ba..df3ece7c 100644
--- a/test/libsolidity/StandardCompiler.cpp
+++ b/test/libsolidity/StandardCompiler.cpp
@@ -724,6 +724,39 @@ BOOST_AUTO_TEST_CASE(library_linking)
BOOST_CHECK(contract["evm"]["bytecode"]["linkReferences"]["library2.sol"]["L2"][0].isObject());
}
+BOOST_AUTO_TEST_CASE(evm_version)
+{
+ auto inputForVersion = [](string const& _version)
+ {
+ return R"(
+ {
+ "language": "Solidity",
+ "sources": { "fileA": { "content": "contract A { }" } },
+ "settings": {
+ )" + _version + R"(
+ "outputSelection": {
+ "fileA": {
+ "A": [ "metadata" ]
+ }
+ }
+ }
+ }
+ )";
+ };
+ Json::Value result;
+ result = compile(inputForVersion("\"evmVersion\": \"homestead\","));
+ BOOST_CHECK(result["contracts"]["fileA"]["A"]["metadata"].asString().find("\"evmVersion\":\"homestead\"") != string::npos);
+ result = compile(inputForVersion("\"evmVersion\": \"byzantium\","));
+ BOOST_CHECK(result["contracts"]["fileA"]["A"]["metadata"].asString().find("\"evmVersion\":\"byzantium\"") != string::npos);
+ // test default
+ result = compile(inputForVersion(""));
+ BOOST_CHECK(result["contracts"]["fileA"]["A"]["metadata"].asString().find("\"evmVersion\":\"byzantium\"") != string::npos);
+ // test invalid
+ result = compile(inputForVersion("\"evmVersion\": \"invalid\","));
+ BOOST_CHECK(result["errors"][0]["message"].asString() == "Invalid EVM version requested.");
+}
+
+
BOOST_AUTO_TEST_SUITE_END()
}