mirror of
https://github.com/ethereum/solidity
synced 2023-10-03 13:03:40 +00:00
Merge remote-tracking branch 'ethereum/develop' into sol_optimizer
Conflicts: libevmcore/Instruction.cpp
This commit is contained in:
commit
3fbe72cc47
@ -57,7 +57,6 @@ public:
|
|||||||
eth::State m_statePost;
|
eth::State m_statePost;
|
||||||
eth::ExtVMFace m_environment;
|
eth::ExtVMFace m_environment;
|
||||||
eth::Transaction m_transaction;
|
eth::Transaction m_transaction;
|
||||||
bytes code;
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
json_spirit::mObject& m_TestObject;
|
json_spirit::mObject& m_TestObject;
|
||||||
|
@ -134,10 +134,10 @@ void doMyTests(json_spirit::mValue& v)
|
|||||||
o["pre"] = mValue(fev.exportState());
|
o["pre"] = mValue(fev.exportState());
|
||||||
|
|
||||||
fev.importExec(o["exec"].get_obj());
|
fev.importExec(o["exec"].get_obj());
|
||||||
if (!fev.code)
|
if (fev.code.empty())
|
||||||
{
|
{
|
||||||
fev.thisTxCode = get<3>(fev.addresses.at(fev.myAddress));
|
fev.thisTxCode = get<3>(fev.addresses.at(fev.myAddress));
|
||||||
fev.code = &fev.thisTxCode;
|
fev.code = fev.thisTxCode;
|
||||||
}
|
}
|
||||||
|
|
||||||
vm.reset(fev.gas);
|
vm.reset(fev.gas);
|
||||||
|
@ -119,7 +119,7 @@ BOOST_AUTO_TEST_CASE(different_argument_numbers)
|
|||||||
byte(Instruction::JUMPDEST), // beginning of g
|
byte(Instruction::JUMPDEST), // beginning of g
|
||||||
byte(Instruction::PUSH1), 0x0,
|
byte(Instruction::PUSH1), 0x0,
|
||||||
byte(Instruction::DUP1), // initialized e and h
|
byte(Instruction::DUP1), // initialized e and h
|
||||||
byte(Instruction::PUSH1), 0x29 + shift, // ret address
|
byte(Instruction::PUSH1), byte(0x29 + shift), // ret address
|
||||||
byte(Instruction::PUSH1), 0x1, byte(Instruction::PUSH1), 0xff, byte(Instruction::AND),
|
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), 0x2, byte(Instruction::PUSH1), 0xff, byte(Instruction::AND),
|
||||||
byte(Instruction::PUSH1), 0x3, byte(Instruction::PUSH1), 0xff, byte(Instruction::AND),
|
byte(Instruction::PUSH1), 0x3, byte(Instruction::PUSH1), 0xff, byte(Instruction::AND),
|
||||||
|
@ -60,6 +60,16 @@ public:
|
|||||||
return callFunction(_index, toBigEndian(_argument1));
|
return callFunction(_index, toBigEndian(_argument1));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool testSolidityAgainstCpp(byte _index, std::function<u256(u256)> const& _cppfun, u256 const& _argument1)
|
||||||
|
{
|
||||||
|
return toBigEndian(_cppfun(_argument1)) == callFunction(_index, toBigEndian(_argument1));
|
||||||
|
}
|
||||||
|
|
||||||
|
bool testSolidityAgainstCpp(byte _index, std::function<u256()> const& _cppfun)
|
||||||
|
{
|
||||||
|
return toBigEndian(_cppfun()) == callFunction(_index, bytes());
|
||||||
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void sendMessage(bytes const& _data, bool _isCreation)
|
void sendMessage(bytes const& _data, bool _isCreation)
|
||||||
{
|
{
|
||||||
@ -123,11 +133,19 @@ BOOST_AUTO_TEST_CASE(recursive_calls)
|
|||||||
" }\n"
|
" }\n"
|
||||||
"}\n";
|
"}\n";
|
||||||
compileAndRun(sourceCode);
|
compileAndRun(sourceCode);
|
||||||
BOOST_CHECK(callFunction(0, u256(0)) == toBigEndian(u256(1)));
|
std::function<u256(u256)> recursive_calls_cpp = [&recursive_calls_cpp](u256 const& n) -> u256
|
||||||
BOOST_CHECK(callFunction(0, u256(1)) == toBigEndian(u256(1)));
|
{
|
||||||
BOOST_CHECK(callFunction(0, u256(2)) == toBigEndian(u256(2)));
|
if (n <= 1)
|
||||||
BOOST_CHECK(callFunction(0, u256(3)) == toBigEndian(u256(6)));
|
return 1;
|
||||||
BOOST_CHECK(callFunction(0, u256(4)) == toBigEndian(u256(24)));
|
else
|
||||||
|
return n * recursive_calls_cpp(n - 1);
|
||||||
|
};
|
||||||
|
|
||||||
|
BOOST_CHECK(testSolidityAgainstCpp(0, recursive_calls_cpp, u256(0)));
|
||||||
|
BOOST_CHECK(testSolidityAgainstCpp(0, recursive_calls_cpp, u256(1)));
|
||||||
|
BOOST_CHECK(testSolidityAgainstCpp(0, recursive_calls_cpp, u256(2)));
|
||||||
|
BOOST_CHECK(testSolidityAgainstCpp(0, recursive_calls_cpp, u256(3)));
|
||||||
|
BOOST_CHECK(testSolidityAgainstCpp(0, recursive_calls_cpp, u256(4)));
|
||||||
}
|
}
|
||||||
|
|
||||||
BOOST_AUTO_TEST_CASE(while_loop)
|
BOOST_AUTO_TEST_CASE(while_loop)
|
||||||
@ -140,11 +158,22 @@ BOOST_AUTO_TEST_CASE(while_loop)
|
|||||||
" }\n"
|
" }\n"
|
||||||
"}\n";
|
"}\n";
|
||||||
compileAndRun(sourceCode);
|
compileAndRun(sourceCode);
|
||||||
BOOST_CHECK(callFunction(0, u256(0)) == toBigEndian(u256(1)));
|
|
||||||
BOOST_CHECK(callFunction(0, u256(1)) == toBigEndian(u256(1)));
|
auto while_loop_cpp = [](u256 const& n) -> u256
|
||||||
BOOST_CHECK(callFunction(0, u256(2)) == toBigEndian(u256(2)));
|
{
|
||||||
BOOST_CHECK(callFunction(0, u256(3)) == toBigEndian(u256(6)));
|
u256 nfac = 1;
|
||||||
BOOST_CHECK(callFunction(0, u256(4)) == toBigEndian(u256(24)));
|
u256 i = 2;
|
||||||
|
while (i <= n)
|
||||||
|
nfac *= i++;
|
||||||
|
|
||||||
|
return nfac;
|
||||||
|
};
|
||||||
|
|
||||||
|
BOOST_CHECK(testSolidityAgainstCpp(0, while_loop_cpp, u256(0)));
|
||||||
|
BOOST_CHECK(testSolidityAgainstCpp(0, while_loop_cpp, u256(1)));
|
||||||
|
BOOST_CHECK(testSolidityAgainstCpp(0, while_loop_cpp, u256(2)));
|
||||||
|
BOOST_CHECK(testSolidityAgainstCpp(0, while_loop_cpp, u256(3)));
|
||||||
|
BOOST_CHECK(testSolidityAgainstCpp(0, while_loop_cpp, u256(4)));
|
||||||
}
|
}
|
||||||
|
|
||||||
BOOST_AUTO_TEST_CASE(break_outside_loop)
|
BOOST_AUTO_TEST_CASE(break_outside_loop)
|
||||||
@ -182,18 +211,43 @@ BOOST_AUTO_TEST_CASE(nested_loops)
|
|||||||
"}\n";
|
"}\n";
|
||||||
ExecutionFramework framework;
|
ExecutionFramework framework;
|
||||||
framework.compileAndRun(sourceCode);
|
framework.compileAndRun(sourceCode);
|
||||||
BOOST_CHECK(framework.callFunction(0, u256(0)) == toBigEndian(u256(0)));
|
|
||||||
BOOST_CHECK(framework.callFunction(0, u256(1)) == toBigEndian(u256(1)));
|
auto nested_loops_cpp = [](u256 n) -> u256
|
||||||
BOOST_CHECK(framework.callFunction(0, u256(2)) == toBigEndian(u256(1)));
|
{
|
||||||
BOOST_CHECK(framework.callFunction(0, u256(3)) == toBigEndian(u256(2)));
|
while (n > 1)
|
||||||
BOOST_CHECK(framework.callFunction(0, u256(4)) == toBigEndian(u256(2)));
|
{
|
||||||
BOOST_CHECK(framework.callFunction(0, u256(5)) == toBigEndian(u256(4)));
|
if (n == 10)
|
||||||
BOOST_CHECK(framework.callFunction(0, u256(6)) == toBigEndian(u256(5)));
|
break;
|
||||||
BOOST_CHECK(framework.callFunction(0, u256(7)) == toBigEndian(u256(5)));
|
while (n > 5)
|
||||||
BOOST_CHECK(framework.callFunction(0, u256(8)) == toBigEndian(u256(7)));
|
{
|
||||||
BOOST_CHECK(framework.callFunction(0, u256(9)) == toBigEndian(u256(8)));
|
if (n == 8)
|
||||||
BOOST_CHECK(framework.callFunction(0, u256(10)) == toBigEndian(u256(10)));
|
break;
|
||||||
BOOST_CHECK(framework.callFunction(0, u256(11)) == toBigEndian(u256(10)));
|
n--;
|
||||||
|
if (n == 6)
|
||||||
|
continue;
|
||||||
|
return n;
|
||||||
|
}
|
||||||
|
n--;
|
||||||
|
if (n == 3)
|
||||||
|
continue;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
return n;
|
||||||
|
};
|
||||||
|
|
||||||
|
BOOST_CHECK(framework.testSolidityAgainstCpp(0, nested_loops_cpp, u256(0)));
|
||||||
|
BOOST_CHECK(framework.testSolidityAgainstCpp(0, nested_loops_cpp, u256(1)));
|
||||||
|
BOOST_CHECK(framework.testSolidityAgainstCpp(0, nested_loops_cpp, u256(2)));
|
||||||
|
BOOST_CHECK(framework.testSolidityAgainstCpp(0, nested_loops_cpp, u256(3)));
|
||||||
|
BOOST_CHECK(framework.testSolidityAgainstCpp(0, nested_loops_cpp, u256(4)));
|
||||||
|
BOOST_CHECK(framework.testSolidityAgainstCpp(0, nested_loops_cpp, u256(5)));
|
||||||
|
BOOST_CHECK(framework.testSolidityAgainstCpp(0, nested_loops_cpp, u256(6)));
|
||||||
|
BOOST_CHECK(framework.testSolidityAgainstCpp(0, nested_loops_cpp, u256(7)));
|
||||||
|
BOOST_CHECK(framework.testSolidityAgainstCpp(0, nested_loops_cpp, u256(8)));
|
||||||
|
BOOST_CHECK(framework.testSolidityAgainstCpp(0, nested_loops_cpp, u256(9)));
|
||||||
|
BOOST_CHECK(framework.testSolidityAgainstCpp(0, nested_loops_cpp, u256(10)));
|
||||||
|
BOOST_CHECK(framework.testSolidityAgainstCpp(0, nested_loops_cpp, u256(11)));
|
||||||
}
|
}
|
||||||
|
|
||||||
BOOST_AUTO_TEST_CASE(calling_other_functions)
|
BOOST_AUTO_TEST_CASE(calling_other_functions)
|
||||||
@ -214,11 +268,34 @@ BOOST_AUTO_TEST_CASE(calling_other_functions)
|
|||||||
" }\n"
|
" }\n"
|
||||||
"}\n";
|
"}\n";
|
||||||
compileAndRun(sourceCode);
|
compileAndRun(sourceCode);
|
||||||
BOOST_CHECK(callFunction(2, u256(0)) == toBigEndian(u256(0)));
|
|
||||||
BOOST_CHECK(callFunction(2, u256(1)) == toBigEndian(u256(1)));
|
auto evenStep_cpp = [](u256 const& n) -> u256
|
||||||
BOOST_CHECK(callFunction(2, u256(2)) == toBigEndian(u256(1)));
|
{
|
||||||
BOOST_CHECK(callFunction(2, u256(8)) == toBigEndian(u256(1)));
|
return n / 2;
|
||||||
BOOST_CHECK(callFunction(2, u256(127)) == toBigEndian(u256(1)));
|
};
|
||||||
|
|
||||||
|
auto oddStep_cpp = [](u256 const& n) -> u256
|
||||||
|
{
|
||||||
|
return 3 * n + 1;
|
||||||
|
};
|
||||||
|
|
||||||
|
auto collatz_cpp = [&evenStep_cpp, &oddStep_cpp] (u256 n) -> u256 {
|
||||||
|
u256 y;
|
||||||
|
while ((y = n) > 1)
|
||||||
|
{
|
||||||
|
if (n % 2 == 0)
|
||||||
|
n = evenStep_cpp(n);
|
||||||
|
else
|
||||||
|
n = oddStep_cpp(n);
|
||||||
|
}
|
||||||
|
return y;
|
||||||
|
};
|
||||||
|
|
||||||
|
BOOST_CHECK(testSolidityAgainstCpp(2, collatz_cpp, u256(0)));
|
||||||
|
BOOST_CHECK(testSolidityAgainstCpp(2, collatz_cpp, u256(1)));
|
||||||
|
BOOST_CHECK(testSolidityAgainstCpp(2, collatz_cpp, u256(2)));
|
||||||
|
BOOST_CHECK(testSolidityAgainstCpp(2, collatz_cpp, u256(8)));
|
||||||
|
BOOST_CHECK(testSolidityAgainstCpp(2, collatz_cpp, u256(127)));
|
||||||
}
|
}
|
||||||
|
|
||||||
BOOST_AUTO_TEST_CASE(many_local_variables)
|
BOOST_AUTO_TEST_CASE(many_local_variables)
|
||||||
@ -270,8 +347,15 @@ BOOST_AUTO_TEST_CASE(short_circuiting)
|
|||||||
" }\n"
|
" }\n"
|
||||||
"}\n";
|
"}\n";
|
||||||
compileAndRun(sourceCode);
|
compileAndRun(sourceCode);
|
||||||
BOOST_CHECK(callFunction(0, u256(0)) == toBigEndian(u256(0)));
|
|
||||||
BOOST_CHECK(callFunction(0, u256(1)) == toBigEndian(u256(8)));
|
auto short_circuiting_cpp = [](u256 n) -> u256
|
||||||
|
{
|
||||||
|
n == 0 || (n = 8) > 0;
|
||||||
|
return n;
|
||||||
|
};
|
||||||
|
|
||||||
|
BOOST_CHECK(testSolidityAgainstCpp(0, short_circuiting_cpp, u256(0)));
|
||||||
|
BOOST_CHECK(testSolidityAgainstCpp(0, short_circuiting_cpp, u256(1)));
|
||||||
}
|
}
|
||||||
|
|
||||||
BOOST_AUTO_TEST_CASE(high_bits_cleaning)
|
BOOST_AUTO_TEST_CASE(high_bits_cleaning)
|
||||||
@ -284,7 +368,14 @@ BOOST_AUTO_TEST_CASE(high_bits_cleaning)
|
|||||||
" }\n"
|
" }\n"
|
||||||
"}\n";
|
"}\n";
|
||||||
compileAndRun(sourceCode);
|
compileAndRun(sourceCode);
|
||||||
BOOST_CHECK(callFunction(0, bytes()) == toBigEndian(u256(9)));
|
auto high_bits_cleaning_cpp = []() -> u256
|
||||||
|
{
|
||||||
|
uint32_t x = uint32_t(0xffffffff) + 10;
|
||||||
|
if (x >= 0xffffffff)
|
||||||
|
return 0;
|
||||||
|
return x;
|
||||||
|
};
|
||||||
|
BOOST_CHECK(testSolidityAgainstCpp(0, high_bits_cleaning_cpp));
|
||||||
}
|
}
|
||||||
|
|
||||||
BOOST_AUTO_TEST_CASE(sign_extension)
|
BOOST_AUTO_TEST_CASE(sign_extension)
|
||||||
@ -297,7 +388,14 @@ BOOST_AUTO_TEST_CASE(sign_extension)
|
|||||||
" }\n"
|
" }\n"
|
||||||
"}\n";
|
"}\n";
|
||||||
compileAndRun(sourceCode);
|
compileAndRun(sourceCode);
|
||||||
BOOST_CHECK(callFunction(0, bytes()) == toBigEndian(u256(0xff)));
|
auto sign_extension_cpp = []() -> u256
|
||||||
|
{
|
||||||
|
int64_t x = -int32_t(0xff);
|
||||||
|
if (x >= 0xff)
|
||||||
|
return 0;
|
||||||
|
return u256(x) * -1;
|
||||||
|
};
|
||||||
|
BOOST_CHECK(testSolidityAgainstCpp(0, sign_extension_cpp));
|
||||||
}
|
}
|
||||||
|
|
||||||
BOOST_AUTO_TEST_CASE(small_unsigned_types)
|
BOOST_AUTO_TEST_CASE(small_unsigned_types)
|
||||||
@ -309,7 +407,12 @@ BOOST_AUTO_TEST_CASE(small_unsigned_types)
|
|||||||
" }\n"
|
" }\n"
|
||||||
"}\n";
|
"}\n";
|
||||||
compileAndRun(sourceCode);
|
compileAndRun(sourceCode);
|
||||||
BOOST_CHECK(callFunction(0, bytes()) == toBigEndian(u256(0xfe0000)));
|
auto small_unsigned_types_cpp = []() -> u256
|
||||||
|
{
|
||||||
|
uint32_t x = uint32_t(0xffffff) * 0xffffff;
|
||||||
|
return x / 0x100;
|
||||||
|
};
|
||||||
|
BOOST_CHECK(testSolidityAgainstCpp(0, small_unsigned_types_cpp));
|
||||||
}
|
}
|
||||||
|
|
||||||
BOOST_AUTO_TEST_CASE(small_signed_types)
|
BOOST_AUTO_TEST_CASE(small_signed_types)
|
||||||
@ -320,7 +423,36 @@ BOOST_AUTO_TEST_CASE(small_signed_types)
|
|||||||
" }\n"
|
" }\n"
|
||||||
"}\n";
|
"}\n";
|
||||||
compileAndRun(sourceCode);
|
compileAndRun(sourceCode);
|
||||||
BOOST_CHECK(callFunction(0, bytes()) == toBigEndian(u256(200)));
|
auto small_signed_types_cpp = []() -> u256
|
||||||
|
{
|
||||||
|
return -int32_t(10) * -int64_t(20);
|
||||||
|
};
|
||||||
|
BOOST_CHECK(testSolidityAgainstCpp(0, small_signed_types_cpp));
|
||||||
|
}
|
||||||
|
|
||||||
|
BOOST_AUTO_TEST_CASE(state_smoke_test)
|
||||||
|
{
|
||||||
|
char const* sourceCode = "contract test {\n"
|
||||||
|
" uint256 value1;\n"
|
||||||
|
" uint256 value2;\n"
|
||||||
|
" function get(uint8 which) returns (uint256 value) {\n"
|
||||||
|
" if (which == 0) return value1;\n"
|
||||||
|
" else return value2;\n"
|
||||||
|
" }\n"
|
||||||
|
" function set(uint8 which, uint256 value) {\n"
|
||||||
|
" if (which == 0) value1 = value;\n"
|
||||||
|
" else value2 = value;\n"
|
||||||
|
" }\n"
|
||||||
|
"}\n";
|
||||||
|
compileAndRun(sourceCode);
|
||||||
|
BOOST_CHECK(callFunction(0, bytes(1, 0x00)) == toBigEndian(u256(0)));
|
||||||
|
BOOST_CHECK(callFunction(0, bytes(1, 0x01)) == toBigEndian(u256(0)));
|
||||||
|
BOOST_CHECK(callFunction(1, bytes(1, 0x00) + toBigEndian(u256(0x1234))) == bytes());
|
||||||
|
BOOST_CHECK(callFunction(1, bytes(1, 0x01) + toBigEndian(u256(0x8765))) == bytes());
|
||||||
|
BOOST_CHECK(callFunction(0, bytes(1, 0x00)) == toBigEndian(u256(0x1234)));
|
||||||
|
BOOST_CHECK(callFunction(0, bytes(1, 0x01)) == toBigEndian(u256(0x8765)));
|
||||||
|
BOOST_CHECK(callFunction(1, bytes(1, 0x00) + toBigEndian(u256(0x3))) == bytes());
|
||||||
|
BOOST_CHECK(callFunction(0, bytes(1, 0x00)) == toBigEndian(u256(0x3)));
|
||||||
}
|
}
|
||||||
|
|
||||||
BOOST_AUTO_TEST_SUITE_END()
|
BOOST_AUTO_TEST_SUITE_END()
|
||||||
|
@ -154,10 +154,10 @@ BOOST_AUTO_TEST_CASE(comparison)
|
|||||||
"}\n";
|
"}\n";
|
||||||
bytes code = compileFirstExpression(sourceCode);
|
bytes code = compileFirstExpression(sourceCode);
|
||||||
|
|
||||||
bytes expectation({byte(eth::Instruction::PUSH2), 0x10, 0xaa, byte(eth::Instruction::PUSH2), 0xff, 0xff, byte(eth::Instruction::AND),
|
bytes expectation({byte(eth::Instruction::PUSH1), 0x1,
|
||||||
byte(eth::Instruction::PUSH2), 0x11, 0xaa, byte(eth::Instruction::PUSH2), 0xff, 0xff, byte(eth::Instruction::AND),
|
byte(eth::Instruction::PUSH2), 0x11, 0xaa, byte(eth::Instruction::PUSH2), 0xff, 0xff, byte(eth::Instruction::AND),
|
||||||
byte(eth::Instruction::GT),
|
byte(eth::Instruction::PUSH2), 0x10, 0xaa, byte(eth::Instruction::PUSH2), 0xff, 0xff, byte(eth::Instruction::AND),
|
||||||
byte(eth::Instruction::PUSH1), 0x1,
|
byte(eth::Instruction::LT),
|
||||||
byte(eth::Instruction::EQ),
|
byte(eth::Instruction::EQ),
|
||||||
byte(eth::Instruction::ISZERO)});
|
byte(eth::Instruction::ISZERO)});
|
||||||
BOOST_CHECK_EQUAL_COLLECTIONS(code.begin(), code.end(), expectation.begin(), expectation.end());
|
BOOST_CHECK_EQUAL_COLLECTIONS(code.begin(), code.end(), expectation.begin(), expectation.end());
|
||||||
@ -166,7 +166,7 @@ BOOST_AUTO_TEST_CASE(comparison)
|
|||||||
BOOST_AUTO_TEST_CASE(short_circuiting)
|
BOOST_AUTO_TEST_CASE(short_circuiting)
|
||||||
{
|
{
|
||||||
char const* sourceCode = "contract test {\n"
|
char const* sourceCode = "contract test {\n"
|
||||||
" function f() { var x = (10 + 8 >= 4 || 2 != 9) != true; }"
|
" function f() { var x = true != (4 <= 8 + 10 || 9 != 2); }"
|
||||||
"}\n";
|
"}\n";
|
||||||
bytes code = compileFirstExpression(sourceCode);
|
bytes code = compileFirstExpression(sourceCode);
|
||||||
|
|
||||||
@ -194,7 +194,7 @@ BOOST_AUTO_TEST_CASE(short_circuiting)
|
|||||||
BOOST_AUTO_TEST_CASE(arithmetics)
|
BOOST_AUTO_TEST_CASE(arithmetics)
|
||||||
{
|
{
|
||||||
char const* sourceCode = "contract test {\n"
|
char const* sourceCode = "contract test {\n"
|
||||||
" function f() { var x = (1 * (2 / (3 % (4 + (5 - (6 | (7 & (8 ^ 9)))))))); }"
|
" function f() { var x = ((((((((9 ^ 8) & 7) | 6) - 5) + 4) % 3) / 2) * 1); }"
|
||||||
"}\n";
|
"}\n";
|
||||||
bytes code = compileFirstExpression(sourceCode);
|
bytes code = compileFirstExpression(sourceCode);
|
||||||
bytes expectation({byte(eth::Instruction::PUSH1), 0x1,
|
bytes expectation({byte(eth::Instruction::PUSH1), 0x1,
|
||||||
@ -211,14 +211,11 @@ BOOST_AUTO_TEST_CASE(arithmetics)
|
|||||||
byte(eth::Instruction::XOR),
|
byte(eth::Instruction::XOR),
|
||||||
byte(eth::Instruction::AND),
|
byte(eth::Instruction::AND),
|
||||||
byte(eth::Instruction::OR),
|
byte(eth::Instruction::OR),
|
||||||
byte(eth::Instruction::SWAP1),
|
|
||||||
byte(eth::Instruction::SUB),
|
byte(eth::Instruction::SUB),
|
||||||
byte(eth::Instruction::ADD),
|
byte(eth::Instruction::ADD),
|
||||||
byte(eth::Instruction::PUSH1), 0xff, byte(eth::Instruction::AND),
|
byte(eth::Instruction::PUSH1), 0xff, byte(eth::Instruction::AND),
|
||||||
byte(eth::Instruction::SWAP1),
|
|
||||||
byte(eth::Instruction::MOD),
|
byte(eth::Instruction::MOD),
|
||||||
byte(eth::Instruction::PUSH1), 0xff, byte(eth::Instruction::AND),
|
byte(eth::Instruction::PUSH1), 0xff, byte(eth::Instruction::AND),
|
||||||
byte(eth::Instruction::SWAP1),
|
|
||||||
byte(eth::Instruction::DIV),
|
byte(eth::Instruction::DIV),
|
||||||
byte(eth::Instruction::MUL)});
|
byte(eth::Instruction::MUL)});
|
||||||
BOOST_CHECK_EQUAL_COLLECTIONS(code.begin(), code.end(), expectation.begin(), expectation.end());
|
BOOST_CHECK_EQUAL_COLLECTIONS(code.begin(), code.end(), expectation.begin(), expectation.end());
|
||||||
@ -231,11 +228,11 @@ BOOST_AUTO_TEST_CASE(unary_operators)
|
|||||||
"}\n";
|
"}\n";
|
||||||
bytes code = compileFirstExpression(sourceCode);
|
bytes code = compileFirstExpression(sourceCode);
|
||||||
|
|
||||||
bytes expectation({byte(eth::Instruction::PUSH1), 0x1,
|
bytes expectation({byte(eth::Instruction::PUSH1), 0x2, byte(eth::Instruction::PUSH1), 0xff, byte(eth::Instruction::AND),
|
||||||
|
byte(eth::Instruction::PUSH1), 0x1,
|
||||||
byte(eth::Instruction::PUSH1), 0x0,
|
byte(eth::Instruction::PUSH1), 0x0,
|
||||||
byte(eth::Instruction::SUB),
|
byte(eth::Instruction::SUB),
|
||||||
byte(eth::Instruction::NOT), byte(eth::Instruction::PUSH1), 0xff, byte(eth::Instruction::AND),
|
byte(eth::Instruction::NOT), byte(eth::Instruction::PUSH1), 0xff, byte(eth::Instruction::AND),
|
||||||
byte(eth::Instruction::PUSH1), 0x2, byte(eth::Instruction::PUSH1), 0xff, byte(eth::Instruction::AND),
|
|
||||||
byte(eth::Instruction::EQ),
|
byte(eth::Instruction::EQ),
|
||||||
byte(eth::Instruction::ISZERO)});
|
byte(eth::Instruction::ISZERO)});
|
||||||
BOOST_CHECK_EQUAL_COLLECTIONS(code.begin(), code.end(), expectation.begin(), expectation.end());
|
BOOST_CHECK_EQUAL_COLLECTIONS(code.begin(), code.end(), expectation.begin(), expectation.end());
|
||||||
@ -244,7 +241,7 @@ BOOST_AUTO_TEST_CASE(unary_operators)
|
|||||||
BOOST_AUTO_TEST_CASE(unary_inc_dec)
|
BOOST_AUTO_TEST_CASE(unary_inc_dec)
|
||||||
{
|
{
|
||||||
char const* sourceCode = "contract test {\n"
|
char const* sourceCode = "contract test {\n"
|
||||||
" function f(uint a) { var x = ((a++ ^ ++a) ^ a--) ^ --a; }"
|
" function f(uint a) { var x = --a ^ (a-- ^ (++a ^ a++)); }"
|
||||||
"}\n";
|
"}\n";
|
||||||
bytes code = compileFirstExpression(sourceCode, {}, {{"test", "f", "a"}, {"test", "f", "x"}});
|
bytes code = compileFirstExpression(sourceCode, {}, {{"test", "f", "a"}, {"test", "f", "x"}});
|
||||||
|
|
||||||
@ -299,16 +296,15 @@ BOOST_AUTO_TEST_CASE(assignment)
|
|||||||
bytes code = compileFirstExpression(sourceCode, {}, {{"test", "f", "a"}, {"test", "f", "b"}});
|
bytes code = compileFirstExpression(sourceCode, {}, {{"test", "f", "a"}, {"test", "f", "b"}});
|
||||||
|
|
||||||
// Stack: a, b
|
// Stack: a, b
|
||||||
bytes expectation({byte(eth::Instruction::DUP1),
|
bytes expectation({byte(eth::Instruction::PUSH1), 0x2, byte(eth::Instruction::PUSH1), 0xff, byte(eth::Instruction::AND),
|
||||||
byte(eth::Instruction::DUP3),
|
|
||||||
byte(eth::Instruction::SWAP1),
|
|
||||||
byte(eth::Instruction::ADD),
|
|
||||||
// Stack here: a b a+b
|
|
||||||
byte(eth::Instruction::SWAP2),
|
|
||||||
byte(eth::Instruction::POP),
|
|
||||||
byte(eth::Instruction::DUP2),
|
byte(eth::Instruction::DUP2),
|
||||||
// Stack here: a+b b a+b
|
byte(eth::Instruction::DUP4),
|
||||||
byte(eth::Instruction::PUSH1), 0x2, byte(eth::Instruction::PUSH1), 0xff, byte(eth::Instruction::AND),
|
byte(eth::Instruction::ADD),
|
||||||
|
// Stack here: a b 2 a+b
|
||||||
|
byte(eth::Instruction::SWAP3),
|
||||||
|
byte(eth::Instruction::POP),
|
||||||
|
byte(eth::Instruction::DUP3),
|
||||||
|
// Stack here: a+b b 2 a+b
|
||||||
byte(eth::Instruction::MUL)});
|
byte(eth::Instruction::MUL)});
|
||||||
BOOST_CHECK_EQUAL_COLLECTIONS(code.begin(), code.end(), expectation.begin(), expectation.end());
|
BOOST_CHECK_EQUAL_COLLECTIONS(code.begin(), code.end(), expectation.begin(), expectation.end());
|
||||||
}
|
}
|
||||||
@ -323,21 +319,20 @@ BOOST_AUTO_TEST_CASE(function_call)
|
|||||||
{{"test", "f", "a"}, {"test", "f", "b"}});
|
{{"test", "f", "a"}, {"test", "f", "b"}});
|
||||||
|
|
||||||
// Stack: a, b
|
// Stack: a, b
|
||||||
bytes expectation({byte(eth::Instruction::PUSH1), 0x0d,
|
bytes expectation({byte(eth::Instruction::PUSH1), 0x02, byte(eth::Instruction::PUSH1), 0xff, byte(eth::Instruction::AND),
|
||||||
byte(eth::Instruction::DUP3),
|
byte(eth::Instruction::PUSH1), 0x12,
|
||||||
byte(eth::Instruction::PUSH1), 0x01, byte(eth::Instruction::PUSH1), 0xff, byte(eth::Instruction::AND),
|
byte(eth::Instruction::PUSH1), 0x01, byte(eth::Instruction::PUSH1), 0xff, byte(eth::Instruction::AND),
|
||||||
|
byte(eth::Instruction::DUP5),
|
||||||
byte(eth::Instruction::ADD),
|
byte(eth::Instruction::ADD),
|
||||||
// Stack here: a b <ret label> (a+1)
|
// Stack here: a b 2 <ret label> (a+1)
|
||||||
byte(eth::Instruction::DUP3),
|
byte(eth::Instruction::DUP4),
|
||||||
byte(eth::Instruction::PUSH1), 0x1a,
|
byte(eth::Instruction::PUSH1), 0x19,
|
||||||
byte(eth::Instruction::JUMP),
|
byte(eth::Instruction::JUMP),
|
||||||
byte(eth::Instruction::JUMPDEST),
|
byte(eth::Instruction::JUMPDEST),
|
||||||
// Stack here: a b g(a+1, b)
|
// Stack here: a b 2 g(a+1, b)
|
||||||
byte(eth::Instruction::PUSH1), 0x02, byte(eth::Instruction::PUSH1), 0xff, byte(eth::Instruction::AND),
|
|
||||||
byte(eth::Instruction::MUL),
|
byte(eth::Instruction::MUL),
|
||||||
// Stack here: a b g(a+1, b)*2
|
// Stack here: a b g(a+1, b)*2
|
||||||
byte(eth::Instruction::DUP3),
|
byte(eth::Instruction::DUP3),
|
||||||
byte(eth::Instruction::SWAP1),
|
|
||||||
byte(eth::Instruction::ADD),
|
byte(eth::Instruction::ADD),
|
||||||
// Stack here: a b a+g(a+1, b)*2
|
// Stack here: a b a+g(a+1, b)*2
|
||||||
byte(eth::Instruction::SWAP2),
|
byte(eth::Instruction::SWAP2),
|
||||||
@ -355,15 +350,15 @@ BOOST_AUTO_TEST_CASE(negative_literals_8bits)
|
|||||||
"}\n";
|
"}\n";
|
||||||
bytes code = compileFirstExpression(sourceCode);
|
bytes code = compileFirstExpression(sourceCode);
|
||||||
|
|
||||||
bytes expectation(bytes({byte(eth::Instruction::PUSH1), 0x00,
|
bytes expectation(bytes({byte(eth::Instruction::PUSH32)}) + bytes(31, 0xff) + bytes(1, 0x80) +
|
||||||
byte(eth::Instruction::PUSH32)}) + bytes(32, 0xff) +
|
bytes({byte(eth::Instruction::PUSH32)}) + bytes(31, 0xff) + bytes(1, 0x81) +
|
||||||
bytes({byte(eth::Instruction::ADD),
|
bytes({byte(eth::Instruction::PUSH32)}) + bytes(32, 0xff) +
|
||||||
byte(eth::Instruction::PUSH32)}) + bytes(32, 0xff) +
|
bytes({byte(eth::Instruction::PUSH32)}) + bytes(32, 0xff) +
|
||||||
bytes({byte(eth::Instruction::ADD),
|
bytes({byte(eth::Instruction::PUSH1), 0x00,
|
||||||
byte(eth::Instruction::PUSH32)}) + bytes(31, 0xff) + bytes(1, 0x81) +
|
byte(eth::Instruction::ADD),
|
||||||
bytes({byte(eth::Instruction::ADD),
|
byte(eth::Instruction::ADD),
|
||||||
byte(eth::Instruction::PUSH32)}) + bytes(31, 0xff) + bytes(1, 0x80) +
|
byte(eth::Instruction::ADD),
|
||||||
bytes({byte(eth::Instruction::ADD)}));
|
byte(eth::Instruction::ADD)}));
|
||||||
BOOST_CHECK_EQUAL_COLLECTIONS(code.begin(), code.end(), expectation.begin(), expectation.end());
|
BOOST_CHECK_EQUAL_COLLECTIONS(code.begin(), code.end(), expectation.begin(), expectation.end());
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -376,11 +371,11 @@ BOOST_AUTO_TEST_CASE(negative_literals_16bits)
|
|||||||
"}\n";
|
"}\n";
|
||||||
bytes code = compileFirstExpression(sourceCode);
|
bytes code = compileFirstExpression(sourceCode);
|
||||||
|
|
||||||
bytes expectation(bytes({byte(eth::Instruction::PUSH32)}) + bytes(32, 0xff) +
|
bytes expectation(bytes({byte(eth::Instruction::PUSH32)}) + bytes(31, 0xff) + bytes(1, 0x7f) +
|
||||||
|
bytes({byte(eth::Instruction::PUSH32)}) + bytes(32, 0xff) +
|
||||||
bytes({byte(eth::Instruction::PUSH1), 0x00,
|
bytes({byte(eth::Instruction::PUSH1), 0x00,
|
||||||
byte(eth::Instruction::SIGNEXTEND),
|
byte(eth::Instruction::SIGNEXTEND),
|
||||||
byte(eth::Instruction::PUSH32)}) + bytes(31, 0xff) + bytes(1, 0x7f) +
|
byte(eth::Instruction::ADD),
|
||||||
bytes({byte(eth::Instruction::ADD),
|
|
||||||
byte(eth::Instruction::PUSH1), 0x01,
|
byte(eth::Instruction::PUSH1), 0x01,
|
||||||
byte(eth::Instruction::SIGNEXTEND)}));
|
byte(eth::Instruction::SIGNEXTEND)}));
|
||||||
BOOST_CHECK_EQUAL_COLLECTIONS(code.begin(), code.end(), expectation.begin(), expectation.end());
|
BOOST_CHECK_EQUAL_COLLECTIONS(code.begin(), code.end(), expectation.begin(), expectation.end());
|
||||||
|
14
state.cpp
14
state.cpp
@ -55,12 +55,6 @@ void doStateTests(json_spirit::mValue& v, bool _fillin)
|
|||||||
|
|
||||||
ImportTest importer(o, _fillin);
|
ImportTest importer(o, _fillin);
|
||||||
|
|
||||||
if (_fillin)
|
|
||||||
{
|
|
||||||
importer.code = importer.m_statePre.code(importer.m_environment.myAddress);
|
|
||||||
importer.m_environment.code = &importer.code;
|
|
||||||
}
|
|
||||||
|
|
||||||
State theState = importer.m_statePre;
|
State theState = importer.m_statePre;
|
||||||
bytes tx = importer.m_transaction.rlp();
|
bytes tx = importer.m_transaction.rlp();
|
||||||
bytes output;
|
bytes output;
|
||||||
@ -124,12 +118,4 @@ BOOST_AUTO_TEST_CASE(stSystemOperationsTest)
|
|||||||
dev::test::executeTests("stSystemOperationsTest", "/StateTests", dev::test::doStateTests);
|
dev::test::executeTests("stSystemOperationsTest", "/StateTests", dev::test::doStateTests);
|
||||||
}
|
}
|
||||||
|
|
||||||
BOOST_AUTO_TEST_CASE(tmp)
|
|
||||||
{
|
|
||||||
int currentVerbosity = g_logVerbosity;
|
|
||||||
g_logVerbosity = 12;
|
|
||||||
dev::test::executeTests("tmp", "/StateTests", dev::test::doStateTests);
|
|
||||||
g_logVerbosity = currentVerbosity;
|
|
||||||
}
|
|
||||||
|
|
||||||
BOOST_AUTO_TEST_SUITE_END()
|
BOOST_AUTO_TEST_SUITE_END()
|
||||||
|
@ -1,44 +0,0 @@
|
|||||||
{
|
|
||||||
"ABAcalls0": {
|
|
||||||
"env" : {
|
|
||||||
"previousHash" : "5e20a0453cecd065ea59c37ac63e079ee08998b6045136a8ce6635c7912ec0b6",
|
|
||||||
"currentNumber" : "0",
|
|
||||||
"currentGasLimit" : "10000000",
|
|
||||||
"currentDifficulty" : "256",
|
|
||||||
"currentTimestamp" : 1,
|
|
||||||
"currentCoinbase" : "2adc25665018aa1fe0e6bc666dac8fc2697ff9ba"
|
|
||||||
},
|
|
||||||
"pre" : {
|
|
||||||
"095e7baea6a6c7c4c2dfeb977efac326af552d87" : {
|
|
||||||
"balance" : "1000000000000000000",
|
|
||||||
"nonce" : 0,
|
|
||||||
"code" : "{ [[ (PC) ]] (CALL 1000 0x945304eb96065b2a98b57a48a06ae28d285a71b5 24 0 0 0 0) }",
|
|
||||||
"storage": {}
|
|
||||||
},
|
|
||||||
"945304eb96065b2a98b57a48a06ae28d285a71b5" : {
|
|
||||||
"balance" : "23",
|
|
||||||
"code" : " { [[ (PC) ]] (ADD 1 (CALL 500 0x095e7baea6a6c7c4c2dfeb977efac326af552d87 23 0 0 0 0)) } ",
|
|
||||||
"nonce" : "0",
|
|
||||||
"storage" : {
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"a94f5374fce5edbc8e2a8697c15331677e6ebf0b" : {
|
|
||||||
"balance" : "1000000000000000000",
|
|
||||||
"nonce" : 0,
|
|
||||||
"code" : "",
|
|
||||||
"storage": {}
|
|
||||||
}
|
|
||||||
|
|
||||||
},
|
|
||||||
"transaction" : {
|
|
||||||
"nonce" : "0",
|
|
||||||
"gasPrice" : "1",
|
|
||||||
"gasLimit" : "10000",
|
|
||||||
"to" : "095e7baea6a6c7c4c2dfeb977efac326af552d87",
|
|
||||||
"value" : "100000",
|
|
||||||
"secretKey" : "45a915e4d060149eb4365960e6a7a45f334393093061116b197e3240065ff2d8",
|
|
||||||
"data" : ""
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
10
vm.cpp
10
vm.cpp
@ -29,7 +29,7 @@ using namespace dev::eth;
|
|||||||
using namespace dev::test;
|
using namespace dev::test;
|
||||||
|
|
||||||
FakeExtVM::FakeExtVM(eth::BlockInfo const& _previousBlock, eth::BlockInfo const& _currentBlock, unsigned _depth): /// TODO: XXX: remove the default argument & fix.
|
FakeExtVM::FakeExtVM(eth::BlockInfo const& _previousBlock, eth::BlockInfo const& _currentBlock, unsigned _depth): /// TODO: XXX: remove the default argument & fix.
|
||||||
ExtVMFace(Address(), Address(), Address(), 0, 1, bytesConstRef(), bytesConstRef(), _previousBlock, _currentBlock, _depth) {}
|
ExtVMFace(Address(), Address(), Address(), 0, 1, bytesConstRef(), bytes(), _previousBlock, _currentBlock, _depth) {}
|
||||||
|
|
||||||
h160 FakeExtVM::create(u256 _endowment, u256* _gas, bytesConstRef _init, OnOpFunc const&)
|
h160 FakeExtVM::create(u256 _endowment, u256* _gas, bytesConstRef _init, OnOpFunc const&)
|
||||||
{
|
{
|
||||||
@ -195,11 +195,11 @@ void FakeExtVM::importExec(mObject& _o)
|
|||||||
gas = toInt(_o["gas"]);
|
gas = toInt(_o["gas"]);
|
||||||
|
|
||||||
thisTxCode.clear();
|
thisTxCode.clear();
|
||||||
code = &thisTxCode;
|
code = thisTxCode;
|
||||||
|
|
||||||
thisTxCode = importCode(_o);
|
thisTxCode = importCode(_o);
|
||||||
if (_o["code"].type() != str_type && _o["code"].type() != array_type)
|
if (_o["code"].type() != str_type && _o["code"].type() != array_type)
|
||||||
code.reset();
|
code.clear();
|
||||||
|
|
||||||
thisTxData.clear();
|
thisTxData.clear();
|
||||||
thisTxData = importData(_o);
|
thisTxData = importData(_o);
|
||||||
@ -289,10 +289,10 @@ void doVMTests(json_spirit::mValue& v, bool _fillin)
|
|||||||
o["pre"] = mValue(fev.exportState());
|
o["pre"] = mValue(fev.exportState());
|
||||||
|
|
||||||
fev.importExec(o["exec"].get_obj());
|
fev.importExec(o["exec"].get_obj());
|
||||||
if (!fev.code)
|
if (fev.code.empty())
|
||||||
{
|
{
|
||||||
fev.thisTxCode = get<3>(fev.addresses.at(fev.myAddress));
|
fev.thisTxCode = get<3>(fev.addresses.at(fev.myAddress));
|
||||||
fev.code = &fev.thisTxCode;
|
fev.code = fev.thisTxCode;
|
||||||
}
|
}
|
||||||
|
|
||||||
bytes output;
|
bytes output;
|
||||||
|
Loading…
Reference in New Issue
Block a user