diff options
author | RJ <catalanor0220@gmail.com> | 2016-01-11 11:36:47 +0800 |
---|---|---|
committer | RJ <catalanor0220@gmail.com> | 2016-01-11 11:36:47 +0800 |
commit | 5a3b40f802612b3fe18eac2c76fb2c849318807a (patch) | |
tree | 10fb0073267d1a49269ad072d66de9ad87d672b2 | |
parent | d751b9085cf465b1c0730032f602f375b0b48c04 (diff) | |
download | dexon-solidity-5a3b40f802612b3fe18eac2c76fb2c849318807a.tar dexon-solidity-5a3b40f802612b3fe18eac2c76fb2c849318807a.tar.gz dexon-solidity-5a3b40f802612b3fe18eac2c76fb2c849318807a.tar.bz2 dexon-solidity-5a3b40f802612b3fe18eac2c76fb2c849318807a.tar.lz dexon-solidity-5a3b40f802612b3fe18eac2c76fb2c849318807a.tar.xz dexon-solidity-5a3b40f802612b3fe18eac2c76fb2c849318807a.tar.zst dexon-solidity-5a3b40f802612b3fe18eac2c76fb2c849318807a.zip |
Update SolidityEndToEndTest.cpp
-rw-r--r-- | test/libsolidity/SolidityEndToEndTest.cpp | 25 |
1 files changed, 18 insertions, 7 deletions
diff --git a/test/libsolidity/SolidityEndToEndTest.cpp b/test/libsolidity/SolidityEndToEndTest.cpp index 218d038e..8be158fb 100644 --- a/test/libsolidity/SolidityEndToEndTest.cpp +++ b/test/libsolidity/SolidityEndToEndTest.cpp @@ -6111,16 +6111,16 @@ BOOST_AUTO_TEST_CASE(inline_array_storage_to_memory_conversion_strings) { char const* sourceCode = R"( contract C { - string s = "aeou"; + string s = "doh"; function f() returns (string, string) { - string memory t = "abc"; - string[3] memory x = [s, t, "Hello"]; - return (x[0], x[2]); + string memory t = "ray"; + string[3] memory x = [s, t, "mi"]; + return (x[1], x[2]); } } )"; compileAndRun(sourceCode); - BOOST_CHECK(callContractFunction("f()") == encodeArgs(u256(0x40), u256(0x80), u256(4), string("aeou"), u256(3), string("abc"))); + BOOST_CHECK(callContractFunction("f()") == encodeArgs(u256(0x40), u256(0x80), u256(3), string("ray"), u256(2), string("mi"))); } BOOST_AUTO_TEST_CASE(inline_array_storage_to_memory_conversion_ints) @@ -6156,22 +6156,33 @@ BOOST_AUTO_TEST_CASE(inline_array_index_access_strings) { char const* sourceCode = R"( contract C { + string public tester; function f() returns (string) { - return (["abc", "def", "g"][1]); + return (["abc", "def", "g"][0]); + } + function test() { + tester = f(); } } )"; compileAndRun(sourceCode, 0, "C"); - BOOST_CHECK(callContractFunction("f()") == encodeArgs(u256(0x40), u256(3), string("def"))); + BOOST_CHECK(callContractFunction("test()") == encodeArgs()); + BOOST_CHECK(callContractFunction("tester()") == encodeArgs(u256(0x20), u256(3), string("abc"))); } BOOST_AUTO_TEST_CASE(inline_array_return) { char const* sourceCode = R"( contract C { + uint8[] tester; function f() returns (uint8[5]) { return ([1,2,3,4,5]); } + function test() returns (uint8, uint8, uint8, uint8, uint8) { + tester = f(); + return (tester[0], tester[1], tester[2], tester[3], tester[4]); + } + } )"; compileAndRun(sourceCode, 0, "C"); |