aboutsummaryrefslogtreecommitdiffstats
path: root/SolidityNameAndTypeResolution.cpp
diff options
context:
space:
mode:
authorLefteris Karapetsas <lefteris@refu.co>2015-04-02 22:56:12 +0800
committerLefteris Karapetsas <lefteris@refu.co>2015-04-17 21:27:31 +0800
commita063e1c5a128cdd986c9a2f9000f4dc063f956dd (patch)
treed019644d53bd5d783a4b131b6d7a099910679393 /SolidityNameAndTypeResolution.cpp
parentf2f0aec91c6b66a8cd5fdc2dae78debd1f4b097a (diff)
downloaddexon-solidity-a063e1c5a128cdd986c9a2f9000f4dc063f956dd.tar
dexon-solidity-a063e1c5a128cdd986c9a2f9000f4dc063f956dd.tar.gz
dexon-solidity-a063e1c5a128cdd986c9a2f9000f4dc063f956dd.tar.bz2
dexon-solidity-a063e1c5a128cdd986c9a2f9000f4dc063f956dd.tar.lz
dexon-solidity-a063e1c5a128cdd986c9a2f9000f4dc063f956dd.tar.xz
dexon-solidity-a063e1c5a128cdd986c9a2f9000f4dc063f956dd.tar.zst
dexon-solidity-a063e1c5a128cdd986c9a2f9000f4dc063f956dd.zip
Check all constructors in inheritance chain get args
- Also add a missing override in a function of EnumValue
Diffstat (limited to 'SolidityNameAndTypeResolution.cpp')
-rw-r--r--SolidityNameAndTypeResolution.cpp19
1 files changed, 19 insertions, 0 deletions
diff --git a/SolidityNameAndTypeResolution.cpp b/SolidityNameAndTypeResolution.cpp
index caca8b04..c1a274b0 100644
--- a/SolidityNameAndTypeResolution.cpp
+++ b/SolidityNameAndTypeResolution.cpp
@@ -421,6 +421,25 @@ BOOST_AUTO_TEST_CASE(abstract_contract_constructor_args_optional)
ETH_TEST_REQUIRE_NO_THROW(parseTextAndResolveNames(text), "Parsing and name resolving failed");
}
+BOOST_AUTO_TEST_CASE(abstract_contract_constructor_args_not_provided)
+{
+ ASTPointer<SourceUnit> sourceUnit;
+ char const* text = R"(
+ contract BaseBase { function BaseBase(uint j); }
+ contract base is BaseBase { function foo(); }
+ contract derived is base {
+ function derived(uint i) {}
+ function foo() {}
+ }
+ )";
+ ETH_TEST_REQUIRE_NO_THROW(sourceUnit = parseTextAndResolveNames(text), "Parsing and name resolving failed");
+ std::vector<ASTPointer<ASTNode>> nodes = sourceUnit->getNodes();
+ BOOST_CHECK_EQUAL(nodes.size(), 3);
+ ContractDefinition* derived = dynamic_cast<ContractDefinition*>(nodes[2].get());
+ BOOST_CHECK(derived);
+ BOOST_CHECK(!derived->isFullyImplemented());
+}
+
BOOST_AUTO_TEST_CASE(redeclare_implemented_abstract_function_as_abstract)
{
ASTPointer<SourceUnit> sourceUnit;