diff options
author | chriseth <chris@ethereum.org> | 2018-03-13 23:50:38 +0800 |
---|---|---|
committer | chriseth <chris@ethereum.org> | 2018-03-13 23:55:41 +0800 |
commit | 51f9e350b152483968391757155189ed0880c755 (patch) | |
tree | 99c371ce089bd4c1e57fa9ab7e1f30df06bfd0e1 | |
parent | 58af150c3dce26206825122d048e4e0732fcb50f (diff) | |
download | dexon-solidity-51f9e350b152483968391757155189ed0880c755.tar dexon-solidity-51f9e350b152483968391757155189ed0880c755.tar.gz dexon-solidity-51f9e350b152483968391757155189ed0880c755.tar.bz2 dexon-solidity-51f9e350b152483968391757155189ed0880c755.tar.lz dexon-solidity-51f9e350b152483968391757155189ed0880c755.tar.xz dexon-solidity-51f9e350b152483968391757155189ed0880c755.tar.zst dexon-solidity-51f9e350b152483968391757155189ed0880c755.zip |
Tests.
-rw-r--r-- | test/libsolidity/SolidityEndToEndTest.cpp | 52 |
1 files changed, 52 insertions, 0 deletions
diff --git a/test/libsolidity/SolidityEndToEndTest.cpp b/test/libsolidity/SolidityEndToEndTest.cpp index 33cd1419..282136f7 100644 --- a/test/libsolidity/SolidityEndToEndTest.cpp +++ b/test/libsolidity/SolidityEndToEndTest.cpp @@ -2879,6 +2879,58 @@ BOOST_AUTO_TEST_CASE(function_modifier_multiple_times_local_vars) ABI_CHECK(callContractFunction("a()"), encodeArgs(0)); } +BOOST_AUTO_TEST_CASE(function_modifier_library) +{ + char const* sourceCode = R"( + library L { + struct S { uint v; } + modifier mod(S storage s) { s.v++; _; } + function libFun(S storage s) mod(s) internal { s.v += 0x100; } + } + + contract Test { + using L for *; + L.S s; + + function f() public returns (uint) { + s.libFun(); + L.libFun(s); + return s.v; + } + } + )"; + compileAndRun(sourceCode); + ABI_CHECK(callContractFunction("f()"), encodeArgs(0x202)); +} + +BOOST_AUTO_TEST_CASE(function_modifier_library_inheritance) +{ + // Tests that virtual lookup for modifiers in libraries does not consider + // the current inheritance hierarchy. + + char const* sourceCode = R"( + library L { + struct S { uint v; } + modifier mod(S storage s) { s.v++; _; } + function libFun(S storage s) mod(s) internal { s.v += 0x100; } + } + + contract Test { + using L for *; + L.S s; + modifier mod(L.S storage) { revert(); _; } + + function f() public returns (uint) { + s.libFun(); + L.libFun(s); + return s.v; + } + } + )"; + compileAndRun(sourceCode); + ABI_CHECK(callContractFunction("f()"), encodeArgs(0x202)); +} + BOOST_AUTO_TEST_CASE(crazy_elementary_typenames_on_stack) { char const* sourceCode = R"( |