diff options
author | chriseth <c@ethdev.com> | 2016-06-27 16:39:37 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2016-06-27 16:39:37 +0800 |
commit | c1a16d8d5afc80eb4c0714fbacbd51c99ba04d72 (patch) | |
tree | a907069c75d43e2c86629e4e148383d4e3d5d26f /test/libsolidity | |
parent | 460ed095f8f6c8e457ef6e284abc513c9e8ca765 (diff) | |
parent | 25a64c7f8f35833b9dec6068232be6e0ce9d2e78 (diff) | |
download | dexon-solidity-c1a16d8d5afc80eb4c0714fbacbd51c99ba04d72.tar dexon-solidity-c1a16d8d5afc80eb4c0714fbacbd51c99ba04d72.tar.gz dexon-solidity-c1a16d8d5afc80eb4c0714fbacbd51c99ba04d72.tar.bz2 dexon-solidity-c1a16d8d5afc80eb4c0714fbacbd51c99ba04d72.tar.lz dexon-solidity-c1a16d8d5afc80eb4c0714fbacbd51c99ba04d72.tar.xz dexon-solidity-c1a16d8d5afc80eb4c0714fbacbd51c99ba04d72.tar.zst dexon-solidity-c1a16d8d5afc80eb4c0714fbacbd51c99ba04d72.zip |
Merge pull request #677 from chriseth/unusedReturn
Warn about unused return values.
Diffstat (limited to 'test/libsolidity')
-rw-r--r-- | test/libsolidity/SolidityNameAndTypeResolution.cpp | 73 |
1 files changed, 73 insertions, 0 deletions
diff --git a/test/libsolidity/SolidityNameAndTypeResolution.cpp b/test/libsolidity/SolidityNameAndTypeResolution.cpp index 697b3fa9..7e81bd7e 100644 --- a/test/libsolidity/SolidityNameAndTypeResolution.cpp +++ b/test/libsolidity/SolidityNameAndTypeResolution.cpp @@ -3750,6 +3750,79 @@ BOOST_AUTO_TEST_CASE(one_divided_by_three_integer_conversion) BOOST_CHECK(!success(text)); } +BOOST_AUTO_TEST_CASE(unused_return_value) +{ + char const* text = R"( + contract test { + function g() returns (uint) {} + function f() { + g(); + } + } + )"; + BOOST_CHECK(success(text)); +} + +BOOST_AUTO_TEST_CASE(unused_return_value_send) +{ + char const* text = R"( + contract test { + function f() { + address(0x12).send(1); + } + } + )"; + BOOST_CHECK(expectError(text, true) == Error::Type::Warning); +} + +BOOST_AUTO_TEST_CASE(unused_return_value_call) +{ + char const* text = R"( + contract test { + function f() { + address(0x12).call("abc"); + } + } + )"; + BOOST_CHECK(expectError(text, true) == Error::Type::Warning); +} + +BOOST_AUTO_TEST_CASE(unused_return_value_call_value) +{ + char const* text = R"( + contract test { + function f() { + address(0x12).call.value(2)("abc"); + } + } + )"; + BOOST_CHECK(expectError(text, true) == Error::Type::Warning); +} + +BOOST_AUTO_TEST_CASE(unused_return_value_callcode) +{ + char const* text = R"( + contract test { + function f() { + address(0x12).callcode("abc"); + } + } + )"; + BOOST_CHECK(expectError(text, true) == Error::Type::Warning); +} + +BOOST_AUTO_TEST_CASE(unused_return_value_delegatecall) +{ + char const* text = R"( + contract test { + function f() { + address(0x12).delegatecall("abc"); + } + } + )"; + BOOST_CHECK(expectError(text, true) == Error::Type::Warning); +} + BOOST_AUTO_TEST_SUITE_END() } |