Browse Source

Test for the Canonical Signature of a function

cl-refactor
Lefteris Karapetsas 10 years ago
parent
commit
0c83932d91
  1. 1
      libsolidity/AST.cpp
  2. 21
      test/SolidityNameAndTypeResolution.cpp

1
libsolidity/AST.cpp

@ -122,6 +122,7 @@ std::string FunctionDefinition::getCanonicalSignature()
if (i != parameters.size()) {
ret += ",";
}
i++;
}
ret += ")";
return ret;

21
test/SolidityNameAndTypeResolution.cpp

@ -38,7 +38,7 @@ namespace test
namespace
{
void parseTextAndResolveNames(std::string const& _source)
ASTPointer<SourceUnit> parseTextAndResolveNames(std::string const& _source)
{
Parser parser;
ASTPointer<SourceUnit> sourceUnit = parser.parse(std::make_shared<Scanner>(CharStream(_source)));
@ -50,6 +50,8 @@ void parseTextAndResolveNames(std::string const& _source)
for (ASTPointer<ASTNode> const& node: sourceUnit->getNodes())
if (ContractDefinition* contract = dynamic_cast<ContractDefinition*>(node.get()))
resolver.checkTypeRequirements(*contract);
return sourceUnit;
}
}
@ -321,6 +323,23 @@ BOOST_AUTO_TEST_CASE(comparison_bitop_precedence)
BOOST_CHECK_NO_THROW(parseTextAndResolveNames(text));
}
BOOST_AUTO_TEST_CASE(function_canonical_signature)
{
ASTPointer<SourceUnit> sourceUnit;
char const* text = "contract Test {\n"
" function foo(uint256 arg1, uint64 arg2, bool arg3) returns (uint256 ret) {\n"
" ret = arg1 + arg2;\n"
" }\n"
"}\n";
BOOST_CHECK_NO_THROW(sourceUnit = parseTextAndResolveNames(text));
for (ASTPointer<ASTNode> const& node: sourceUnit->getNodes())
if (ContractDefinition* contract = dynamic_cast<ContractDefinition*>(node.get()))
{
auto functions = contract->getDefinedFunctions();
BOOST_ASSERT("foo(uint256,uint64,bool)" == functions[0]->getCanonicalSignature());
}
}
BOOST_AUTO_TEST_SUITE_END()
}

Loading…
Cancel
Save