2020-09-23 15:55:55 +00:00
|
|
|
==== Source: base ====
|
|
|
|
contract Base {
|
|
|
|
uint x;
|
|
|
|
address a;
|
|
|
|
function f() internal returns (uint) {
|
|
|
|
a = address(this);
|
|
|
|
++x;
|
|
|
|
return 2;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
==== Source: der ====
|
|
|
|
pragma experimental SMTChecker;
|
|
|
|
import "base";
|
|
|
|
contract Der is Base {
|
|
|
|
function g(uint y) public {
|
2020-12-30 13:35:48 +00:00
|
|
|
require(x < 10); // added to restrict the search space and avoid non-determinsm in Spacer
|
2020-09-23 15:55:55 +00:00
|
|
|
x += f();
|
|
|
|
assert(y > x);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
// ----
|
2020-12-30 13:35:48 +00:00
|
|
|
// Warning 6328: (der:205-218): CHC: Assertion violation happens here.\nCounterexample:\nx = 3, a = 0\ny = 0\n\nTransaction trace:\nDer.constructor()\nState: x = 0, a = 0\nDer.g(0)\n Base.f() -- internal call
|