mirror of
https://github.com/ethereum/solidity
synced 2023-10-03 13:03:40 +00:00
test: add a test about trying to log an event with too big enum values
This commit is contained in:
parent
d49904c92a
commit
d4173cd54a
@ -4539,6 +4539,40 @@ BOOST_AUTO_TEST_CASE(invalid_enum_compared)
|
||||
BOOST_CHECK(callContractFunction("test_neq()") == encodeArgs());
|
||||
}
|
||||
|
||||
BOOST_AUTO_TEST_CASE(invalid_enum_logged)
|
||||
{
|
||||
char const* sourceCode = R"(
|
||||
contract C {
|
||||
enum X { A, B }
|
||||
event Log(X);
|
||||
|
||||
function test_log() returns (uint) {
|
||||
X garbled = X.A;
|
||||
assembly {
|
||||
garbled := 5
|
||||
}
|
||||
Log(garbled);
|
||||
return 1;
|
||||
}
|
||||
function test_log_ok() returns (uint) {
|
||||
X x = X.A;
|
||||
Log(x);
|
||||
return 1;
|
||||
}
|
||||
}
|
||||
)";
|
||||
compileAndRun(sourceCode, 0, "C");
|
||||
BOOST_CHECK(callContractFunction("test_log_ok()") == encodeArgs(u256(1)));
|
||||
BOOST_REQUIRE_EQUAL(m_logs.size(), 1);
|
||||
BOOST_CHECK_EQUAL(m_logs[0].address, m_contractAddress);
|
||||
BOOST_REQUIRE_EQUAL(m_logs[0].topics.size(), 1);
|
||||
BOOST_REQUIRE_EQUAL(m_logs[0].topics[0], dev::keccak256(string("Log(uint8)")));
|
||||
BOOST_CHECK_EQUAL(h256(m_logs[0].data), h256(u256(0)));
|
||||
|
||||
// should throw
|
||||
BOOST_CHECK(callContractFunction("test_log()") == encodeArgs());
|
||||
}
|
||||
|
||||
BOOST_AUTO_TEST_CASE(invalid_enum_as_external_ret)
|
||||
{
|
||||
char const* sourceCode = R"(
|
||||
|
Loading…
Reference in New Issue
Block a user