solidity/test/libsolidity/smtCheckerTests/loops/for_1_false_positive.sol

22 lines
550 B
Solidity
Raw Normal View History

2018-11-09 17:50:06 +00:00
pragma experimental SMTChecker;
contract C
{
function f(uint x) public pure {
require(x < 100);
for(uint i = 0; i < 10; ++i) {
// Overflows due to resetting x.
x = x + 1;
}
2019-08-20 13:03:45 +00:00
// Assertion is safe but current solver version cannot solve it.
// Keep test for next solver release.
2018-11-09 17:50:06 +00:00
assert(x > 0);
}
}
// ====
// SMTSolvers: z3
2018-11-09 17:50:06 +00:00
// ----
2019-08-20 13:03:45 +00:00
// Warning: (296-309): Error trying to invoke SMT solver.
// Warning: (176-181): Overflow (resulting value larger than 2**256 - 1) happens here
2019-08-20 13:03:45 +00:00
// Warning: (296-309): Assertion violation happens here