mirror of
https://github.com/ethereum/solidity
synced 2023-10-03 13:03:40 +00:00
fixed the test
This commit is contained in:
parent
757972b4e3
commit
960033de6b
@ -3910,6 +3910,35 @@ BOOST_AUTO_TEST_CASE(external_types_in_calls)
|
|||||||
BOOST_CHECK(callContractFunction("nonexisting") == encodeArgs(u256(9)));
|
BOOST_CHECK(callContractFunction("nonexisting") == encodeArgs(u256(9)));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
BOOST_AUTO_TEST_CASE(proper_order_of_overwriting_of_attributes)
|
||||||
|
{
|
||||||
|
// bug #1798
|
||||||
|
char const* sourceCode = R"(
|
||||||
|
contract init {
|
||||||
|
function isOk() returns (bool) { return false; }
|
||||||
|
bool public ok = false;
|
||||||
|
}
|
||||||
|
contract fix {
|
||||||
|
function isOk() returns (bool) { return true; }
|
||||||
|
bool public ok = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
contract init_fix is init, fix {
|
||||||
|
function checkOk() returns (bool) { return ok; }
|
||||||
|
}
|
||||||
|
contract fix_init is fix, init {
|
||||||
|
function checkOk() returns (bool) { return ok; }
|
||||||
|
}
|
||||||
|
)";
|
||||||
|
compileAndRun(sourceCode, 0, "init_fix");
|
||||||
|
BOOST_CHECK(callContractFunction("isOk()") == encodeArgs(true));
|
||||||
|
BOOST_CHECK(callContractFunction("ok()") == encodeArgs(true));
|
||||||
|
|
||||||
|
compileAndRun(sourceCode, 0, "fix_init");
|
||||||
|
BOOST_CHECK(callContractFunction("isOk()") == encodeArgs(false));
|
||||||
|
BOOST_CHECK(callContractFunction("ok()") == encodeArgs(false));
|
||||||
|
}
|
||||||
|
|
||||||
BOOST_AUTO_TEST_SUITE_END()
|
BOOST_AUTO_TEST_SUITE_END()
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -1761,25 +1761,6 @@ BOOST_AUTO_TEST_CASE(uninitialized_var)
|
|||||||
BOOST_CHECK_THROW(parseTextAndResolveNames(sourceCode), TypeError);
|
BOOST_CHECK_THROW(parseTextAndResolveNames(sourceCode), TypeError);
|
||||||
}
|
}
|
||||||
|
|
||||||
BOOST_AUTO_TEST_CASE(deny_overwriting_of_attributes_when_deriving)
|
|
||||||
{
|
|
||||||
// bug #1798
|
|
||||||
char const* sourceCode = R"(
|
|
||||||
contract owned {
|
|
||||||
address owner;
|
|
||||||
}
|
|
||||||
|
|
||||||
contract reg {
|
|
||||||
function owner(bytes32 x) returns (address) {}
|
|
||||||
}
|
|
||||||
|
|
||||||
contract x is owned, reg {
|
|
||||||
}
|
|
||||||
)";
|
|
||||||
ETH_TEST_CHECK_NO_THROW(parseTextAndResolveNames(sourceCode), "Parsing and Name Resolving Failed");
|
|
||||||
//BOOST_CHECK_THROW(parseTextAndResolveNames(sourceCode), TypeError);
|
|
||||||
}
|
|
||||||
|
|
||||||
BOOST_AUTO_TEST_SUITE_END()
|
BOOST_AUTO_TEST_SUITE_END()
|
||||||
|
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user