aboutsummaryrefslogtreecommitdiffstats
path: root/test
diff options
context:
space:
mode:
authorchriseth <chris@ethereum.org>2018-06-04 22:10:56 +0800
committerGitHub <noreply@github.com>2018-06-04 22:10:56 +0800
commitc59a06bb97081f95885ce7c0c076d4290c26cd38 (patch)
tree428ba950791db68954151ba43ca649fedd8fafa6 /test
parent0a074d8494cd927c523a3fc164fff98acbda2dd3 (diff)
parent4b7e58f22fbac413b8f182cfdd5df9fdf1efd674 (diff)
downloaddexon-solidity-c59a06bb97081f95885ce7c0c076d4290c26cd38.tar.gz
dexon-solidity-c59a06bb97081f95885ce7c0c076d4290c26cd38.tar.zst
dexon-solidity-c59a06bb97081f95885ce7c0c076d4290c26cd38.zip
Merge pull request #4213 from ethereum/fixpop
Fix bug related to byte array pop.
Diffstat (limited to 'test')
-rw-r--r--test/libsolidity/SolidityEndToEndTest.cpp34
1 files changed, 34 insertions, 0 deletions
diff --git a/test/libsolidity/SolidityEndToEndTest.cpp b/test/libsolidity/SolidityEndToEndTest.cpp
index 91f59035..b53a9294 100644
--- a/test/libsolidity/SolidityEndToEndTest.cpp
+++ b/test/libsolidity/SolidityEndToEndTest.cpp
@@ -5397,6 +5397,40 @@ BOOST_AUTO_TEST_CASE(byte_array_pop_copy_long)
));
}
+BOOST_AUTO_TEST_CASE(array_pop_isolated)
+{
+ char const* sourceCode = R"(
+ // This tests that the compiler knows the correct size of the function on the stack.
+ contract c {
+ uint[] data;
+ function test() public returns (uint x) {
+ x = 2;
+ data.pop;
+ x = 3;
+ }
+ }
+ )";
+ compileAndRun(sourceCode);
+ ABI_CHECK(callContractFunction("test()"), encodeArgs(3));
+}
+
+BOOST_AUTO_TEST_CASE(byte_array_pop_isolated)
+{
+ char const* sourceCode = R"(
+ // This tests that the compiler knows the correct size of the function on the stack.
+ contract c {
+ bytes data;
+ function test() public returns (uint x) {
+ x = 2;
+ data.pop;
+ x = 3;
+ }
+ }
+ )";
+ compileAndRun(sourceCode);
+ ABI_CHECK(callContractFunction("test()"), encodeArgs(3));
+}
+
BOOST_AUTO_TEST_CASE(external_array_args)
{
char const* sourceCode = R"(