mirror of
https://github.com/ethereum/solidity
synced 2023-10-03 13:03:40 +00:00
Fix version pragmas in tests.
This commit is contained in:
parent
d87450b9b2
commit
459d2dd7cd
@ -39,7 +39,7 @@ namespace
|
|||||||
{
|
{
|
||||||
|
|
||||||
static char const* registrarCode = R"DELIMITER(
|
static char const* registrarCode = R"DELIMITER(
|
||||||
pragma solidity ^0.3.6;
|
pragma solidity ^0.3.5;
|
||||||
|
|
||||||
contract NameRegister {
|
contract NameRegister {
|
||||||
function addr(string _name) constant returns (address o_owner);
|
function addr(string _name) constant returns (address o_owner);
|
||||||
|
@ -52,7 +52,7 @@ static char const* registrarCode = R"DELIMITER(
|
|||||||
// @authors:
|
// @authors:
|
||||||
// Gav Wood <g@ethdev.com>
|
// Gav Wood <g@ethdev.com>
|
||||||
|
|
||||||
pragma solidity ^0.3.6;
|
pragma solidity ^0.3.5;
|
||||||
|
|
||||||
contract Registrar {
|
contract Registrar {
|
||||||
event Changed(string indexed name);
|
event Changed(string indexed name);
|
||||||
|
@ -55,7 +55,7 @@ static char const* walletCode = R"DELIMITER(
|
|||||||
// some number (specified in constructor) of the set of owners (specified in the constructor, modifiable) before the
|
// some number (specified in constructor) of the set of owners (specified in the constructor, modifiable) before the
|
||||||
// interior is executed.
|
// interior is executed.
|
||||||
|
|
||||||
pragma solidity ^0.3.6;
|
pragma solidity ^0.3.5;
|
||||||
|
|
||||||
contract multiowned {
|
contract multiowned {
|
||||||
|
|
||||||
|
@ -46,7 +46,7 @@ public:
|
|||||||
GasMeterTestFramework() { }
|
GasMeterTestFramework() { }
|
||||||
void compile(string const& _sourceCode)
|
void compile(string const& _sourceCode)
|
||||||
{
|
{
|
||||||
m_compiler.setSource("pragma solidity >= 0;" + _sourceCode);
|
m_compiler.setSource("pragma solidity >= 0.0;" + _sourceCode);
|
||||||
ETH_TEST_REQUIRE_NO_THROW(m_compiler.compile(), "Compiling contract failed");
|
ETH_TEST_REQUIRE_NO_THROW(m_compiler.compile(), "Compiling contract failed");
|
||||||
|
|
||||||
AssemblyItems const* items = m_compiler.runtimeAssemblyItems("");
|
AssemblyItems const* items = m_compiler.runtimeAssemblyItems("");
|
||||||
|
@ -39,106 +39,106 @@ BOOST_AUTO_TEST_SUITE(SolidityImports)
|
|||||||
BOOST_AUTO_TEST_CASE(smoke_test)
|
BOOST_AUTO_TEST_CASE(smoke_test)
|
||||||
{
|
{
|
||||||
CompilerStack c;
|
CompilerStack c;
|
||||||
c.addSource("a", "contract C {} pragma solidity >= 0;");
|
c.addSource("a", "contract C {} pragma solidity >=0.0;");
|
||||||
BOOST_CHECK(c.compile());
|
BOOST_CHECK(c.compile());
|
||||||
}
|
}
|
||||||
|
|
||||||
BOOST_AUTO_TEST_CASE(regular_import)
|
BOOST_AUTO_TEST_CASE(regular_import)
|
||||||
{
|
{
|
||||||
CompilerStack c;
|
CompilerStack c;
|
||||||
c.addSource("a", "contract C {} pragma solidity >= 0;");
|
c.addSource("a", "contract C {} pragma solidity >=0.0;");
|
||||||
c.addSource("b", "import \"a\"; contract D is C {} pragma solidity >= 0;");
|
c.addSource("b", "import \"a\"; contract D is C {} pragma solidity >=0.0;");
|
||||||
BOOST_CHECK(c.compile());
|
BOOST_CHECK(c.compile());
|
||||||
}
|
}
|
||||||
|
|
||||||
BOOST_AUTO_TEST_CASE(import_does_not_clutter_importee)
|
BOOST_AUTO_TEST_CASE(import_does_not_clutter_importee)
|
||||||
{
|
{
|
||||||
CompilerStack c;
|
CompilerStack c;
|
||||||
c.addSource("a", "contract C { D d; } pragma solidity >= 0;");
|
c.addSource("a", "contract C { D d; } pragma solidity >=0.0;");
|
||||||
c.addSource("b", "import \"a\"; contract D is C {} pragma solidity >= 0;");
|
c.addSource("b", "import \"a\"; contract D is C {} pragma solidity >=0.0;");
|
||||||
BOOST_CHECK(!c.compile());
|
BOOST_CHECK(!c.compile());
|
||||||
}
|
}
|
||||||
|
|
||||||
BOOST_AUTO_TEST_CASE(import_is_transitive)
|
BOOST_AUTO_TEST_CASE(import_is_transitive)
|
||||||
{
|
{
|
||||||
CompilerStack c;
|
CompilerStack c;
|
||||||
c.addSource("a", "contract C { } pragma solidity >= 0;");
|
c.addSource("a", "contract C { } pragma solidity >=0.0;");
|
||||||
c.addSource("b", "import \"a\"; pragma solidity >= 0;");
|
c.addSource("b", "import \"a\"; pragma solidity >=0.0;");
|
||||||
c.addSource("c", "import \"b\"; contract D is C {} pragma solidity >= 0;");
|
c.addSource("c", "import \"b\"; contract D is C {} pragma solidity >=0.0;");
|
||||||
BOOST_CHECK(c.compile());
|
BOOST_CHECK(c.compile());
|
||||||
}
|
}
|
||||||
|
|
||||||
BOOST_AUTO_TEST_CASE(circular_import)
|
BOOST_AUTO_TEST_CASE(circular_import)
|
||||||
{
|
{
|
||||||
CompilerStack c;
|
CompilerStack c;
|
||||||
c.addSource("a", "import \"b\"; contract C { D d; } pragma solidity >= 0;");
|
c.addSource("a", "import \"b\"; contract C { D d; } pragma solidity >=0.0;");
|
||||||
c.addSource("b", "import \"a\"; contract D { C c; } pragma solidity >= 0;");
|
c.addSource("b", "import \"a\"; contract D { C c; } pragma solidity >=0.0;");
|
||||||
BOOST_CHECK(c.compile());
|
BOOST_CHECK(c.compile());
|
||||||
}
|
}
|
||||||
|
|
||||||
BOOST_AUTO_TEST_CASE(relative_import)
|
BOOST_AUTO_TEST_CASE(relative_import)
|
||||||
{
|
{
|
||||||
CompilerStack c;
|
CompilerStack c;
|
||||||
c.addSource("a", "import \"./dir/b\"; contract A is B {} pragma solidity >= 0;");
|
c.addSource("a", "import \"./dir/b\"; contract A is B {} pragma solidity >=0.0;");
|
||||||
c.addSource("dir/b", "contract B {} pragma solidity >= 0;");
|
c.addSource("dir/b", "contract B {} pragma solidity >=0.0;");
|
||||||
c.addSource("dir/c", "import \"../a\"; contract C is A {} pragma solidity >= 0;");
|
c.addSource("dir/c", "import \"../a\"; contract C is A {} pragma solidity >=0.0;");
|
||||||
BOOST_CHECK(c.compile());
|
BOOST_CHECK(c.compile());
|
||||||
}
|
}
|
||||||
|
|
||||||
BOOST_AUTO_TEST_CASE(relative_import_multiplex)
|
BOOST_AUTO_TEST_CASE(relative_import_multiplex)
|
||||||
{
|
{
|
||||||
CompilerStack c;
|
CompilerStack c;
|
||||||
c.addSource("a", "contract A {} pragma solidity >= 0;");
|
c.addSource("a", "contract A {} pragma solidity >=0.0;");
|
||||||
c.addSource("dir/a/b/c", "import \"../../.././a\"; contract B is A {} pragma solidity >= 0;");
|
c.addSource("dir/a/b/c", "import \"../../.././a\"; contract B is A {} pragma solidity >=0.0;");
|
||||||
BOOST_CHECK(c.compile());
|
BOOST_CHECK(c.compile());
|
||||||
}
|
}
|
||||||
|
|
||||||
BOOST_AUTO_TEST_CASE(simple_alias)
|
BOOST_AUTO_TEST_CASE(simple_alias)
|
||||||
{
|
{
|
||||||
CompilerStack c;
|
CompilerStack c;
|
||||||
c.addSource("a", "contract A {} pragma solidity >= 0;");
|
c.addSource("a", "contract A {} pragma solidity >=0.0;");
|
||||||
c.addSource("dir/a/b/c", "import \"../../.././a\" as x; contract B is x.A { function() { x.A r = x.A(20); } } pragma solidity >= 0;");
|
c.addSource("dir/a/b/c", "import \"../../.././a\" as x; contract B is x.A { function() { x.A r = x.A(20); } } pragma solidity >=0.0;");
|
||||||
BOOST_CHECK(c.compile());
|
BOOST_CHECK(c.compile());
|
||||||
}
|
}
|
||||||
|
|
||||||
BOOST_AUTO_TEST_CASE(library_name_clash)
|
BOOST_AUTO_TEST_CASE(library_name_clash)
|
||||||
{
|
{
|
||||||
CompilerStack c;
|
CompilerStack c;
|
||||||
c.addSource("a", "library A {} pragma solidity >= 0;");
|
c.addSource("a", "library A {} pragma solidity >=0.0;");
|
||||||
c.addSource("b", "library A {} pragma solidity >= 0;");
|
c.addSource("b", "library A {} pragma solidity >=0.0;");
|
||||||
BOOST_CHECK(!c.compile());
|
BOOST_CHECK(!c.compile());
|
||||||
}
|
}
|
||||||
|
|
||||||
BOOST_AUTO_TEST_CASE(library_name_clash_with_contract)
|
BOOST_AUTO_TEST_CASE(library_name_clash_with_contract)
|
||||||
{
|
{
|
||||||
CompilerStack c;
|
CompilerStack c;
|
||||||
c.addSource("a", "contract A {} pragma solidity >= 0;");
|
c.addSource("a", "contract A {} pragma solidity >=0.0;");
|
||||||
c.addSource("b", "library A {} pragma solidity >= 0;");
|
c.addSource("b", "library A {} pragma solidity >=0.0;");
|
||||||
BOOST_CHECK(c.compile());
|
BOOST_CHECK(c.compile());
|
||||||
}
|
}
|
||||||
|
|
||||||
BOOST_AUTO_TEST_CASE(complex_import)
|
BOOST_AUTO_TEST_CASE(complex_import)
|
||||||
{
|
{
|
||||||
CompilerStack c;
|
CompilerStack c;
|
||||||
c.addSource("a", "contract A {} contract B {} contract C { struct S { uint a; } } pragma solidity >= 0;");
|
c.addSource("a", "contract A {} contract B {} contract C { struct S { uint a; } } pragma solidity >=0.0;");
|
||||||
c.addSource("b", "import \"a\" as x; import {B as b, C as c, C} from \"a\"; "
|
c.addSource("b", "import \"a\" as x; import {B as b, C as c, C} from \"a\"; "
|
||||||
"contract D is b { function f(c.S var1, x.C.S var2, C.S var3) internal {} } pragma solidity >= 0;");
|
"contract D is b { function f(c.S var1, x.C.S var2, C.S var3) internal {} } pragma solidity >=0.0;");
|
||||||
BOOST_CHECK(c.compile());
|
BOOST_CHECK(c.compile());
|
||||||
}
|
}
|
||||||
|
|
||||||
BOOST_AUTO_TEST_CASE(name_clash_in_import)
|
BOOST_AUTO_TEST_CASE(name_clash_in_import)
|
||||||
{
|
{
|
||||||
CompilerStack c;
|
CompilerStack c;
|
||||||
c.addSource("a", "contract A {} pragma solidity >= 0;");
|
c.addSource("a", "contract A {} pragma solidity >=0.0;");
|
||||||
c.addSource("b", "import \"a\"; contract A {} pragma solidity >= 0;");
|
c.addSource("b", "import \"a\"; contract A {} pragma solidity >=0.0;");
|
||||||
BOOST_CHECK(!c.compile());
|
BOOST_CHECK(!c.compile());
|
||||||
c.addSource("b", "import \"a\" as A; contract A {} pragma solidity >= 0;");
|
c.addSource("b", "import \"a\" as A; contract A {} pragma solidity >=0.0;");
|
||||||
BOOST_CHECK(!c.compile());
|
BOOST_CHECK(!c.compile());
|
||||||
c.addSource("b", "import {A as b} from \"a\"; contract b {} pragma solidity >= 0;");
|
c.addSource("b", "import {A as b} from \"a\"; contract b {} pragma solidity >=0.0;");
|
||||||
BOOST_CHECK(!c.compile());
|
BOOST_CHECK(!c.compile());
|
||||||
c.addSource("b", "import {A} from \"a\"; contract A {} pragma solidity >= 0;");
|
c.addSource("b", "import {A} from \"a\"; contract A {} pragma solidity >=0.0;");
|
||||||
BOOST_CHECK(!c.compile());
|
BOOST_CHECK(!c.compile());
|
||||||
c.addSource("b", "import {A} from \"a\"; contract B {} pragma solidity >= 0;");
|
c.addSource("b", "import {A} from \"a\"; contract B {} pragma solidity >=0.0;");
|
||||||
BOOST_CHECK(c.compile());
|
BOOST_CHECK(c.compile());
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -146,10 +146,10 @@ BOOST_AUTO_TEST_CASE(remappings)
|
|||||||
{
|
{
|
||||||
CompilerStack c;
|
CompilerStack c;
|
||||||
c.setRemappings(vector<string>{"s=s_1.4.6", "t=Tee"});
|
c.setRemappings(vector<string>{"s=s_1.4.6", "t=Tee"});
|
||||||
c.addSource("a", "import \"s/s.sol\"; contract A is S {} pragma solidity >= 0;");
|
c.addSource("a", "import \"s/s.sol\"; contract A is S {} pragma solidity >=0.0;");
|
||||||
c.addSource("b", "import \"t/tee.sol\"; contract A is Tee {} pragma solidity >= 0;");
|
c.addSource("b", "import \"t/tee.sol\"; contract A is Tee {} pragma solidity >=0.0;");
|
||||||
c.addSource("s_1.4.6/s.sol", "contract S {} pragma solidity >= 0;");
|
c.addSource("s_1.4.6/s.sol", "contract S {} pragma solidity >=0.0;");
|
||||||
c.addSource("Tee/tee.sol", "contract Tee {} pragma solidity >= 0;");
|
c.addSource("Tee/tee.sol", "contract Tee {} pragma solidity >=0.0;");
|
||||||
BOOST_CHECK(c.compile());
|
BOOST_CHECK(c.compile());
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -157,10 +157,10 @@ BOOST_AUTO_TEST_CASE(context_dependent_remappings)
|
|||||||
{
|
{
|
||||||
CompilerStack c;
|
CompilerStack c;
|
||||||
c.setRemappings(vector<string>{"a:s=s_1.4.6", "b:s=s_1.4.7"});
|
c.setRemappings(vector<string>{"a:s=s_1.4.6", "b:s=s_1.4.7"});
|
||||||
c.addSource("a/a.sol", "import \"s/s.sol\"; contract A is SSix {} pragma solidity >= 0;");
|
c.addSource("a/a.sol", "import \"s/s.sol\"; contract A is SSix {} pragma solidity >=0.0;");
|
||||||
c.addSource("b/b.sol", "import \"s/s.sol\"; contract B is SSeven {} pragma solidity >= 0;");
|
c.addSource("b/b.sol", "import \"s/s.sol\"; contract B is SSeven {} pragma solidity >=0.0;");
|
||||||
c.addSource("s_1.4.6/s.sol", "contract SSix {} pragma solidity >= 0;");
|
c.addSource("s_1.4.6/s.sol", "contract SSix {} pragma solidity >=0.0;");
|
||||||
c.addSource("s_1.4.7/s.sol", "contract SSeven {} pragma solidity >= 0;");
|
c.addSource("s_1.4.7/s.sol", "contract SSeven {} pragma solidity >=0.0;");
|
||||||
BOOST_CHECK(c.compile());
|
BOOST_CHECK(c.compile());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -39,7 +39,7 @@ public:
|
|||||||
|
|
||||||
void checkInterface(std::string const& _code, std::string const& _expectedInterfaceString)
|
void checkInterface(std::string const& _code, std::string const& _expectedInterfaceString)
|
||||||
{
|
{
|
||||||
ETH_TEST_REQUIRE_NO_THROW(m_compilerStack.parse("pragma solidity >=0;\n" + _code), "Parsing contract failed");
|
ETH_TEST_REQUIRE_NO_THROW(m_compilerStack.parse("pragma solidity >=0.0;\n" + _code), "Parsing contract failed");
|
||||||
std::string generatedInterfaceString = m_compilerStack.metadata("", DocumentationType::ABIInterface);
|
std::string generatedInterfaceString = m_compilerStack.metadata("", DocumentationType::ABIInterface);
|
||||||
Json::Value generatedInterface;
|
Json::Value generatedInterface;
|
||||||
m_reader.parse(generatedInterfaceString, generatedInterface);
|
m_reader.parse(generatedInterfaceString, generatedInterface);
|
||||||
|
@ -68,7 +68,7 @@ public:
|
|||||||
)
|
)
|
||||||
{
|
{
|
||||||
// Silence compiler version warning
|
// Silence compiler version warning
|
||||||
std::string sourceCode = "pragma solidity >=0;\n" + _sourceCode;
|
std::string sourceCode = "pragma solidity >=0.0;\n" + _sourceCode;
|
||||||
m_compiler.reset(false);
|
m_compiler.reset(false);
|
||||||
m_compiler.addSource("", sourceCode);
|
m_compiler.addSource("", sourceCode);
|
||||||
if (!m_compiler.compile(m_optimize, m_optimizeRuns))
|
if (!m_compiler.compile(m_optimize, m_optimizeRuns))
|
||||||
|
@ -48,7 +48,7 @@ pair<ASTPointer<SourceUnit>, std::shared_ptr<Error::Type const>>
|
|||||||
parseAnalyseAndReturnError(string const& _source, bool _reportWarnings = false, bool _insertVersionPragma = true)
|
parseAnalyseAndReturnError(string const& _source, bool _reportWarnings = false, bool _insertVersionPragma = true)
|
||||||
{
|
{
|
||||||
// Silence compiler version warning
|
// Silence compiler version warning
|
||||||
string source = _insertVersionPragma ? "pragma solidity >=0;\n" + _source : _source;
|
string source = _insertVersionPragma ? "pragma solidity >=0.0;\n" + _source : _source;
|
||||||
ErrorList errors;
|
ErrorList errors;
|
||||||
Parser parser(errors);
|
Parser parser(errors);
|
||||||
ASTPointer<SourceUnit> sourceUnit;
|
ASTPointer<SourceUnit> sourceUnit;
|
||||||
|
@ -46,7 +46,7 @@ public:
|
|||||||
)
|
)
|
||||||
{
|
{
|
||||||
std::string generatedDocumentationString;
|
std::string generatedDocumentationString;
|
||||||
ETH_TEST_REQUIRE_NO_THROW(m_compilerStack.parse("pragma solidity >=0;\n" + _code), "Parsing failed");
|
ETH_TEST_REQUIRE_NO_THROW(m_compilerStack.parse("pragma solidity >=0.0;\n" + _code), "Parsing failed");
|
||||||
|
|
||||||
if (_userDocumentation)
|
if (_userDocumentation)
|
||||||
generatedDocumentationString = m_compilerStack.metadata("", DocumentationType::NatspecUser);
|
generatedDocumentationString = m_compilerStack.metadata("", DocumentationType::NatspecUser);
|
||||||
|
Loading…
Reference in New Issue
Block a user