aboutsummaryrefslogtreecommitdiffstats
path: root/test
diff options
context:
space:
mode:
authorchriseth <chris@ethereum.org>2017-06-19 18:00:04 +0800
committerGitHub <noreply@github.com>2017-06-19 18:00:04 +0800
commitb3a7b5a145ba66e5ce99c04cc99418e995543355 (patch)
treea8149862e6a8e009948e9b37af1deb6fdf8f7ca0 /test
parent0c75afb2c1b9c8e81295c76aa1caa2a48b239aaf (diff)
parentd170ceaf3d8f63536a730ccc6388183a7a483514 (diff)
downloaddexon-solidity-b3a7b5a145ba66e5ce99c04cc99418e995543355.tar.gz
dexon-solidity-b3a7b5a145ba66e5ce99c04cc99418e995543355.tar.zst
dexon-solidity-b3a7b5a145ba66e5ce99c04cc99418e995543355.zip
Merge pull request #2416 from federicobond/multiple-specifiers
Display error if payable or constant is specified multiple times
Diffstat (limited to 'test')
-rw-r--r--test/libsolidity/SolidityParser.cpp18
1 files changed, 18 insertions, 0 deletions
diff --git a/test/libsolidity/SolidityParser.cpp b/test/libsolidity/SolidityParser.cpp
index 27231b9b..78edd4d1 100644
--- a/test/libsolidity/SolidityParser.cpp
+++ b/test/libsolidity/SolidityParser.cpp
@@ -901,6 +901,24 @@ BOOST_AUTO_TEST_CASE(multiple_visibility_specifiers)
CHECK_PARSE_ERROR(text, "Visibility already specified");
}
+BOOST_AUTO_TEST_CASE(multiple_payable_specifiers)
+{
+ char const* text = R"(
+ contract c {
+ function f() payable payable {}
+ })";
+ CHECK_PARSE_ERROR(text, "Multiple \"payable\" specifiers.");
+}
+
+BOOST_AUTO_TEST_CASE(multiple_constant_specifiers)
+{
+ char const* text = R"(
+ contract c {
+ function f() constant constant {}
+ })";
+ CHECK_PARSE_ERROR(text, "Multiple \"constant\" specifiers.");
+}
+
BOOST_AUTO_TEST_CASE(literal_constants_with_ether_subdenominations)
{
char const* text = R"(