diff options
author | Lu Guanqun <guanqun.lu@gmail.com> | 2016-01-12 00:00:14 +0800 |
---|---|---|
committer | Lu Guanqun <guanqun.lu@gmail.com> | 2016-01-23 01:14:01 +0800 |
commit | d36537e73720f181fae3e3b82a3d751d27782ca1 (patch) | |
tree | 5e9ce3f9e00bf3987ec79057cf8c9a21b9e9f07b /test/libsolidity/SolidityEndToEndTest.cpp | |
parent | c8b05339335d8e9166ef6863f7697bcc59f09260 (diff) | |
download | dexon-solidity-d36537e73720f181fae3e3b82a3d751d27782ca1.tar.gz dexon-solidity-d36537e73720f181fae3e3b82a3d751d27782ca1.tar.zst dexon-solidity-d36537e73720f181fae3e3b82a3d751d27782ca1.zip |
cond-expr: use the mobile type instead of the original type
Diffstat (limited to 'test/libsolidity/SolidityEndToEndTest.cpp')
-rw-r--r-- | test/libsolidity/SolidityEndToEndTest.cpp | 35 |
1 files changed, 34 insertions, 1 deletions
diff --git a/test/libsolidity/SolidityEndToEndTest.cpp b/test/libsolidity/SolidityEndToEndTest.cpp index 0f0eb417..0907525b 100644 --- a/test/libsolidity/SolidityEndToEndTest.cpp +++ b/test/libsolidity/SolidityEndToEndTest.cpp @@ -141,7 +141,40 @@ BOOST_AUTO_TEST_CASE(conditional_expression_with_return_values) BOOST_CHECK(callContractFunction("f(bool,uint256)", false, u256(20)) == encodeArgs(u256(0), u256(20))); } -BOOST_AUTO_TEST_CASE(conditional_expression_storage_memory) +BOOST_AUTO_TEST_CASE(conditional_expression_storage_memory_1) +{ + char const* sourceCode = R"( + contract test { + bytes2[2] data1; + function f(bool cond) returns (uint) { + bytes2[2] memory x; + x[0] = "aa"; + bytes2[2] memory y; + y[0] = "bb"; + + data1 = cond ? x : y; + + uint ret = 0; + if (data1[0] == "aa") + { + ret = 1; + } + + if (data1[0] == "bb") + { + ret = 2; + } + + return ret; + } + } + )"; + compileAndRun(sourceCode); + BOOST_CHECK(callContractFunction("f(bool)", true) == encodeArgs(u256(1))); + BOOST_CHECK(callContractFunction("f(bool)", false) == encodeArgs(u256(2))); +} + +BOOST_AUTO_TEST_CASE(conditional_expression_storage_memory_2) { char const* sourceCode = R"( contract test { |