solidity/test/libsolidity/smtCheckerTests/blockchain_state/library_internal_2.sol

28 lines
668 B
Solidity
Raw Normal View History

library L {
function l(address payable a) internal {
2021-08-23 09:30:12 +00:00
require(a != address(this));
a.transfer(1);
}
}
contract C {
using L for address payable;
uint x;
function f(address payable a) public payable {
require(msg.value > 1);
uint b1 = address(this).balance;
a.l();
uint b2 = address(this).balance;
assert(b1 == b2); // should fail
2021-08-23 09:30:12 +00:00
assert(b1 == b2 + 1); // should hold
assert(x == 0); // should hold
}
}
// ====
// SMTEngine: all
2021-08-23 09:30:12 +00:00
// SMTIgnoreCex: yes
// ----
2021-08-23 09:30:12 +00:00
// Warning 6328: (315-331): CHC: Assertion violation happens here.
2021-10-06 09:53:03 +00:00
// Info 1180: Contract invariant(s) for :C:\n(x <= 0)\n
2021-08-23 09:30:12 +00:00
// Warning 1236: (87-100): BMC: Insufficient funds happens here.