aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorLu Guanqun <guanqun.lu@gmail.com>2015-02-28 16:10:19 +0800
committerLu Guanqun <guanqun.lu@gmail.com>2015-03-08 22:48:53 +0800
commita1eed074329d2b3987b7ce105b5b50a174263da8 (patch)
tree09ba96d0e03fa381614c2b577e265c9fae24e370
parent52e9a85d6286ab4bfe439908400e82d191dd87b1 (diff)
downloaddexon-solidity-a1eed074329d2b3987b7ce105b5b50a174263da8.tar
dexon-solidity-a1eed074329d2b3987b7ce105b5b50a174263da8.tar.gz
dexon-solidity-a1eed074329d2b3987b7ce105b5b50a174263da8.tar.bz2
dexon-solidity-a1eed074329d2b3987b7ce105b5b50a174263da8.tar.lz
dexon-solidity-a1eed074329d2b3987b7ce105b5b50a174263da8.tar.xz
dexon-solidity-a1eed074329d2b3987b7ce105b5b50a174263da8.tar.zst
dexon-solidity-a1eed074329d2b3987b7ce105b5b50a174263da8.zip
add two parsing test cases related to overloaded functions
-rw-r--r--SolidityParser.cpp25
1 files changed, 25 insertions, 0 deletions
diff --git a/SolidityParser.cpp b/SolidityParser.cpp
index 88b86e63..414ac525 100644
--- a/SolidityParser.cpp
+++ b/SolidityParser.cpp
@@ -126,6 +126,31 @@ BOOST_AUTO_TEST_CASE(missing_argument_in_named_args)
BOOST_CHECK_THROW(parseText(text), ParserError);
}
+BOOST_AUTO_TEST_CASE(two_exact_functions)
+{
+ char const* text = R"(
+ contract test {
+ function fun(uint a) returns(uint r) { return a; }
+ function fun(uint a) returns(uint r) { return a; }
+ }
+ )";
+ // with support of overloaded functions, during parsing,
+ // we can't determine whether they match exactly, however
+ // it will throw DeclarationError in following stage.
+ BOOST_CHECK_NO_THROW(parseText(text));
+}
+
+BOOST_AUTO_TEST_CASE(overloaded_functions)
+{
+ char const* text = R"(
+ contract test {
+ function fun(uint a) returns(uint r) { return a; }
+ function fun(uint a, uint b) returns(uint r) { return a + b; }
+ }
+ )";
+ BOOST_CHECK_NO_THROW(parseText(text));
+}
+
BOOST_AUTO_TEST_CASE(function_natspec_documentation)
{
ASTPointer<ContractDefinition> contract;