aboutsummaryrefslogtreecommitdiffstats
path: root/test/liblll
diff options
context:
space:
mode:
authorbenjaminion <ben@edginet.org>2017-07-12 04:22:38 +0800
committerbenjaminion <ben@edginet.org>2017-07-12 04:22:38 +0800
commit3bc935d932da3d7e8ff21bb3057276338c4ad497 (patch)
tree36bd8668c7908189707690942a3e1806a3c0c113 /test/liblll
parent0b17ff1bdde6a56d3c9b48e8c40da7ad4e9a43f5 (diff)
downloaddexon-solidity-3bc935d932da3d7e8ff21bb3057276338c4ad497.tar
dexon-solidity-3bc935d932da3d7e8ff21bb3057276338c4ad497.tar.gz
dexon-solidity-3bc935d932da3d7e8ff21bb3057276338c4ad497.tar.bz2
dexon-solidity-3bc935d932da3d7e8ff21bb3057276338c4ad497.tar.lz
dexon-solidity-3bc935d932da3d7e8ff21bb3057276338c4ad497.tar.xz
dexon-solidity-3bc935d932da3d7e8ff21bb3057276338c4ad497.tar.zst
dexon-solidity-3bc935d932da3d7e8ff21bb3057276338c4ad497.zip
LLL: rewrite alloc to avoid issues with edge cases.
Diffstat (limited to 'test/liblll')
-rw-r--r--test/liblll/EndToEndTest.cpp55
1 files changed, 55 insertions, 0 deletions
diff --git a/test/liblll/EndToEndTest.cpp b/test/liblll/EndToEndTest.cpp
index 7f4dd91a..4e896fd0 100644
--- a/test/liblll/EndToEndTest.cpp
+++ b/test/liblll/EndToEndTest.cpp
@@ -467,6 +467,61 @@ BOOST_AUTO_TEST_CASE(send_three_args)
BOOST_CHECK(balanceAt(Address(0xdead)) == 42);
}
+// Regression test for edge case that previously failed
+BOOST_AUTO_TEST_CASE(alloc_zero)
+{
+ char const* sourceCode = R"(
+ (returnlll
+ (seq
+ (mstore 0x00 (~ 0))
+ (alloc 0)
+ (return 0x00 0x20)))
+ )";
+ compileAndRun(sourceCode);
+ BOOST_CHECK(callFallback() == encodeArgs(u256(-1)));
+}
+
+BOOST_AUTO_TEST_CASE(alloc_size)
+{
+ char const* sourceCode = R"(
+ (returnlll
+ (seq
+ (mstore 0x00 0) ; reserve space for the result of the alloc
+ (mstore 0x00 (alloc (calldataload 0x04)))
+ (return (- (msize) (mload 0x00)))))
+ )";
+ compileAndRun(sourceCode);
+ BOOST_CHECK(callContractFunction("test()", 0) == encodeArgs(u256(0)));
+ BOOST_CHECK(callContractFunction("test()", 1) == encodeArgs(u256(32)));
+ BOOST_CHECK(callContractFunction("test()", 32) == encodeArgs(u256(32)));
+ BOOST_CHECK(callContractFunction("test()", 33) == encodeArgs(u256(64)));
+}
+
+BOOST_AUTO_TEST_CASE(alloc_start)
+{
+ char const* sourceCode = R"(
+ (returnlll
+ (seq
+ (mstore 0x40 0) ; Set initial MSIZE to 0x60
+ (return (alloc 1))))
+ )";
+ compileAndRun(sourceCode);
+ BOOST_CHECK(callFallback() == encodeArgs(96));
+}
+
+BOOST_AUTO_TEST_CASE(alloc_with_variable)
+{
+ char const* sourceCode = R"(
+ (returnlll
+ (seq
+ (set 'x (alloc 1))
+ (mstore8 @x 42) ; ASCII '*'
+ (return @x 0x20)))
+ )";
+ compileAndRun(sourceCode);
+ BOOST_CHECK(callFallback() == encodeArgs("*"));
+}
+
BOOST_AUTO_TEST_CASE(msg_six_args)
{
char const* sourceCode = R"(