aboutsummaryrefslogtreecommitdiffstats
path: root/test/libsolidity/SyntaxTest.cpp
diff options
context:
space:
mode:
authorchriseth <chris@ethereum.org>2018-03-16 00:03:43 +0800
committerGitHub <noreply@github.com>2018-03-16 00:03:43 +0800
commit9e1095608d265ac941afbf1e4ed4c79d63a15926 (patch)
tree1950350b746bd820cdf0617ad802dcf548d69738 /test/libsolidity/SyntaxTest.cpp
parent3f1e0d8434b477b7123a7e72655aa6e76c2c53a9 (diff)
parent50ad89d369a3ffd90471b2738f2f30491841e197 (diff)
downloaddexon-solidity-9e1095608d265ac941afbf1e4ed4c79d63a15926.tar
dexon-solidity-9e1095608d265ac941afbf1e4ed4c79d63a15926.tar.gz
dexon-solidity-9e1095608d265ac941afbf1e4ed4c79d63a15926.tar.bz2
dexon-solidity-9e1095608d265ac941afbf1e4ed4c79d63a15926.tar.lz
dexon-solidity-9e1095608d265ac941afbf1e4ed4c79d63a15926.tar.xz
dexon-solidity-9e1095608d265ac941afbf1e4ed4c79d63a15926.tar.zst
dexon-solidity-9e1095608d265ac941afbf1e4ed4c79d63a15926.zip
Merge pull request #3709 from ethereum/syntaxTestsInteractiveTool
Interactive syntax test tool.
Diffstat (limited to 'test/libsolidity/SyntaxTest.cpp')
-rw-r--r--test/libsolidity/SyntaxTest.cpp62
1 files changed, 49 insertions, 13 deletions
diff --git a/test/libsolidity/SyntaxTest.cpp b/test/libsolidity/SyntaxTest.cpp
index 45a851b6..acfdff29 100644
--- a/test/libsolidity/SyntaxTest.cpp
+++ b/test/libsolidity/SyntaxTest.cpp
@@ -27,6 +27,7 @@
using namespace dev;
using namespace solidity;
using namespace dev::solidity::test;
+using namespace dev::solidity::test::formatting;
using namespace std;
namespace fs = boost::filesystem;
using namespace boost::unit_test;
@@ -56,41 +57,76 @@ SyntaxTest::SyntaxTest(string const& _filename)
m_expectations = parseExpectations(file);
}
-bool SyntaxTest::run(ostream& _stream, string const& _indent)
+bool SyntaxTest::run(ostream& _stream, string const& _linePrefix, bool const _formatted)
{
m_errorList = parseAnalyseAndReturnError(m_source, true, true, true).second;
if (!matchesExpectations(m_errorList))
{
- std::string nextIndentLevel = _indent + "\t";
- _stream << _indent << "Expected result:" << endl;
- printExpected(_stream, nextIndentLevel);
- _stream << _indent << "Obtained result:\n";
- printErrorList(_stream, m_errorList, nextIndentLevel);
+ std::string nextIndentLevel = _linePrefix + " ";
+ FormattedScope(_stream, _formatted, {BOLD, CYAN}) << _linePrefix << "Expected result:" << endl;
+ printExpected(_stream, nextIndentLevel, _formatted);
+ FormattedScope(_stream, _formatted, {BOLD, CYAN}) << _linePrefix << "Obtained result:\n";
+ printErrorList(_stream, m_errorList, nextIndentLevel, false, false, _formatted);
return false;
}
return true;
}
-void SyntaxTest::printExpected(ostream& _stream, string const& _indent) const
+void SyntaxTest::printExpected(ostream& _stream, string const& _linePrefix, bool const _formatted) const
{
if (m_expectations.empty())
- _stream << _indent << "Success" << endl;
+ FormattedScope(_stream, _formatted, {BOLD, GREEN}) << _linePrefix << "Success" << endl;
else
for (auto const& expectation: m_expectations)
- _stream << _indent << expectation.type << ": " << expectation.message << endl;
+ {
+ FormattedScope(_stream, _formatted, {BOLD, expectation.type == "Warning" ? YELLOW : RED}) <<
+ _linePrefix << expectation.type << ": ";
+ _stream << expectation.message << endl;
+ }
}
void SyntaxTest::printErrorList(
ostream& _stream,
ErrorList const& _errorList,
- string const& _indent
+ string const& _linePrefix,
+ bool const _ignoreWarnings,
+ bool const _lineNumbers,
+ bool const _formatted
) const
{
if (_errorList.empty())
- _stream << _indent << "Success" << endl;
+ FormattedScope(_stream, _formatted, {BOLD, GREEN}) << _linePrefix << "Success" << endl;
else
for (auto const& error: _errorList)
- _stream << _indent << error->typeName() << ": " << errorMessage(*error) << endl;
+ {
+ bool isWarning = (error->type() == Error::Type::Warning);
+ if (isWarning && _ignoreWarnings) continue;
+
+ {
+ FormattedScope scope(_stream, _formatted, {BOLD, isWarning ? YELLOW : RED});
+ _stream << _linePrefix;
+ if (_lineNumbers)
+ {
+ int line = offsetToLineNumber(
+ boost::get_error_info<errinfo_sourceLocation>(*error)->start
+ );
+ if (line >= 0)
+ _stream << "(" << line << "): ";
+ }
+ _stream << error->typeName() << ": ";
+ }
+ _stream << errorMessage(*error) << endl;
+ }
+}
+
+int SyntaxTest::offsetToLineNumber(int _location) const
+{
+ // parseAnalyseAndReturnError(...) prepends a version pragma
+ _location -= strlen("pragma solidity >=0.0;\n");
+ if (_location < 0 || static_cast<size_t>(_location) >= m_source.size())
+ return -1;
+ else
+ return 1 + std::count(m_source.begin(), m_source.begin() + _location, '\n');
}
bool SyntaxTest::matchesExpectations(ErrorList const& _errorList) const
@@ -196,7 +232,7 @@ int SyntaxTest::registerTests(
[fullpath]
{
std::stringstream errorStream;
- if (!SyntaxTest(fullpath.string()).run(errorStream, ""))
+ if (!SyntaxTest(fullpath.string()).run(errorStream))
BOOST_ERROR("Test expectation mismatch.\n" + errorStream.str());
},
_path.stem().string(),