|
@ -21,6 +21,7 @@ |
|
|
*/ |
|
|
*/ |
|
|
|
|
|
|
|
|
#include "../TestHelper.h" |
|
|
#include "../TestHelper.h" |
|
|
|
|
|
#include <string> |
|
|
#include <json/json.h> |
|
|
#include <json/json.h> |
|
|
#include <libsolidity/CompilerStack.h> |
|
|
#include <libsolidity/CompilerStack.h> |
|
|
#include <libsolidity/Exceptions.h> |
|
|
#include <libsolidity/Exceptions.h> |
|
@ -38,9 +39,11 @@ class DocumentationChecker |
|
|
public: |
|
|
public: |
|
|
DocumentationChecker(): m_compilerStack(false) {} |
|
|
DocumentationChecker(): m_compilerStack(false) {} |
|
|
|
|
|
|
|
|
void checkNatspec(std::string const& _code, |
|
|
void checkNatspec( |
|
|
|
|
|
std::string const& _code, |
|
|
std::string const& _expectedDocumentationString, |
|
|
std::string const& _expectedDocumentationString, |
|
|
bool _userDocumentation) |
|
|
bool _userDocumentation |
|
|
|
|
|
) |
|
|
{ |
|
|
{ |
|
|
std::string generatedDocumentationString; |
|
|
std::string generatedDocumentationString; |
|
|
ETH_TEST_REQUIRE_NO_THROW(m_compilerStack.parse(_code), "Parsing failed"); |
|
|
ETH_TEST_REQUIRE_NO_THROW(m_compilerStack.parse(_code), "Parsing failed"); |
|
@ -53,9 +56,11 @@ public: |
|
|
m_reader.parse(generatedDocumentationString, generatedDocumentation); |
|
|
m_reader.parse(generatedDocumentationString, generatedDocumentation); |
|
|
Json::Value expectedDocumentation; |
|
|
Json::Value expectedDocumentation; |
|
|
m_reader.parse(_expectedDocumentationString, expectedDocumentation); |
|
|
m_reader.parse(_expectedDocumentationString, expectedDocumentation); |
|
|
BOOST_CHECK_MESSAGE(expectedDocumentation == generatedDocumentation, |
|
|
BOOST_CHECK_MESSAGE( |
|
|
|
|
|
expectedDocumentation == generatedDocumentation, |
|
|
"Expected " << _expectedDocumentationString << |
|
|
"Expected " << _expectedDocumentationString << |
|
|
"\n but got:\n" << generatedDocumentationString); |
|
|
"\n but got:\n" << generatedDocumentationString |
|
|
|
|
|
); |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
private: |
|
|
private: |
|
@ -229,18 +234,6 @@ BOOST_AUTO_TEST_CASE(dev_multiple_params) |
|
|
checkNatspec(sourceCode, natspec, false); |
|
|
checkNatspec(sourceCode, natspec, false); |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(dev_documenting_nonexistant_param) |
|
|
|
|
|
{ |
|
|
|
|
|
char const* sourceCode = "contract test {\n" |
|
|
|
|
|
" /// @dev Multiplies a number by 7 and adds second parameter\n" |
|
|
|
|
|
" /// @param a Documentation for the first parameter\n" |
|
|
|
|
|
" /// @param not_existing Documentation for the second parameter\n" |
|
|
|
|
|
" function mul(uint a, uint second) returns(uint d) { return a * 7 + second; }\n" |
|
|
|
|
|
"}\n"; |
|
|
|
|
|
|
|
|
|
|
|
BOOST_CHECK_THROW(checkNatspec(sourceCode, "", false), DocstringParsingError); |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(dev_mutiline_param_description) |
|
|
BOOST_AUTO_TEST_CASE(dev_mutiline_param_description) |
|
|
{ |
|
|
{ |
|
|
char const* sourceCode = "contract test {\n" |
|
|
char const* sourceCode = "contract test {\n" |
|
@ -488,46 +481,48 @@ BOOST_AUTO_TEST_CASE(dev_author_at_function) |
|
|
checkNatspec(sourceCode, natspec, false); |
|
|
checkNatspec(sourceCode, natspec, false); |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(dev_title_at_function_error) |
|
|
|
|
|
{ |
|
|
|
|
|
char const* sourceCode = " /// @author Lefteris\n" |
|
|
|
|
|
" /// @title Just a test contract\n" |
|
|
|
|
|
"contract test {\n" |
|
|
|
|
|
" /// @dev Mul function\n" |
|
|
|
|
|
" /// @title I really should not be here\n" |
|
|
|
|
|
" function mul(uint a, uint second) returns(uint d) { return a * 7 + second; }\n" |
|
|
|
|
|
"}\n"; |
|
|
|
|
|
|
|
|
|
|
|
BOOST_CHECK_THROW(checkNatspec(sourceCode, "", false), DocstringParsingError); |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(natspec_notice_without_tag) |
|
|
BOOST_AUTO_TEST_CASE(natspec_notice_without_tag) |
|
|
{ |
|
|
{ |
|
|
char const* sourceCode = "contract test {\n" |
|
|
char const* sourceCode = R"( |
|
|
" /// I do something awesome\n" |
|
|
contract test { |
|
|
" function mul(uint a) returns(uint d) { return a * 7; }\n" |
|
|
/// I do something awesome
|
|
|
"}\n"; |
|
|
function mul(uint a) returns(uint d) { return a * 7; } |
|
|
|
|
|
} |
|
|
|
|
|
)"; |
|
|
|
|
|
|
|
|
char const* natspec = "{" |
|
|
|
|
|
"\"methods\":{" |
|
|
char const* natspec = R"ABCDEF( |
|
|
" \"mul(uint256)\":{ \"notice\": \"I do something awesome\"}" |
|
|
{ |
|
|
"}}"; |
|
|
"methods" : { |
|
|
|
|
|
"mul(uint256)" : { |
|
|
|
|
|
"notice" : "I do something awesome" |
|
|
|
|
|
} |
|
|
|
|
|
} |
|
|
|
|
|
} |
|
|
|
|
|
)ABCDEF"; |
|
|
|
|
|
|
|
|
checkNatspec(sourceCode, natspec, true); |
|
|
checkNatspec(sourceCode, natspec, true); |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(natspec_multiline_notice_without_tag) |
|
|
BOOST_AUTO_TEST_CASE(natspec_multiline_notice_without_tag) |
|
|
{ |
|
|
{ |
|
|
char const* sourceCode = "contract test {\n" |
|
|
char const* sourceCode = R"( |
|
|
" /// I do something awesome\n" |
|
|
contract test { |
|
|
" /// which requires two lines to explain\n" |
|
|
/// I do something awesome
|
|
|
" function mul(uint a) returns(uint d) { return a * 7; }\n" |
|
|
/// which requires two lines to explain
|
|
|
"}\n"; |
|
|
function mul(uint a) returns(uint d) { return a * 7; } |
|
|
|
|
|
} |
|
|
|
|
|
)"; |
|
|
|
|
|
|
|
|
char const* natspec = "{" |
|
|
char const* natspec = R"ABCDEF( |
|
|
"\"methods\":{" |
|
|
{ |
|
|
" \"mul(uint256)\":{ \"notice\": \"I do something awesome which requires two lines to explain\"}" |
|
|
"methods" : { |
|
|
"}}"; |
|
|
"mul(uint256)" : { |
|
|
|
|
|
"notice" : "I do something awesome which requires two lines to explain" |
|
|
|
|
|
} |
|
|
|
|
|
} |
|
|
|
|
|
} |
|
|
|
|
|
)ABCDEF"; |
|
|
|
|
|
|
|
|
checkNatspec(sourceCode, natspec, true); |
|
|
checkNatspec(sourceCode, natspec, true); |
|
|
} |
|
|
} |
|
|