==== Source: s1.sol ==== uint constant a = 89; function fre() pure returns (uint) { return a; } ==== Source: s2.sol ==== function foo() pure returns (uint) { return 42; } ==== Source: s3.sol ==== import {fre as foo} from "s1.sol"; import "s1.sol" as M; import "s2.sol" as N; uint256 constant a = 13; contract C { function f() internal pure returns (uint, uint, uint, uint) { return (a, foo(), N.foo(), M.a); } function p() public pure { (uint x, uint y, uint z, uint t) = f(); assert(x == 13); // should hold assert(x == 89); // should fail assert(y == 89); // should hold assert(y == 42); // should fail assert(z == 42); // should hold assert(z == 89); // should fail assert(t == 89); // should hold assert(t == 13); // should fail } } // ==== // SMTEngine: all // ---- // Warning 6328: (s3.sol:327-342): CHC: Assertion violation happens here.\nCounterexample:\n\nx = 13\ny = 89\nz = 42\nt = 89\n\nTransaction trace:\nC.constructor()\nC.p()\n C.f() -- internal call\n s1.sol:fre() -- internal call\n s2.sol:foo() -- internal call // Warning 6328: (s3.sol:396-411): CHC: Assertion violation happens here.\nCounterexample:\n\nx = 13\ny = 89\nz = 42\nt = 89\n\nTransaction trace:\nC.constructor()\nC.p()\n C.f() -- internal call\n s1.sol:fre() -- internal call\n s2.sol:foo() -- internal call // Warning 6328: (s3.sol:465-480): CHC: Assertion violation happens here.\nCounterexample:\n\nx = 13\ny = 89\nz = 42\nt = 89\n\nTransaction trace:\nC.constructor()\nC.p()\n C.f() -- internal call\n s1.sol:fre() -- internal call\n s2.sol:foo() -- internal call // Warning 6328: (s3.sol:534-549): CHC: Assertion violation happens here.\nCounterexample:\n\nx = 13\ny = 89\nz = 42\nt = 89\n\nTransaction trace:\nC.constructor()\nC.p()\n C.f() -- internal call\n s1.sol:fre() -- internal call\n s2.sol:foo() -- internal call