aboutsummaryrefslogtreecommitdiffstats
path: root/test/libsolidity/StandardCompiler.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'test/libsolidity/StandardCompiler.cpp')
-rw-r--r--test/libsolidity/StandardCompiler.cpp62
1 files changed, 9 insertions, 53 deletions
diff --git a/test/libsolidity/StandardCompiler.cpp b/test/libsolidity/StandardCompiler.cpp
index 9b53e841..ec2f69d9 100644
--- a/test/libsolidity/StandardCompiler.cpp
+++ b/test/libsolidity/StandardCompiler.cpp
@@ -26,6 +26,7 @@
#include <libsolidity/interface/StandardCompiler.h>
#include <libdevcore/JSON.h>
+#include "../Metadata.h"
using namespace std;
using namespace dev::eth;
@@ -74,51 +75,6 @@ bool containsAtMostWarnings(Json::Value const& _compilerResult)
return true;
}
-string bytecodeSansMetadata(string const& _bytecode)
-{
- /// The metadata hash takes up 43 bytes (or 86 characters in hex)
- /// /a165627a7a72305820([0-9a-f]{64})0029$/
-
- if (_bytecode.size() < 88)
- return _bytecode;
-
- if (_bytecode.substr(_bytecode.size() - 4, 4) != "0029")
- return _bytecode;
-
- if (_bytecode.substr(_bytecode.size() - 86, 18) != "a165627a7a72305820")
- return _bytecode;
-
- return _bytecode.substr(0, _bytecode.size() - 86);
-}
-
-bool isValidMetadata(string const& _metadata)
-{
- Json::Value metadata;
- if (!Json::Reader().parse(_metadata, metadata, false))
- return false;
-
- if (
- !metadata.isObject() ||
- !metadata.isMember("version") ||
- !metadata.isMember("language") ||
- !metadata.isMember("compiler") ||
- !metadata.isMember("settings") ||
- !metadata.isMember("sources") ||
- !metadata.isMember("output")
- )
- return false;
-
- if (!metadata["version"].isNumeric() || metadata["version"] != 1)
- return false;
-
- if (!metadata["language"].isString() || metadata["language"].asString() != "Solidity")
- return false;
-
- /// @TODO add more strict checks
-
- return true;
-}
-
Json::Value getContractResult(Json::Value const& _compilerResult, string const& _file, string const& _name)
{
if (
@@ -232,17 +188,17 @@ BOOST_AUTO_TEST_CASE(basic_compilation)
BOOST_CHECK(containsAtMostWarnings(result));
Json::Value contract = getContractResult(result, "fileA", "A");
BOOST_CHECK(contract.isObject());
- BOOST_CHECK(contract["abi"].isString());
- BOOST_CHECK(contract["abi"].asString() == "[]");
- BOOST_CHECK(contract["devdoc"].isString());
- BOOST_CHECK(contract["devdoc"].asString() == "{\"methods\":{}}");
- BOOST_CHECK(contract["userdoc"].isString());
- BOOST_CHECK(contract["userdoc"].asString() == "{\"methods\":{}}");
+ BOOST_CHECK(contract["abi"].isArray());
+ BOOST_CHECK(dev::jsonCompactPrint(contract["abi"]) == "[]");
+ BOOST_CHECK(contract["devdoc"].isObject());
+ BOOST_CHECK(dev::jsonCompactPrint(contract["devdoc"]) == "{\"methods\":{}}");
+ BOOST_CHECK(contract["userdoc"].isObject());
+ BOOST_CHECK(dev::jsonCompactPrint(contract["userdoc"]) == "{\"methods\":{}}");
BOOST_CHECK(contract["evm"].isObject());
/// @TODO check evm.methodIdentifiers, legacyAssembly, bytecode, deployedBytecode
BOOST_CHECK(contract["evm"]["bytecode"].isObject());
BOOST_CHECK(contract["evm"]["bytecode"]["object"].isString());
- BOOST_CHECK(bytecodeSansMetadata(contract["evm"]["bytecode"]["object"].asString()) ==
+ BOOST_CHECK(dev::test::bytecodeSansMetadata(contract["evm"]["bytecode"]["object"].asString()) ==
"60606040523415600b57fe5b5b60338060196000396000f30060606040525bfe00");
BOOST_CHECK(contract["evm"]["assembly"].isString());
BOOST_CHECK(contract["evm"]["assembly"].asString() ==
@@ -254,7 +210,7 @@ BOOST_AUTO_TEST_CASE(basic_compilation)
BOOST_CHECK(dev::jsonCompactPrint(contract["evm"]["gasEstimates"]) ==
"{\"creation\":{\"codeDepositCost\":\"10200\",\"executionCost\":\"62\",\"totalCost\":\"10262\"}}");
BOOST_CHECK(contract["metadata"].isString());
- BOOST_CHECK(isValidMetadata(contract["metadata"].asString()));
+ BOOST_CHECK(dev::test::isValidMetadata(contract["metadata"].asString()));
BOOST_CHECK(result["sources"].isObject());
BOOST_CHECK(result["sources"]["fileA"].isObject());
BOOST_CHECK(result["sources"]["fileA"]["legacyAST"].isObject());