diff options
author | Lefteris Karapetsas <lefteris@refu.co> | 2015-04-02 22:56:12 +0800 |
---|---|---|
committer | Lefteris Karapetsas <lefteris@refu.co> | 2015-04-17 21:27:31 +0800 |
commit | a063e1c5a128cdd986c9a2f9000f4dc063f956dd (patch) | |
tree | d019644d53bd5d783a4b131b6d7a099910679393 /SolidityNameAndTypeResolution.cpp | |
parent | f2f0aec91c6b66a8cd5fdc2dae78debd1f4b097a (diff) | |
download | dexon-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.cpp | 19 |
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; |