solidity/test/libsolidity/smtCheckerTests/modifiers/modifier_code_after_placeholder.sol

25 lines
608 B
Solidity
Raw Normal View History

2019-03-11 20:06:28 +00:00
pragma experimental SMTChecker;
contract C
{
uint x;
modifier m {
require(x > 0);
_;
// Fails because of overflow behavior.
assert(x > 1);
}
function f() m public {
assert(x > 0);
2020-12-16 17:32:34 +00:00
unchecked { x = x + 1; }
2019-03-11 20:06:28 +00:00
}
function g(uint _x) public {
x = _x;
}
2019-03-11 20:06:28 +00:00
}
// ----
2021-01-06 15:06:15 +00:00
// Warning 6328: (136-149): CHC: Assertion violation happens here.\nCounterexample:\nx = 0\n\nTransaction trace:\nC.constructor()\nState: x = 0\nC.g(115792089237316195423570985008687907853269984665640564039457584007913129639935)\nState: x = 115792089237316195423570985008687907853269984665640564039457584007913129639935\nC.f()