From 208429644dbf646e90107447b148e7edb6c36512 Mon Sep 17 00:00:00 2001 From: Lu Guanqun Date: Mon, 4 Jan 2016 16:11:13 +0800 Subject: add a test case for decayed tuple expression as left value --- test/libsolidity/SolidityEndToEndTest.cpp | 15 +++++++++++++++ test/libsolidity/SolidityParser.cpp | 1 + 2 files changed, 16 insertions(+) (limited to 'test/libsolidity') diff --git a/test/libsolidity/SolidityEndToEndTest.cpp b/test/libsolidity/SolidityEndToEndTest.cpp index d57360dc..2f627fc2 100644 --- a/test/libsolidity/SolidityEndToEndTest.cpp +++ b/test/libsolidity/SolidityEndToEndTest.cpp @@ -5785,6 +5785,21 @@ BOOST_AUTO_TEST_CASE(string_tuples) BOOST_CHECK(callContractFunction("g()") == encodeArgs(u256(0x40), u256(0x80), u256(3), string("abc"), u256(3), string("def"))); } +BOOST_AUTO_TEST_CASE(decayed_tuple) +{ + char const* sourceCode = R"( + contract C { + function f() returns (uint) { + uint x = 1; + (x) = 2; + return x; + } + } + )"; + compileAndRun(sourceCode); + BOOST_CHECK(callContractFunction("f()") == encodeArgs(u256(2))); +} + BOOST_AUTO_TEST_CASE(destructuring_assignment) { char const* sourceCode = R"( diff --git a/test/libsolidity/SolidityParser.cpp b/test/libsolidity/SolidityParser.cpp index 5c5a9f68..8e0bf77e 100644 --- a/test/libsolidity/SolidityParser.cpp +++ b/test/libsolidity/SolidityParser.cpp @@ -1008,6 +1008,7 @@ BOOST_AUTO_TEST_CASE(tuples) var (b,) = (1,); var (c,d) = (1, 2 + a); var (e,) = (1, 2, b); + (a) = 3; } } )"; -- cgit