From ba62831143e5d4f8ebef6242f821e7a1b3dfc810 Mon Sep 17 00:00:00 2001 From: chriseth Date: Tue, 25 Sep 2018 16:24:40 +0200 Subject: Tests for inlining inside condition. --- test/libjulia/Inliner.cpp | 35 +++++++++++++++++++++++++++++++++++ 1 file changed, 35 insertions(+) (limited to 'test/libjulia') diff --git a/test/libjulia/Inliner.cpp b/test/libjulia/Inliner.cpp index 43a7d757..0cffabb2 100644 --- a/test/libjulia/Inliner.cpp +++ b/test/libjulia/Inliner.cpp @@ -342,5 +342,40 @@ BOOST_AUTO_TEST_CASE(pop_result) ); } +BOOST_AUTO_TEST_CASE(inside_condition) +{ + // This tests that breaking the expresison inside the condition works properly. + BOOST_CHECK_EQUAL( + fullInline(R"({ + if gt(f(mload(1)), mload(0)) { + sstore(0, 2) + } + function f(a) -> r { + a := mload(a) + r := add(a, calldatasize()) + } + })", false), + format(R"({ + { + let _1 := mload(0) + let f_a := mload(1) + let f_r + { + f_a := mload(f_a) + f_r := add(f_a, calldatasize()) + } + if gt(f_r, _1) + { + sstore(0, 2) + } + } + function f(a) -> r + { + a := mload(a) + r := add(a, calldatasize()) + } + })", false) + ); +} BOOST_AUTO_TEST_SUITE_END() -- cgit