solidity/test/libsolidity/smtCheckerTests/abi/abi_encode_with_sig_hash.sol
2020-12-17 14:42:49 +01:00

21 lines
908 B
Solidity

pragma experimental SMTChecker;
contract C {
function abiEncodeHash(string memory sig, uint a, uint b) public pure {
require(a == b);
bytes memory b1 = abi.encodeWithSignature(sig, a, a, a, a);
bytes memory b2 = abi.encodeWithSignature(sig, b, a, b, a);
assert(keccak256(b1) == keccak256(b2));
bytes memory b3 = abi.encodeWithSelector("f()", a, a, a, a);
assert(keccak256(b1) == keccak256(b3)); // should fail
assert(keccak256(b1) != keccak256(b3)); // should fail
}
}
// ----
// Warning 1218: (369-407): CHC: Error trying to invoke SMT solver.
// Warning 6328: (369-407): CHC: Assertion violation might happen here.
// Warning 1218: (426-464): CHC: Error trying to invoke SMT solver.
// Warning 6328: (426-464): CHC: Assertion violation might happen here.
// Warning 4661: (369-407): BMC: Assertion violation happens here.
// Warning 4661: (426-464): BMC: Assertion violation happens here.