mirror of
				https://github.com/ethereum/solidity
				synced 2023-10-03 13:03:40 +00:00 
			
		
		
		
	Merge remote-tracking branch 'origin/vm' into develop-evmcc
Conflicts: libethereum/Executive.cpp libethereum/Executive.h libethereum/State.cpp libevm/VM.cpp libevm/VM.h libevm/VMFace.h test/createRandomTest.cpp test/vm.cpp windows/LibEthereum.vcxproj.filters
This commit is contained in:
		
						commit
						3ba2d4195f
					
				| @ -72,7 +72,7 @@ ImportTest::ImportTest(json_spirit::mObject& _o, bool isFiller): m_TestObject(_o | ||||
| 	if (!isFiller) | ||||
| 	{ | ||||
| 		importState(_o["post"].get_obj(), m_statePost); | ||||
| 		m_environment.sub.logs = importLog(_o["logs"].get_obj()); | ||||
| 		m_environment.sub.logs = importLog(_o["logs"].get_array()); | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| @ -259,16 +259,17 @@ bytes importCode(json_spirit::mObject& _o) | ||||
| 	return code; | ||||
| } | ||||
| 
 | ||||
| LogEntries importLog(json_spirit::mObject& _o) | ||||
| LogEntries importLog(json_spirit::mArray& _a) | ||||
| { | ||||
| 	LogEntries logEntries; | ||||
| 	for (auto const& l: _o) | ||||
| 	for (auto const& l: _a) | ||||
| 	{ | ||||
| 		json_spirit::mObject o = l.second.get_obj(); | ||||
| 		json_spirit::mObject o = l.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); | ||||
| 		assert(o.count("bloom") > 0); | ||||
| 		LogEntry log; | ||||
| 		log.address = Address(o["address"].get_str()); | ||||
| 		for (auto const& t: o["topics"].get_array()) | ||||
| @ -279,9 +280,9 @@ LogEntries importLog(json_spirit::mObject& _o) | ||||
| 	return logEntries; | ||||
| } | ||||
| 
 | ||||
| json_spirit::mObject exportLog(eth::LogEntries _logs) | ||||
| json_spirit::mArray exportLog(eth::LogEntries _logs) | ||||
| { | ||||
| 	json_spirit::mObject ret; | ||||
| 	json_spirit::mArray ret; | ||||
| 	if (_logs.size() == 0) return ret; | ||||
| 	for (LogEntry const& l: _logs) | ||||
| 	{ | ||||
| @ -292,7 +293,8 @@ json_spirit::mObject exportLog(eth::LogEntries _logs) | ||||
| 			topics.push_back(toString(t)); | ||||
| 		o["topics"] = topics; | ||||
| 		o["data"] = "0x" + toHex(l.data); | ||||
| 		ret[toString(l.bloom())] = o; | ||||
| 		o["bloom"] = toString(l.bloom()); | ||||
| 		ret.push_back(o); | ||||
| 	} | ||||
| 	return ret; | ||||
| } | ||||
|  | ||||
| @ -68,8 +68,8 @@ u256 toInt(json_spirit::mValue const& _v); | ||||
| byte toByte(json_spirit::mValue const& _v); | ||||
| bytes importCode(json_spirit::mObject& _o); | ||||
| bytes importData(json_spirit::mObject& _o); | ||||
| eth::LogEntries importLog(json_spirit::mObject& _o); | ||||
| json_spirit::mObject exportLog(eth::LogEntries _logs); | ||||
| eth::LogEntries importLog(json_spirit::mArray& _o); | ||||
| json_spirit::mArray exportLog(eth::LogEntries _logs); | ||||
| void checkOutput(bytes const& _output, json_spirit::mObject& _o); | ||||
| void checkStorage(std::map<u256, u256> _expectedStore, std::map<u256, u256> _resultStore, Address _expectedAddr); | ||||
| void checkLog(eth::LogEntries _resultLogs, eth::LogEntries _expectedLogs); | ||||
|  | ||||
| @ -31,9 +31,8 @@ | ||||
| #include <json_spirit/json_spirit_writer_template.h> | ||||
| #include <libdevcore/CommonIO.h> | ||||
| #include <libdevcore/CommonData.h> | ||||
| #include <libethereum/VMFactory.h> | ||||
| #include <libevmcore/Instruction.h> | ||||
| #include <libevm/VM.h> | ||||
| #include <libevm/VMFactory.h> | ||||
| #include "vm.h" | ||||
| 
 | ||||
| using namespace std; | ||||
| @ -129,9 +128,6 @@ void doMyTests(json_spirit::mValue& v) | ||||
| 		assert(o.count("pre") > 0); | ||||
| 		assert(o.count("exec") > 0); | ||||
| 
 | ||||
| 
 | ||||
| 		auto vmObj = eth::VMFactory::create(eth::VMFactory::Interpreter); | ||||
| 		auto& vm = *vmObj; | ||||
| 		dev::test::FakeExtVM fev; | ||||
| 		fev.importEnv(o["env"].get_obj()); | ||||
| 		fev.importState(o["pre"].get_obj()); | ||||
| @ -145,14 +141,15 @@ void doMyTests(json_spirit::mValue& v) | ||||
| 			fev.code = fev.thisTxCode; | ||||
| 		} | ||||
| 
 | ||||
| 		vm.reset(fev.gas); | ||||
| 		bytes output; | ||||
| 		auto vm = eth::VMFactory::create(fev.gas); | ||||
| 
 | ||||
| 		u256 gas; | ||||
| 		bool vmExceptionOccured = false; | ||||
| 		try | ||||
| 		{ | ||||
| 			output = vm.go(fev, fev.simpleTrace()).toBytes(); | ||||
| 			gas = vm.gas(); | ||||
| 			output = vm->go(fev, fev.simpleTrace()).toBytes(); | ||||
| 			gas = vm->gas(); | ||||
| 		} | ||||
| 		catch (eth::VMException const& _e) | ||||
| 		{ | ||||
| @ -192,7 +189,7 @@ void doMyTests(json_spirit::mValue& v) | ||||
| 			o["callcreates"] = fev.exportCallCreates(); | ||||
| 			o["out"] = "0x" + toHex(output); | ||||
| 			fev.push(o, "gas", gas); | ||||
| 			o["logs"] = mValue(test::exportLog(fev.sub.logs)); | ||||
| 			o["logs"] = test::exportLog(fev.sub.logs); | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
|  | ||||
| @ -44,6 +44,14 @@ static CryptoPP::OID s_curveOID(CryptoPP::ASN1::secp256k1()); | ||||
| static CryptoPP::DL_GroupParameters_EC<CryptoPP::ECP> s_params(s_curveOID); | ||||
| static CryptoPP::DL_GroupParameters_EC<CryptoPP::ECP>::EllipticCurve s_curve(s_params.GetCurve()); | ||||
| 
 | ||||
| BOOST_AUTO_TEST_CASE(cryptopp_patch) | ||||
| { | ||||
| 	KeyPair k = KeyPair::create(); | ||||
| 	bytes io_text; | ||||
| 	s_secp256k1.decrypt(k.sec(), io_text); | ||||
| 	BOOST_REQUIRE_EQUAL(io_text.size(), 0); | ||||
| } | ||||
| 
 | ||||
| BOOST_AUTO_TEST_CASE(verify_secert) | ||||
| { | ||||
| 	h256 empty; | ||||
|  | ||||
| @ -46,16 +46,23 @@ namespace | ||||
| bytes compileContract(const string& _sourceCode) | ||||
| { | ||||
| 	Parser parser; | ||||
| 	ASTPointer<ContractDefinition> contract; | ||||
| 	BOOST_REQUIRE_NO_THROW(contract = parser.parse(make_shared<Scanner>(CharStream(_sourceCode)))); | ||||
| 	ASTPointer<SourceUnit> sourceUnit; | ||||
| 	BOOST_REQUIRE_NO_THROW(sourceUnit = parser.parse(make_shared<Scanner>(CharStream(_sourceCode)))); | ||||
| 	NameAndTypeResolver resolver({}); | ||||
| 	BOOST_REQUIRE_NO_THROW(resolver.resolveNamesAndTypes(*contract)); | ||||
| 	resolver.registerDeclarations(*sourceUnit); | ||||
| 	for (ASTPointer<ASTNode> const& node: sourceUnit->getNodes()) | ||||
| 		if (ContractDefinition* contract = dynamic_cast<ContractDefinition*>(node.get())) | ||||
| 		{ | ||||
| 			BOOST_REQUIRE_NO_THROW(resolver.resolveNamesAndTypes(*contract)); | ||||
| 
 | ||||
| 	Compiler compiler; | ||||
| 	compiler.compileContract(*contract, {}); | ||||
| 	// debug
 | ||||
| 	//compiler.streamAssembly(cout);
 | ||||
| 	return compiler.getAssembledBytecode(); | ||||
| 			Compiler compiler; | ||||
| 			compiler.compileContract(*contract, {}); | ||||
| 			// debug
 | ||||
| 			//compiler.streamAssembly(cout);
 | ||||
| 			return compiler.getAssembledBytecode(); | ||||
| 		} | ||||
| 	BOOST_FAIL("No contract found in source."); | ||||
| 	return bytes(); | ||||
| } | ||||
| 
 | ||||
| /// Checks that @a _compiledCode is present starting from offset @a _offset in @a _expectation.
 | ||||
| @ -118,8 +125,8 @@ BOOST_AUTO_TEST_CASE(different_argument_numbers) | ||||
| 					   byte(Instruction::JUMP), // end of f
 | ||||
| 					   byte(Instruction::JUMPDEST), // beginning of g
 | ||||
| 					   byte(Instruction::PUSH1), 0x0, | ||||
| 					   byte(Instruction::DUP1), // initialized e and h
 | ||||
| 					   byte(Instruction::PUSH1), byte(0x29 + shift), // ret address
 | ||||
| 					   byte(Instruction::PUSH1), 0x0, // initialized e and h
 | ||||
| 					   byte(Instruction::PUSH1), byte(0x2a + shift), // ret address
 | ||||
| 					   byte(Instruction::PUSH1), 0x1, byte(Instruction::PUSH1), 0xff, byte(Instruction::AND), | ||||
| 					   byte(Instruction::PUSH1), 0x2, byte(Instruction::PUSH1), 0xff, byte(Instruction::AND), | ||||
| 					   byte(Instruction::PUSH1), 0x3, byte(Instruction::PUSH1), 0xff, byte(Instruction::AND), | ||||
|  | ||||
| @ -47,9 +47,11 @@ class ExecutionFramework | ||||
| public: | ||||
| 	ExecutionFramework() { g_logVerbosity = 0; } | ||||
| 
 | ||||
| 	bytes const& compileAndRun(string const& _sourceCode, u256 const& _value = 0) | ||||
| 	bytes const& compileAndRun(string const& _sourceCode, u256 const& _value = 0, string const& _contractName = "") | ||||
| 	{ | ||||
| 		bytes code = dev::solidity::CompilerStack::staticCompile(_sourceCode); | ||||
| 		dev::solidity::CompilerStack compiler; | ||||
| 		compiler.compile(_sourceCode); | ||||
| 		bytes code = compiler.getBytecode(_contractName); | ||||
| 		sendMessage(code, true, _value); | ||||
| 		BOOST_REQUIRE(!m_output.empty()); | ||||
| 		return m_output; | ||||
| @ -115,6 +117,7 @@ private: | ||||
| 
 | ||||
| 	void sendMessage(bytes const& _data, bool _isCreation, u256 const& _value = 0) | ||||
| 	{ | ||||
| 		m_state.addBalance(m_sender, _value); // just in case
 | ||||
| 		eth::Executive executive(m_state); | ||||
| 		eth::Transaction t = _isCreation ? eth::Transaction(_value, m_gasPrice, m_gas, _data, 0, KeyPair::create().sec()) | ||||
| 										 : eth::Transaction(_value, m_gasPrice, m_gas, m_contractAddress, _data, 0, KeyPair::create().sec()); | ||||
| @ -127,7 +130,7 @@ private: | ||||
| 		catch (...) {} | ||||
| 		if (_isCreation) | ||||
| 		{ | ||||
| 			BOOST_REQUIRE(!executive.create(Address(), _value, m_gasPrice, m_gas, &_data, Address())); | ||||
| 			BOOST_REQUIRE(!executive.create(m_sender, _value, m_gasPrice, m_gas, &_data, m_sender)); | ||||
| 			m_contractAddress = executive.newAddress(); | ||||
| 			BOOST_REQUIRE(m_contractAddress); | ||||
| 			BOOST_REQUIRE(m_state.addressHasCode(m_contractAddress)); | ||||
| @ -135,14 +138,16 @@ private: | ||||
| 		else | ||||
| 		{ | ||||
| 			BOOST_REQUIRE(m_state.addressHasCode(m_contractAddress)); | ||||
| 			BOOST_REQUIRE(!executive.call(m_contractAddress, Address(), _value, m_gasPrice, &_data, m_gas, Address())); | ||||
| 			BOOST_REQUIRE(!executive.call(m_contractAddress, m_sender, _value, m_gasPrice, &_data, m_gas, m_sender)); | ||||
| 		} | ||||
| 		BOOST_REQUIRE(executive.go()); | ||||
| 		m_state.noteSending(m_sender); | ||||
| 		executive.finalize(); | ||||
| 		m_output = executive.out().toVector(); | ||||
| 	} | ||||
| 
 | ||||
| protected: | ||||
| 	Address m_sender; | ||||
| 	Address m_contractAddress; | ||||
| 	eth::State m_state; | ||||
| 	u256 const m_gasPrice = 100 * eth::szabo; | ||||
| @ -898,6 +903,163 @@ BOOST_AUTO_TEST_CASE(ecrecover) | ||||
| 	BOOST_CHECK(callContractFunction(0, h, v, r, s) == toBigEndian(addr)); | ||||
| } | ||||
| 
 | ||||
| BOOST_AUTO_TEST_CASE(inter_contract_calls) | ||||
| { | ||||
| 	char const* sourceCode = R"( | ||||
| 		contract Helper { | ||||
| 			function multiply(uint a, uint b) returns (uint c) { | ||||
| 				return a * b; | ||||
| 			} | ||||
| 		} | ||||
| 		contract Main { | ||||
| 			Helper h; | ||||
| 			function callHelper(uint a, uint b) returns (uint c) { | ||||
| 				return h.multiply(a, b); | ||||
| 			} | ||||
| 			function getHelper() returns (address haddress) { | ||||
| 				return address(h); | ||||
| 			} | ||||
| 			function setHelper(address haddress) { | ||||
| 				h = Helper(haddress); | ||||
| 			} | ||||
| 		})"; | ||||
| 	compileAndRun(sourceCode, 0, "Helper"); | ||||
| 	u160 const helperAddress = m_contractAddress; | ||||
| 	compileAndRun(sourceCode, 0, "Main"); | ||||
| 	BOOST_REQUIRE(callContractFunction(2, helperAddress) == bytes()); | ||||
| 	BOOST_REQUIRE(callContractFunction(1, helperAddress) == toBigEndian(helperAddress)); | ||||
| 	u256 a(3456789); | ||||
| 	u256 b("0x282837623374623234aa74"); | ||||
| 	BOOST_REQUIRE(callContractFunction(0, a, b) == toBigEndian(a * b)); | ||||
| } | ||||
| 
 | ||||
| BOOST_AUTO_TEST_CASE(inter_contract_calls_with_complex_parameters) | ||||
| { | ||||
| 	char const* sourceCode = R"( | ||||
| 		contract Helper { | ||||
| 			function sel(uint a, bool select, uint b) returns (uint c) { | ||||
| 				if (select) return a; else return b; | ||||
| 			} | ||||
| 		} | ||||
| 		contract Main { | ||||
| 			Helper h; | ||||
| 			function callHelper(uint a, bool select, uint b) returns (uint c) { | ||||
| 				return h.sel(a, select, b) * 3; | ||||
| 			} | ||||
| 			function getHelper() returns (address haddress) { | ||||
| 				return address(h); | ||||
| 			} | ||||
| 			function setHelper(address haddress) { | ||||
| 				h = Helper(haddress); | ||||
| 			} | ||||
| 		})"; | ||||
| 	compileAndRun(sourceCode, 0, "Helper"); | ||||
| 	u160 const helperAddress = m_contractAddress; | ||||
| 	compileAndRun(sourceCode, 0, "Main"); | ||||
| 	BOOST_REQUIRE(callContractFunction(2, helperAddress) == bytes()); | ||||
| 	BOOST_REQUIRE(callContractFunction(1, helperAddress) == toBigEndian(helperAddress)); | ||||
| 	u256 a(3456789); | ||||
| 	u256 b("0x282837623374623234aa74"); | ||||
| 	BOOST_REQUIRE(callContractFunction(0, a, true, b) == toBigEndian(a * 3)); | ||||
| 	BOOST_REQUIRE(callContractFunction(0, a, false, b) == toBigEndian(b * 3)); | ||||
| } | ||||
| 
 | ||||
| BOOST_AUTO_TEST_CASE(inter_contract_calls_accessing_this) | ||||
| { | ||||
| 	char const* sourceCode = R"( | ||||
| 		contract Helper { | ||||
| 			function getAddress() returns (address addr) { | ||||
| 				return address(this); | ||||
| 			} | ||||
| 		} | ||||
| 		contract Main { | ||||
| 			Helper h; | ||||
| 			function callHelper() returns (address addr) { | ||||
| 				return h.getAddress(); | ||||
| 			} | ||||
| 			function getHelper() returns (address addr) { | ||||
| 				return address(h); | ||||
| 			} | ||||
| 			function setHelper(address addr) { | ||||
| 				h = Helper(addr); | ||||
| 			} | ||||
| 		})"; | ||||
| 	compileAndRun(sourceCode, 0, "Helper"); | ||||
| 	u160 const helperAddress = m_contractAddress; | ||||
| 	compileAndRun(sourceCode, 0, "Main"); | ||||
| 	BOOST_REQUIRE(callContractFunction(2, helperAddress) == bytes()); | ||||
| 	BOOST_REQUIRE(callContractFunction(1, helperAddress) == toBigEndian(helperAddress)); | ||||
| 	BOOST_REQUIRE(callContractFunction(0) == toBigEndian(helperAddress)); | ||||
| } | ||||
| 
 | ||||
| BOOST_AUTO_TEST_CASE(calls_to_this) | ||||
| { | ||||
| 	char const* sourceCode = R"( | ||||
| 		contract Helper { | ||||
| 			function invoke(uint a, uint b) returns (uint c) { | ||||
| 				return this.multiply(a, b, 10); | ||||
| 			} | ||||
| 			function multiply(uint a, uint b, uint8 c) returns (uint ret) { | ||||
| 				return a * b + c; | ||||
| 			} | ||||
| 		} | ||||
| 		contract Main { | ||||
| 			Helper h; | ||||
| 			function callHelper(uint a, uint b) returns (uint ret) { | ||||
| 				return h.invoke(a, b); | ||||
| 			} | ||||
| 			function getHelper() returns (address addr) { | ||||
| 				return address(h); | ||||
| 			} | ||||
| 			function setHelper(address addr) { | ||||
| 				h = Helper(addr); | ||||
| 			} | ||||
| 		})"; | ||||
| 	compileAndRun(sourceCode, 0, "Helper"); | ||||
| 	u160 const helperAddress = m_contractAddress; | ||||
| 	compileAndRun(sourceCode, 0, "Main"); | ||||
| 	BOOST_REQUIRE(callContractFunction(2, helperAddress) == bytes()); | ||||
| 	BOOST_REQUIRE(callContractFunction(1, helperAddress) == toBigEndian(helperAddress)); | ||||
| 	u256 a(3456789); | ||||
| 	u256 b("0x282837623374623234aa74"); | ||||
| 	BOOST_REQUIRE(callContractFunction(0, a, b) == toBigEndian(a * b + 10)); | ||||
| } | ||||
| 
 | ||||
| BOOST_AUTO_TEST_CASE(inter_contract_calls_with_local_vars) | ||||
| { | ||||
| 	// note that a reference to another contract's function occupies two stack slots,
 | ||||
| 	// so this tests correct stack slot allocation
 | ||||
| 	char const* sourceCode = R"( | ||||
| 		contract Helper { | ||||
| 			function multiply(uint a, uint b) returns (uint c) { | ||||
| 				return a * b; | ||||
| 			} | ||||
| 		} | ||||
| 		contract Main { | ||||
| 			Helper h; | ||||
| 			function callHelper(uint a, uint b) returns (uint c) { | ||||
| 				var fu = h.multiply; | ||||
| 				var y = 9; | ||||
| 				var ret = fu(a, b); | ||||
| 				return ret + y; | ||||
| 			} | ||||
| 			function getHelper() returns (address haddress) { | ||||
| 				return address(h); | ||||
| 			} | ||||
| 			function setHelper(address haddress) { | ||||
| 				h = Helper(haddress); | ||||
| 			} | ||||
| 		})"; | ||||
| 	compileAndRun(sourceCode, 0, "Helper"); | ||||
| 	u160 const helperAddress = m_contractAddress; | ||||
| 	compileAndRun(sourceCode, 0, "Main"); | ||||
| 	BOOST_REQUIRE(callContractFunction(2, helperAddress) == bytes()); | ||||
| 	BOOST_REQUIRE(callContractFunction(1, helperAddress) == toBigEndian(helperAddress)); | ||||
| 	u256 a(3456789); | ||||
| 	u256 b("0x282837623374623234aa74"); | ||||
| 	BOOST_REQUIRE(callContractFunction(0, a, b) == toBigEndian(a * b + 9)); | ||||
| } | ||||
| 
 | ||||
| BOOST_AUTO_TEST_SUITE_END() | ||||
| 
 | ||||
| } | ||||
|  | ||||
| @ -86,27 +86,34 @@ bytes compileFirstExpression(const string& _sourceCode, vector<vector<string>> _ | ||||
| 							 vector<vector<string>> _localVariables = {}) | ||||
| { | ||||
| 	Parser parser; | ||||
| 	ASTPointer<ContractDefinition> contract; | ||||
| 	BOOST_REQUIRE_NO_THROW(contract = parser.parse(make_shared<Scanner>(CharStream(_sourceCode)))); | ||||
| 	ASTPointer<SourceUnit> sourceUnit; | ||||
| 	BOOST_REQUIRE_NO_THROW(sourceUnit = parser.parse(make_shared<Scanner>(CharStream(_sourceCode)))); | ||||
| 	NameAndTypeResolver resolver({}); | ||||
| 	BOOST_REQUIRE_NO_THROW(resolver.resolveNamesAndTypes(*contract)); | ||||
| 	FirstExpressionExtractor extractor(*contract); | ||||
| 	BOOST_REQUIRE(extractor.getExpression() != nullptr); | ||||
| 	resolver.registerDeclarations(*sourceUnit); | ||||
| 	for (ASTPointer<ASTNode> const& node: sourceUnit->getNodes()) | ||||
| 		if (ContractDefinition* contract = dynamic_cast<ContractDefinition*>(node.get())) | ||||
| 		{ | ||||
| 			BOOST_REQUIRE_NO_THROW(resolver.resolveNamesAndTypes(*contract)); | ||||
| 			FirstExpressionExtractor extractor(*contract); | ||||
| 			BOOST_REQUIRE(extractor.getExpression() != nullptr); | ||||
| 
 | ||||
| 	CompilerContext context; | ||||
| 	for (vector<string> const& function: _functions) | ||||
| 		context.addFunction(dynamic_cast<FunctionDefinition const&>(resolveDeclaration(function, resolver))); | ||||
| 	for (vector<string> const& variable: _localVariables) | ||||
| 		context.addVariable(dynamic_cast<VariableDeclaration const&>(resolveDeclaration(variable, resolver))); | ||||
| 			CompilerContext context; | ||||
| 			for (vector<string> const& function: _functions) | ||||
| 				context.addFunction(dynamic_cast<FunctionDefinition const&>(resolveDeclaration(function, resolver))); | ||||
| 			for (vector<string> const& variable: _localVariables) | ||||
| 				context.addVariable(dynamic_cast<VariableDeclaration const&>(resolveDeclaration(variable, resolver))); | ||||
| 
 | ||||
| 	ExpressionCompiler::compileExpression(context, *extractor.getExpression()); | ||||
| 			ExpressionCompiler::compileExpression(context, *extractor.getExpression()); | ||||
| 
 | ||||
| 	for (vector<string> const& function: _functions) | ||||
| 		context << context.getFunctionEntryLabel(dynamic_cast<FunctionDefinition const&>(resolveDeclaration(function, resolver))); | ||||
| 	bytes instructions = context.getAssembledBytecode(); | ||||
| 	// debug
 | ||||
| 	// cout << eth::disassemble(instructions) << endl;
 | ||||
| 	return instructions; | ||||
| 			for (vector<string> const& function: _functions) | ||||
| 				context << context.getFunctionEntryLabel(dynamic_cast<FunctionDefinition const&>(resolveDeclaration(function, resolver))); | ||||
| 			bytes instructions = context.getAssembledBytecode(); | ||||
| 			// debug
 | ||||
| 			// cout << eth::disassemble(instructions) << endl;
 | ||||
| 			return instructions; | ||||
| 		} | ||||
| 	BOOST_FAIL("No contract found in source."); | ||||
| 	return bytes(); | ||||
| } | ||||
| 
 | ||||
| } // end anonymous namespace
 | ||||
|  | ||||
| @ -50,7 +50,7 @@ public: | ||||
| 				msg += *extra; | ||||
| 			BOOST_FAIL(msg); | ||||
| 		} | ||||
| 		std::string generatedInterfaceString = m_compilerStack.getJsonDocumentation(ABI_INTERFACE); | ||||
| 		std::string generatedInterfaceString = m_compilerStack.getJsonDocumentation("", DocumentationType::ABI_INTERFACE); | ||||
| 		Json::Value generatedInterface; | ||||
| 		m_reader.parse(generatedInterfaceString, generatedInterface); | ||||
| 		Json::Value expectedInterface; | ||||
|  | ||||
| @ -41,10 +41,12 @@ namespace | ||||
| void parseTextAndResolveNames(std::string const& _source) | ||||
| { | ||||
| 	Parser parser; | ||||
| 	ASTPointer<ContractDefinition> contract = parser.parse( | ||||
| 										   std::make_shared<Scanner>(CharStream(_source))); | ||||
| 	ASTPointer<SourceUnit> sourceUnit = parser.parse(std::make_shared<Scanner>(CharStream(_source))); | ||||
| 	NameAndTypeResolver resolver({}); | ||||
| 	resolver.resolveNamesAndTypes(*contract); | ||||
| 	resolver.registerDeclarations(*sourceUnit); | ||||
| 	for (ASTPointer<ASTNode> const& node: sourceUnit->getNodes()) | ||||
| 		if (ContractDefinition* contract = dynamic_cast<ContractDefinition*>(node.get())) | ||||
| 			resolver.resolveNamesAndTypes(*contract); | ||||
| } | ||||
| } | ||||
| 
 | ||||
|  | ||||
| @ -55,9 +55,9 @@ public: | ||||
| 		} | ||||
| 
 | ||||
| 		if (_userDocumentation) | ||||
| 			generatedDocumentationString = m_compilerStack.getJsonDocumentation(NATSPEC_USER); | ||||
| 			generatedDocumentationString = m_compilerStack.getJsonDocumentation("", DocumentationType::NATSPEC_USER); | ||||
| 		else | ||||
| 			generatedDocumentationString = m_compilerStack.getJsonDocumentation(NATSPEC_DEV); | ||||
| 			generatedDocumentationString = m_compilerStack.getJsonDocumentation("", DocumentationType::NATSPEC_DEV); | ||||
| 		Json::Value generatedDocumentation; | ||||
| 		m_reader.parse(generatedDocumentationString, generatedDocumentation); | ||||
| 		Json::Value expectedDocumentation; | ||||
|  | ||||
| @ -21,13 +21,15 @@ | ||||
|  */ | ||||
| 
 | ||||
| #include <string> | ||||
| 
 | ||||
| #include <memory> | ||||
| #include <libdevcore/Log.h> | ||||
| #include <libsolidity/Scanner.h> | ||||
| #include <libsolidity/Parser.h> | ||||
| #include <libsolidity/Exceptions.h> | ||||
| #include <boost/test/unit_test.hpp> | ||||
| 
 | ||||
| using namespace std; | ||||
| 
 | ||||
| namespace dev | ||||
| { | ||||
| namespace solidity | ||||
| @ -40,7 +42,12 @@ namespace | ||||
| ASTPointer<ContractDefinition> parseText(std::string const& _source) | ||||
| { | ||||
| 	Parser parser; | ||||
| 	return parser.parse(std::make_shared<Scanner>(CharStream(_source))); | ||||
| 	ASTPointer<SourceUnit> sourceUnit = parser.parse(std::make_shared<Scanner>(CharStream(_source))); | ||||
| 	for (ASTPointer<ASTNode> const& node: sourceUnit->getNodes()) | ||||
| 		if (ASTPointer<ContractDefinition> contract = dynamic_pointer_cast<ContractDefinition>(node)) | ||||
| 			return contract; | ||||
| 	BOOST_FAIL("No contract found in source."); | ||||
| 	return ASTPointer<ContractDefinition>(); | ||||
| } | ||||
| } | ||||
| 
 | ||||
| @ -380,6 +387,50 @@ BOOST_AUTO_TEST_CASE(statement_starting_with_type_conversion) | ||||
| 	BOOST_CHECK_NO_THROW(parseText(text)); | ||||
| } | ||||
| 
 | ||||
| BOOST_AUTO_TEST_CASE(import_directive) | ||||
| { | ||||
| 	char const* text = "import \"abc\";\n" | ||||
| 					   "contract test {\n" | ||||
| 					   "  function fun() {\n" | ||||
| 					   "    uint64(2);\n" | ||||
| 					   "  }\n" | ||||
| 					   "}\n"; | ||||
| 	BOOST_CHECK_NO_THROW(parseText(text)); | ||||
| } | ||||
| 
 | ||||
| BOOST_AUTO_TEST_CASE(multiple_contracts) | ||||
| { | ||||
| 	char const* text = "contract test {\n" | ||||
| 					   "  function fun() {\n" | ||||
| 					   "    uint64(2);\n" | ||||
| 					   "  }\n" | ||||
| 					   "}\n" | ||||
| 					   "contract test2 {\n" | ||||
| 					   "  function fun() {\n" | ||||
| 					   "    uint64(2);\n" | ||||
| 					   "  }\n" | ||||
| 					   "}\n"; | ||||
| 	BOOST_CHECK_NO_THROW(parseText(text)); | ||||
| } | ||||
| 
 | ||||
| BOOST_AUTO_TEST_CASE(multiple_contracts_and_imports) | ||||
| { | ||||
| 	char const* text = "import \"abc\";\n" | ||||
| 					   "contract test {\n" | ||||
| 					   "  function fun() {\n" | ||||
| 					   "    uint64(2);\n" | ||||
| 					   "  }\n" | ||||
| 					   "}\n" | ||||
| 					   "import \"def\";\n" | ||||
| 					   "contract test2 {\n" | ||||
| 					   "  function fun() {\n" | ||||
| 					   "    uint64(2);\n" | ||||
| 					   "  }\n" | ||||
| 					   "}\n" | ||||
| 					   "import \"ghi\";\n"; | ||||
| 	BOOST_CHECK_NO_THROW(parseText(text)); | ||||
| } | ||||
| 
 | ||||
| BOOST_AUTO_TEST_SUITE_END() | ||||
| 
 | ||||
| } | ||||
|  | ||||
							
								
								
									
										1851
									
								
								stLogTestsFiller.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1851
									
								
								stLogTestsFiller.json
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @ -33,6 +33,41 @@ | ||||
|         } | ||||
|      }, | ||||
| 
 | ||||
|     "CallEcrecover0_overlappingInputOutput": { | ||||
|          "env" : { | ||||
|              "previousHash" : "5e20a0453cecd065ea59c37ac63e079ee08998b6045136a8ce6635c7912ec0b6", | ||||
|              "currentNumber" : "0", | ||||
|              "currentGasLimit" : "10000000", | ||||
|              "currentDifficulty" : "256", | ||||
|              "currentTimestamp" : 1, | ||||
|              "currentCoinbase" : "2adc25665018aa1fe0e6bc666dac8fc2697ff9ba" | ||||
|          }, | ||||
|          "pre" : { | ||||
|              "095e7baea6a6c7c4c2dfeb977efac326af552d87" : { | ||||
|                  "balance" : "20000000", | ||||
|                  "nonce" : 0, | ||||
|                  "code": "{ (MSTORE 0 0x18c547e4f7b0f325ad1e56f57e26c745b09a3e503d86e00e5255ff7f715d3d1c) (MSTORE 32 28) (MSTORE 64 0x73b1693892219d736caba55bdb67216e485557ea6b6af75f37096c9aa6a5a75f) (MSTORE 96 0xeeb940b1d03b21e36b0e47e79769f095fe2ab855bd91e3a38756b7d75a9c4549) [[ 2 ]] (CALL 1000 1 0 0 128 64 32) [[ 0 ]] (MOD (MLOAD 64) (EXP 2 160)) [[ 1 ]] (EQ (ORIGIN) (SLOAD 0))  }", | ||||
|                  "storage": {} | ||||
|              }, | ||||
|             "a94f5374fce5edbc8e2a8697c15331677e6ebf0b" : { | ||||
|                 "balance" : "1000000000000000000", | ||||
|                 "nonce" : 0, | ||||
|                 "code" : "", | ||||
|                 "storage": {} | ||||
|             } | ||||
|         }, | ||||
|         "transaction" : { | ||||
|             "nonce" : "0", | ||||
|             "gasPrice" : "1", | ||||
|             "gasLimit" : "365224", | ||||
|             "to" : "095e7baea6a6c7c4c2dfeb977efac326af552d87", | ||||
|             "value" : "100000", | ||||
|             "secretKey" : "45a915e4d060149eb4365960e6a7a45f334393093061116b197e3240065ff2d8", | ||||
|             "data" : "" | ||||
|         } | ||||
|      }, | ||||
| 
 | ||||
| 
 | ||||
|     "CallEcrecover0_completeReturnValue": { | ||||
|          "env" : { | ||||
|              "previousHash" : "5e20a0453cecd065ea59c37ac63e079ee08998b6045136a8ce6635c7912ec0b6", | ||||
|  | ||||
| @ -634,6 +634,86 @@ | ||||
|         } | ||||
|      }, | ||||
| 
 | ||||
|     "CallRecursiveBombLog": { | ||||
|          "env" : { | ||||
|              "previousHash" : "5e20a0453cecd065ea59c37ac63e079ee08998b6045136a8ce6635c7912ec0b6", | ||||
|              "currentNumber" : "0", | ||||
|              "currentGasLimit" : "10000000", | ||||
|              "currentDifficulty" : "256", | ||||
|              "currentTimestamp" : 1, | ||||
|              "currentCoinbase" : "2adc25665018aa1fe0e6bc666dac8fc2697ff9ba" | ||||
|          }, | ||||
|          "pre" : { | ||||
|              "095e7baea6a6c7c4c2dfeb977efac326af552d87" : { | ||||
|                  "balance" : "20000000", | ||||
|                  "nonce" : 0, | ||||
|                  "code" : "{  (CALL 100000 0x945304eb96065b2a98b57a48a06ae28d285a71b5 23 0 0 0 0)  }", | ||||
|                  "storage": {} | ||||
|              }, | ||||
|              "945304eb96065b2a98b57a48a06ae28d285a71b5" : { | ||||
|                  "balance" : "1000000000000000000", | ||||
|                  "nonce" : 0, | ||||
|                  "code" : "{ (MSTORE 0 0xffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff) (LOG0 0 32) [[ 0 ]] (+ (SLOAD 0) 1) [[ 1 ]] (CALL (- (GAS) 224) (ADDRESS) 0 0 0 0 0) } ", | ||||
|                  "storage": {} | ||||
|              }, | ||||
|             "a94f5374fce5edbc8e2a8697c15331677e6ebf0b" : { | ||||
|                 "balance" : "1000000000000000000", | ||||
|                 "nonce" : 0, | ||||
|                 "code" : "", | ||||
|                 "storage": {} | ||||
|             } | ||||
|         }, | ||||
|         "transaction" : { | ||||
|             "nonce" : "0", | ||||
|             "gasPrice" : "1", | ||||
|             "gasLimit" : "1000000", | ||||
|             "to" : "095e7baea6a6c7c4c2dfeb977efac326af552d87", | ||||
|             "value" : "100000", | ||||
|             "secretKey" : "45a915e4d060149eb4365960e6a7a45f334393093061116b197e3240065ff2d8", | ||||
|             "data" : "" | ||||
|         } | ||||
|      }, | ||||
| 
 | ||||
|     "CallRecursiveBombLog2": { | ||||
|          "env" : { | ||||
|              "previousHash" : "5e20a0453cecd065ea59c37ac63e079ee08998b6045136a8ce6635c7912ec0b6", | ||||
|              "currentNumber" : "0", | ||||
|              "currentGasLimit" : "10000000", | ||||
|              "currentDifficulty" : "256", | ||||
|              "currentTimestamp" : 1, | ||||
|              "currentCoinbase" : "2adc25665018aa1fe0e6bc666dac8fc2697ff9ba" | ||||
|          }, | ||||
|          "pre" : { | ||||
|              "095e7baea6a6c7c4c2dfeb977efac326af552d87" : { | ||||
|                  "balance" : "20000000", | ||||
|                  "nonce" : 0, | ||||
|                  "code" : "{  (CALL 100000 0x945304eb96065b2a98b57a48a06ae28d285a71b5 23 0 0 0 0)  }", | ||||
|                  "storage": {} | ||||
|              }, | ||||
|              "945304eb96065b2a98b57a48a06ae28d285a71b5" : { | ||||
|                  "balance" : "1000000000000000000", | ||||
|                  "nonce" : 0, | ||||
|                  "code" : "{ (MSTORE 0 (GAS)) (LOG0 0 32) [[ 0 ]] (+ (SLOAD 0) 1) [[ 1 ]] (CALL (- (GAS) 224) (ADDRESS) 0 0 0 0 0) } ", | ||||
|                  "storage": {} | ||||
|              }, | ||||
|             "a94f5374fce5edbc8e2a8697c15331677e6ebf0b" : { | ||||
|                 "balance" : "1000000000000000000", | ||||
|                 "nonce" : 0, | ||||
|                 "code" : "", | ||||
|                 "storage": {} | ||||
|             } | ||||
|         }, | ||||
|         "transaction" : { | ||||
|             "nonce" : "0", | ||||
|             "gasPrice" : "1", | ||||
|             "gasLimit" : "1000000", | ||||
|             "to" : "095e7baea6a6c7c4c2dfeb977efac326af552d87", | ||||
|             "value" : "100000", | ||||
|             "secretKey" : "45a915e4d060149eb4365960e6a7a45f334393093061116b197e3240065ff2d8", | ||||
|             "data" : "" | ||||
|         } | ||||
|      }, | ||||
| 
 | ||||
|     "CallRecursiveBomb1": { | ||||
|          "env" : { | ||||
|              "previousHash" : "5e20a0453cecd065ea59c37ac63e079ee08998b6045136a8ce6635c7912ec0b6", | ||||
|  | ||||
| @ -125,6 +125,11 @@ BOOST_AUTO_TEST_CASE(stPreCompiledContracts) | ||||
| 	dev::test::executeTests("stPreCompiledContracts", "/StateTests", dev::test::doStateTests); | ||||
| } | ||||
| 
 | ||||
| BOOST_AUTO_TEST_CASE(stLogTests) | ||||
| { | ||||
| 	dev::test::executeTests("stLogTests", "/StateTests", dev::test::doStateTests); | ||||
| } | ||||
| 
 | ||||
| BOOST_AUTO_TEST_CASE(stSpecialTest) | ||||
| { | ||||
| 	dev::test::executeTests("stSpecialTest", "/StateTests", dev::test::doStateTests); | ||||
|  | ||||
							
								
								
									
										86
									
								
								vm.cpp
									
									
									
									
									
								
							
							
						
						
									
										86
									
								
								vm.cpp
									
									
									
									
									
								
							| @ -22,8 +22,10 @@ | ||||
| 
 | ||||
| #include <chrono> | ||||
| #include <boost/filesystem.hpp> | ||||
| #include <libethereum/VMFactory.h> | ||||
| #include <libethereum/Executive.h> | ||||
| #include <libevm/VMFactory.h> | ||||
| #include "vm.h" | ||||
| 
 | ||||
| using namespace std; | ||||
| using namespace json_spirit; | ||||
| using namespace dev; | ||||
| @ -121,41 +123,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; | ||||
| @ -320,14 +287,16 @@ void doVMTests(json_spirit::mValue& v, bool _fillin) | ||||
| 
 | ||||
| 		auto argc = boost::unit_test::framework::master_test_suite().argc; | ||||
| 		auto argv = boost::unit_test::framework::master_test_suite().argv; | ||||
| 		auto useJit = false; | ||||
| 		for (auto i =  0; i < argc && !useJit; ++i) | ||||
| 			useJit |= std::string(argv[i]) == "--jit"; | ||||
| #if ETH_EVMJIT | ||||
| 		auto vmKind = useJit ? VMFactory::JIT : VMFactory::Interpreter; | ||||
| #else | ||||
| 		auto vmKind == VMFactory::Interpreter; | ||||
| #endif | ||||
| 
 | ||||
| 		for (auto i =  0; i < argc; ++i) | ||||
| 		{ | ||||
| 			if (std::string(argv[i]) == "--jit") | ||||
| 			{ | ||||
| 				VMFactory::setKind(VMKind::JIT); | ||||
| 				break; | ||||
| 			} | ||||
| 		} | ||||
| 
 | ||||
| 		dev::test::FakeExtVM fev; | ||||
| 
 | ||||
| 		fev.importEnv(o["env"].get_obj()); | ||||
| @ -343,14 +312,13 @@ void doVMTests(json_spirit::mValue& v, bool _fillin) | ||||
| 			fev.code = fev.thisTxCode; | ||||
| 		} | ||||
| 
 | ||||
| 		auto vm = VMFactory::create(vmKind, fev.gas); | ||||
| 		bytes output; | ||||
| 
 | ||||
| 		auto startTime = std::chrono::high_resolution_clock::now(); | ||||
| 		u256 gas; | ||||
| 		bool vmExceptionOccured = false; | ||||
| 		auto startTime = std::chrono::high_resolution_clock::now(); | ||||
| 		try | ||||
| 		{ | ||||
| 			auto vm = eth::VMFactory::create(fev.gas); | ||||
| 			output = vm->go(fev, fev.simpleTrace()).toBytes(); | ||||
| 			gas = vm->gas(); | ||||
| 		} | ||||
| @ -410,7 +378,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 | ||||
| @ -428,7 +396,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); | ||||
| 
 | ||||
| @ -514,6 +482,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(); | ||||
|  | ||||
							
								
								
									
										2
									
								
								vm.h
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								vm.h
									
									
									
									
									
								
							| @ -72,8 +72,6 @@ public: | ||||
| 	void importExec(json_spirit::mObject& _o); | ||||
| 	json_spirit::mArray exportCallCreates(); | ||||
| 	void importCallCreates(json_spirit::mArray& _callcreates); | ||||
| 	json_spirit::mObject exportLog(); | ||||
| 	void importLog(json_spirit::mObject& _o); | ||||
| 
 | ||||
| 	eth::OnOpFunc simpleTrace(); | ||||
| 
 | ||||
|  | ||||
| @ -338,6 +338,33 @@ | ||||
|         } | ||||
|     }, | ||||
| 
 | ||||
|     "calldataloadSizeTooHigh": { | ||||
|         "env" : { | ||||
|             "previousHash" : "5e20a0453cecd065ea59c37ac63e079ee08998b6045136a8ce6635c7912ec0b6", | ||||
|             "currentNumber" : "0", | ||||
|             "currentGasLimit" : "1000000", | ||||
|             "currentDifficulty" : "256", | ||||
|             "currentTimestamp" : 1, | ||||
|             "currentCoinbase" : "2adc25665018aa1fe0e6bc666dac8fc2697ff9ba" | ||||
|         }, | ||||
|         "pre" : { | ||||
|             "0f572e5295c57f15886f9b263e2f6d2d6c7b5ec6" : { | ||||
|                 "balance" : "1000000000000000000", | ||||
|                 "nonce" : 0, | ||||
|                 "code" : "{ [[ 0 ]] (CALLDATALOAD 0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffa)}", | ||||
|                 "storage": {} | ||||
|             } | ||||
|         }, | ||||
|         "exec" : { | ||||
|             "address" : "0f572e5295c57f15886f9b263e2f6d2d6c7b5ec6", | ||||
|             "origin" : "cd1722f3947def4cf144679da39c4c32bdc35681", | ||||
|             "caller" : "cd1722f3947def4cf144679da39c4c32bdc35681", | ||||
|             "value" : "1000000000000000000", | ||||
|             "data" : "0x123456789abcdef0000000000000000000000000000000000000000000000000024", | ||||
|             "gasPrice" : "1000000000", | ||||
|             "gas" : "100000000000" | ||||
|         } | ||||
|     }, | ||||
| 
 | ||||
|     "calldatasize0": { | ||||
|         "env" : { | ||||
| @ -451,6 +478,62 @@ | ||||
|         } | ||||
|     }, | ||||
| 
 | ||||
|     "calldatacopy_DataIndexTooHigh": { | ||||
|         "env" : { | ||||
|             "previousHash" : "5e20a0453cecd065ea59c37ac63e079ee08998b6045136a8ce6635c7912ec0b6", | ||||
|             "currentNumber" : "0", | ||||
|             "currentGasLimit" : "1000000", | ||||
|             "currentDifficulty" : "256", | ||||
|             "currentTimestamp" : 1, | ||||
|             "currentCoinbase" : "2adc25665018aa1fe0e6bc666dac8fc2697ff9ba" | ||||
|         }, | ||||
|         "pre" : { | ||||
|             "0f572e5295c57f15886f9b263e2f6d2d6c7b5ec6" : { | ||||
|                 "balance" : "1000000000000000000", | ||||
|                 "nonce" : 0, | ||||
|                 "code" : "{ (CALLDATACOPY 0 0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffa 0xff ) [[ 0 ]] @0}", | ||||
|                 "storage": {} | ||||
|             } | ||||
|         }, | ||||
|         "exec" : { | ||||
|             "address" : "0f572e5295c57f15886f9b263e2f6d2d6c7b5ec6", | ||||
|             "origin" : "cd1722f3947def4cf144679da39c4c32bdc35681", | ||||
|             "caller" : "cd1722f3947def4cf144679da39c4c32bdc35681", | ||||
|             "value" : "1000000000000000000", | ||||
|             "data" : "0x1234567890abcdef01234567890abcdef", | ||||
|             "gasPrice" : "1000000000", | ||||
|             "gas" : "100000000000" | ||||
|         } | ||||
|     }, | ||||
| 
 | ||||
|     "calldatacopy_DataIndexTooHigh2": { | ||||
|         "env" : { | ||||
|             "previousHash" : "5e20a0453cecd065ea59c37ac63e079ee08998b6045136a8ce6635c7912ec0b6", | ||||
|             "currentNumber" : "0", | ||||
|             "currentGasLimit" : "1000000", | ||||
|             "currentDifficulty" : "256", | ||||
|             "currentTimestamp" : 1, | ||||
|             "currentCoinbase" : "2adc25665018aa1fe0e6bc666dac8fc2697ff9ba" | ||||
|         }, | ||||
|         "pre" : { | ||||
|             "0f572e5295c57f15886f9b263e2f6d2d6c7b5ec6" : { | ||||
|                 "balance" : "1000000000000000000", | ||||
|                 "nonce" : 0, | ||||
|                 "code" : "{ (CALLDATACOPY 0 0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffa 9 ) [[ 0 ]] @0}", | ||||
|                 "storage": {} | ||||
|             } | ||||
|         }, | ||||
|         "exec" : { | ||||
|             "address" : "0f572e5295c57f15886f9b263e2f6d2d6c7b5ec6", | ||||
|             "origin" : "cd1722f3947def4cf144679da39c4c32bdc35681", | ||||
|             "caller" : "cd1722f3947def4cf144679da39c4c32bdc35681", | ||||
|             "value" : "1000000000000000000", | ||||
|             "data" : "0x1234567890abcdef01234567890abcdef", | ||||
|             "gasPrice" : "1000000000", | ||||
|             "gas" : "100000000000" | ||||
|         } | ||||
|     }, | ||||
| 
 | ||||
|     "calldatacopy1": { | ||||
|         "env" : { | ||||
|             "previousHash" : "5e20a0453cecd065ea59c37ac63e079ee08998b6045136a8ce6635c7912ec0b6", | ||||
| @ -535,6 +618,34 @@ | ||||
|         } | ||||
|     }, | ||||
| 
 | ||||
|     "codecopy_DataIndexTooHigh": { | ||||
|         "env" : { | ||||
|             "previousHash" : "5e20a0453cecd065ea59c37ac63e079ee08998b6045136a8ce6635c7912ec0b6", | ||||
|             "currentNumber" : "0", | ||||
|             "currentGasLimit" : "1000000", | ||||
|             "currentDifficulty" : "256", | ||||
|             "currentTimestamp" : 1, | ||||
|             "currentCoinbase" : "2adc25665018aa1fe0e6bc666dac8fc2697ff9ba" | ||||
|         }, | ||||
|         "pre" : { | ||||
|             "0f572e5295c57f15886f9b263e2f6d2d6c7b5ec6" : { | ||||
|                 "balance" : "1000000000000000000", | ||||
|                 "nonce" : 0, | ||||
|                 "code" : "{ (CODECOPY 0 0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffa 8 ) [[ 0 ]] @0}", | ||||
|                 "storage": {} | ||||
|             } | ||||
|         }, | ||||
|         "exec" : { | ||||
|             "address" : "0f572e5295c57f15886f9b263e2f6d2d6c7b5ec6", | ||||
|             "origin" : "cd1722f3947def4cf144679da39c4c32bdc35681", | ||||
|             "caller" : "cd1722f3947def4cf144679da39c4c32bdc35681", | ||||
|             "value" : "1000000000000000000", | ||||
|             "data" : "0x1234567890abcdef01234567890abcdef", | ||||
|             "gasPrice" : "1000000000", | ||||
|             "gas" : "100000000000" | ||||
|         } | ||||
|     }, | ||||
| 
 | ||||
|     "codecopy0": { | ||||
|         "env" : { | ||||
|             "previousHash" : "5e20a0453cecd065ea59c37ac63e079ee08998b6045136a8ce6635c7912ec0b6", | ||||
| @ -686,6 +797,35 @@ | ||||
|         } | ||||
|     }, | ||||
| 
 | ||||
|     "extcodecopy_DataIndexTooHigh": { | ||||
|         "env" : { | ||||
|             "previousHash" : "5e20a0453cecd065ea59c37ac63e079ee08998b6045136a8ce6635c7912ec0b6", | ||||
|             "currentNumber" : "0", | ||||
|             "currentGasLimit" : "1000000", | ||||
|             "currentDifficulty" : "256", | ||||
|             "currentTimestamp" : 1, | ||||
|             "currentCoinbase" : "2adc25665018aa1fe0e6bc666dac8fc2697ff9ba" | ||||
|         }, | ||||
|         "pre" : { | ||||
|             "0f572e5295c57f15886f9b263e2f6d2d6c7b5ec6" : { | ||||
|                 "balance" : "1000000000000000000", | ||||
|                 "nonce" : 0, | ||||
|                 "code" : "{ (EXTCODECOPY (ADDRESS) 0 0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffa 8 ) [[ 0 ]] @0}", | ||||
|                 "storage": {} | ||||
|             } | ||||
|         }, | ||||
|         "exec" : { | ||||
|             "address" : "0f572e5295c57f15886f9b263e2f6d2d6c7b5ec6", | ||||
|             "origin" : "cd1722f3947def4cf144679da39c4c32bdc35681", | ||||
|             "caller" : "cd1722f3947def4cf144679da39c4c32bdc35681", | ||||
|             "value" : "1000000000000000000", | ||||
|             "data" : "0x1234567890abcdef01234567890abcdef", | ||||
|             "gasPrice" : "1000000000", | ||||
|             "gas" : "100000000000" | ||||
|         } | ||||
|     }, | ||||
| 
 | ||||
| 
 | ||||
|     "extcodecopy0": { | ||||
|         "env" : { | ||||
|             "previousHash" : "5e20a0453cecd065ea59c37ac63e079ee08998b6045136a8ce6635c7912ec0b6", | ||||
|  | ||||
| @ -55,6 +55,34 @@ | ||||
|         } | ||||
|     }, | ||||
| 
 | ||||
|     "log_2logs": { | ||||
|         "env" : { | ||||
|         "previousHash" : "5e20a0453cecd065ea59c37ac63e079ee08998b6045136a8ce6635c7912ec0b6", | ||||
|         "currentNumber" : "0", | ||||
|         "currentGasLimit" : "1000000", | ||||
|         "currentDifficulty" : "256", | ||||
|         "currentTimestamp" : 1, | ||||
|         "currentCoinbase" : "2adc25665018aa1fe0e6bc666dac8fc2697ff9ba" | ||||
|         }, | ||||
|         "pre" : { | ||||
|         "0f572e5295c57f15886f9b263e2f6d2d6c7b5ec6" : { | ||||
|             "balance" : "1000000000000000000", | ||||
|             "nonce" : 0, | ||||
|             "code" : "{ (MSTORE 0 0xffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff) (LOG0 0 32) (LOG0 2 16) }", | ||||
|             "storage": {} | ||||
|         } | ||||
|         }, | ||||
|         "exec" : { | ||||
|             "address" : "0f572e5295c57f15886f9b263e2f6d2d6c7b5ec6", | ||||
|             "origin" : "cd1722f3947def4cf144679da39c4c32bdc35681", | ||||
|             "caller" : "cd1722f3947def4cf144679da39c4c32bdc35681", | ||||
|             "value" : "1000000000000000000", | ||||
|             "data" : "", | ||||
|             "gasPrice" : "100000000000000", | ||||
|             "gas" : "10000" | ||||
|         } | ||||
|     }, | ||||
| 
 | ||||
|     "log0_nonEmptyMem_logMemSize1": { | ||||
|         "env" : { | ||||
|         "previousHash" : "5e20a0453cecd065ea59c37ac63e079ee08998b6045136a8ce6635c7912ec0b6", | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user