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

28 lines
743 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.
2023-02-09 16:07:13 +00:00
// Info 1391: CHC: 3 verification condition(s) proved safe! Enable the model checker option "show proved safe" to see all of them.
2021-08-23 09:30:12 +00:00
// Warning 1236: (87-100): BMC: Insufficient funds happens here.