aboutsummaryrefslogtreecommitdiffstats
path: root/test
diff options
context:
space:
mode:
authorchriseth <chris@ethereum.org>2017-11-22 23:24:59 +0800
committerchriseth <chris@ethereum.org>2017-11-22 23:27:32 +0800
commit9232cd2621113dac43829b7f0dd37f791526f0b4 (patch)
tree15f0493adc82ae4ad15c29a8fd5646345a0e7f7c /test
parente15918d8b6fd106d147d00d0c3405df88ab39b64 (diff)
downloaddexon-solidity-9232cd2621113dac43829b7f0dd37f791526f0b4.tar
dexon-solidity-9232cd2621113dac43829b7f0dd37f791526f0b4.tar.gz
dexon-solidity-9232cd2621113dac43829b7f0dd37f791526f0b4.tar.bz2
dexon-solidity-9232cd2621113dac43829b7f0dd37f791526f0b4.tar.lz
dexon-solidity-9232cd2621113dac43829b7f0dd37f791526f0b4.tar.xz
dexon-solidity-9232cd2621113dac43829b7f0dd37f791526f0b4.tar.zst
dexon-solidity-9232cd2621113dac43829b7f0dd37f791526f0b4.zip
Tests.
Diffstat (limited to 'test')
-rw-r--r--test/libjulia/Parser.cpp13
-rw-r--r--test/libsolidity/InlineAssembly.cpp16
2 files changed, 29 insertions, 0 deletions
diff --git a/test/libjulia/Parser.cpp b/test/libjulia/Parser.cpp
index f8c1aa4d..473a1d2c 100644
--- a/test/libjulia/Parser.cpp
+++ b/test/libjulia/Parser.cpp
@@ -269,6 +269,19 @@ BOOST_AUTO_TEST_CASE(multiple_assignment)
BOOST_CHECK(successParse(text));
}
+BOOST_AUTO_TEST_CASE(if_statement)
+{
+ BOOST_CHECK(successParse("{ if 42:u256 {} }"));
+ BOOST_CHECK(successParse("{ if 42:u256 { let x:u256 := 3:u256 } }"));
+ BOOST_CHECK(successParse("{ function f() -> x:u256 {} if f() { let b:u256 := f() } }"));
+}
+
+BOOST_AUTO_TEST_CASE(if_statement_invalid)
+{
+ CHECK_ERROR("{ if let x:u256 {} }", ParserError, "Literal or identifier expected.");
+ CHECK_ERROR("{ if 32:u256 let x:u256 := 3:u256 }", ParserError, "Expected token LBrace");
+}
+
BOOST_AUTO_TEST_SUITE_END()
}
diff --git a/test/libsolidity/InlineAssembly.cpp b/test/libsolidity/InlineAssembly.cpp
index 8b7ba3b0..e9fb8431 100644
--- a/test/libsolidity/InlineAssembly.cpp
+++ b/test/libsolidity/InlineAssembly.cpp
@@ -258,6 +258,12 @@ BOOST_AUTO_TEST_CASE(if_statement)
BOOST_CHECK(successParse("{ function f() -> x {} if f() { pop(f()) } }"));
}
+BOOST_AUTO_TEST_CASE(if_statement_scope)
+{
+ BOOST_CHECK(successParse("{ let x := 2 if 42 { x := 3 } }"));
+ CHECK_PARSE_ERROR("{ if 32 { let x := 3 } x := 2 }", DeclarationError, "Variable not found or variable not lvalue.");
+}
+
BOOST_AUTO_TEST_CASE(if_statement_invalid)
{
CHECK_PARSE_ERROR("{ if calldatasize {}", ParserError, "Instructions are not supported as conditions for if");
@@ -502,6 +508,11 @@ BOOST_AUTO_TEST_CASE(print_string_literal_unicode)
parsePrintCompare(parsed);
}
+BOOST_AUTO_TEST_CASE(print_if)
+{
+ parsePrintCompare("{\n if 2\n {\n pop(mload(0))\n }\n}");
+}
+
BOOST_AUTO_TEST_CASE(print_switch)
{
parsePrintCompare("{\n switch 42\n case 1 {\n }\n case 2 {\n }\n default {\n }\n}");
@@ -643,6 +654,11 @@ BOOST_AUTO_TEST_CASE(for_statement)
BOOST_CHECK(successAssemble("{ let x := calldatasize() for { let i := 0} lt(i, x) { i := add(i, 1) } { mstore(i, 2) } }"));
}
+BOOST_AUTO_TEST_CASE(if_statement)
+{
+ BOOST_CHECK(successAssemble("{ if 1 {} }"));
+ BOOST_CHECK(successAssemble("{ let x := 0 if eq(calldatasize(), 0) { x := 1 } mstore(0, x) }"));
+}
BOOST_AUTO_TEST_CASE(large_constant)
{