* Error handling in ERC20 and ERC721 * Added message string for require. * Fixed solhint errors. * Updated PR as per issue #1709 * changes as per #1709 and openzeppelin forum. * Changes in require statement * Changes in require statement * build pipeline fix * Changes as per @nventuro's comment. * Update revert reason strings. * Fianal update of revert reason strings. * WIP: Updating reason strings in test cases * WIP: Added changes to ERC20 and ERC721 * Fixes linting errors in *.tes.js files * Achieved 100% code coverage * Updated the test cases with shouldFail.reverting.withMessage() * Fix package-lock. * address review comments * fix linter issues * fix remaining revert reasons
24 lines
682 B
Solidity
24 lines
682 B
Solidity
pragma solidity ^0.5.7;
|
|
|
|
import "../token/ERC721/IERC721Receiver.sol";
|
|
|
|
contract ERC721ReceiverMock is IERC721Receiver {
|
|
bytes4 private _retval;
|
|
bool private _reverts;
|
|
|
|
event Received(address operator, address from, uint256 tokenId, bytes data, uint256 gas);
|
|
|
|
constructor (bytes4 retval, bool reverts) public {
|
|
_retval = retval;
|
|
_reverts = reverts;
|
|
}
|
|
|
|
function onERC721Received(address operator, address from, uint256 tokenId, bytes memory data)
|
|
public returns (bytes4)
|
|
{
|
|
require(!_reverts, "ERC721ReceiverMock: reverting");
|
|
emit Received(operator, from, tokenId, data, gasleft());
|
|
return _retval;
|
|
}
|
|
}
|