aboutsummaryrefslogtreecommitdiffstats
path: root/test
diff options
context:
space:
mode:
authorDaniel Kirchner <daniel@ekpyron.org>2019-01-15 20:40:10 +0800
committerDaniel Kirchner <daniel@ekpyron.org>2019-01-15 23:32:21 +0800
commit4c8f8e949143d0c680a8257adbcc768d908fae9a (patch)
treecbaea6e325d355e4050f084936497a0816bb5bcc /test
parentf9ca5b78fb41c18fe0b538d0be909c9026269fbd (diff)
downloaddexon-solidity-4c8f8e949143d0c680a8257adbcc768d908fae9a.tar
dexon-solidity-4c8f8e949143d0c680a8257adbcc768d908fae9a.tar.gz
dexon-solidity-4c8f8e949143d0c680a8257adbcc768d908fae9a.tar.bz2
dexon-solidity-4c8f8e949143d0c680a8257adbcc768d908fae9a.tar.lz
dexon-solidity-4c8f8e949143d0c680a8257adbcc768d908fae9a.tar.xz
dexon-solidity-4c8f8e949143d0c680a8257adbcc768d908fae9a.tar.zst
dexon-solidity-4c8f8e949143d0c680a8257adbcc768d908fae9a.zip
Disallow mismatching types in switch cases and detect duplicates by value for number literals.
Diffstat (limited to 'test')
-rw-r--r--test/libsolidity/InlineAssembly.cpp2
-rw-r--r--test/libyul/Parser.cpp13
2 files changed, 14 insertions, 1 deletions
diff --git a/test/libsolidity/InlineAssembly.cpp b/test/libsolidity/InlineAssembly.cpp
index b6986041..92e4dcf6 100644
--- a/test/libsolidity/InlineAssembly.cpp
+++ b/test/libsolidity/InlineAssembly.cpp
@@ -316,7 +316,7 @@ BOOST_AUTO_TEST_CASE(switch_no_cases)
BOOST_AUTO_TEST_CASE(switch_duplicate_case)
{
- CHECK_PARSE_ERROR("{ switch 42 case 1 {} case 1 {} default {} }", DeclarationError, "Duplicate case defined");
+ CHECK_PARSE_ERROR("{ switch 42 case 1 {} case 1 {} default {} }", DeclarationError, "Duplicate case defined.");
}
BOOST_AUTO_TEST_CASE(switch_invalid_expression)
diff --git a/test/libyul/Parser.cpp b/test/libyul/Parser.cpp
index 897f18ae..84f5c14b 100644
--- a/test/libyul/Parser.cpp
+++ b/test/libyul/Parser.cpp
@@ -304,6 +304,19 @@ BOOST_AUTO_TEST_CASE(if_statement_invalid)
BOOST_CHECK(successParse("{ if 42:u256 { } }"));
}
+BOOST_AUTO_TEST_CASE(switch_case_types)
+{
+ CHECK_ERROR("{ switch 0:u256 case 0:u256 {} case 1:u32 {} }", TypeError, "Switch cases have non-matching types.");
+ // The following should be an error in the future, but this is not yet detected.
+ BOOST_CHECK(successParse("{ switch 0:u256 case 0:u32 {} case 1:u32 {} }"));
+}
+
+BOOST_AUTO_TEST_CASE(switch_duplicate_case)
+{
+ CHECK_ERROR("{ switch 0:u256 case 0:u256 {} case 0x0:u256 {} }", DeclarationError, "Duplicate case defined.");
+ BOOST_CHECK(successParse("{ switch 0:u256 case 42:u256 {} case 0x42:u256 {} }"));
+}
+
BOOST_AUTO_TEST_CASE(builtins_parser)
{
struct SimpleDialect: public Dialect