aboutsummaryrefslogtreecommitdiffstats
path: root/libsolidity/SolidityEndToEndTest.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'libsolidity/SolidityEndToEndTest.cpp')
-rw-r--r--libsolidity/SolidityEndToEndTest.cpp28
1 files changed, 27 insertions, 1 deletions
diff --git a/libsolidity/SolidityEndToEndTest.cpp b/libsolidity/SolidityEndToEndTest.cpp
index faa5dad4..839ad792 100644
--- a/libsolidity/SolidityEndToEndTest.cpp
+++ b/libsolidity/SolidityEndToEndTest.cpp
@@ -4111,7 +4111,7 @@ BOOST_AUTO_TEST_CASE(struct_delete_struct_in_mapping)
BOOST_CHECK(callContractFunction("deleteIt()") == encodeArgs(0));
}
-BOOST_AUTO_TEST_CASE(evm_exceptions)
+BOOST_AUTO_TEST_CASE(evm_exceptions_out_of_band_access)
{
char const* sourceCode = R"(
contract A {
@@ -4135,6 +4135,32 @@ BOOST_AUTO_TEST_CASE(evm_exceptions)
BOOST_CHECK(callContractFunction("test()") == encodeArgs(false));
}
+BOOST_AUTO_TEST_CASE(evm_exceptions_when_calling_non_existing_function)
+{
+ char const* sourceCode = R"(
+ contract A {
+ uint public test = 0;
+ function badFunction() returns (uint)
+ {
+ this.call("123");
+ test = 1;
+ return 2;
+ }
+ function testIt() returns (bool)
+ {
+ this.badFunction();
+ test = 2;
+ return true;
+ }
+ }
+ )";
+ compileAndRun(sourceCode, 0, "A");
+
+ BOOST_CHECK(callContractFunction("test()") == encodeArgs(0));
+ BOOST_CHECK(callContractFunction("testIt()") == encodeArgs());
+ BOOST_CHECK(callContractFunction("test()") == encodeArgs(0));
+}
+
BOOST_AUTO_TEST_SUITE_END()
}