ERC4626Mock.sol 1.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950
  1. // SPDX-License-Identifier: MIT
  2. pragma solidity ^0.8.0;
  3. import "../token/ERC20/extensions/ERC4626.sol";
  4. contract ERC4626Mock is ERC4626 {
  5. constructor(IERC20Metadata asset, string memory name, string memory symbol) ERC20(name, symbol) ERC4626(asset) {}
  6. function mockMint(address account, uint256 amount) public {
  7. _mint(account, amount);
  8. }
  9. function mockBurn(address account, uint256 amount) public {
  10. _burn(account, amount);
  11. }
  12. }
  13. contract ERC4626DecimalMock is ERC4626Mock {
  14. using Math for uint256;
  15. uint8 private immutable _decimals;
  16. constructor(
  17. IERC20Metadata asset,
  18. string memory name,
  19. string memory symbol,
  20. uint8 decimalsOverride
  21. ) ERC4626Mock(asset, name, symbol) {
  22. _decimals = decimalsOverride;
  23. }
  24. function decimals() public view virtual override returns (uint8) {
  25. return _decimals;
  26. }
  27. function _initialConvertToShares(
  28. uint256 assets,
  29. Math.Rounding rounding
  30. ) internal view virtual override returns (uint256 shares) {
  31. return assets.mulDiv(10 ** decimals(), 10 ** super.decimals(), rounding);
  32. }
  33. function _initialConvertToAssets(
  34. uint256 shares,
  35. Math.Rounding rounding
  36. ) internal view virtual override returns (uint256 assets) {
  37. return shares.mulDiv(10 ** super.decimals(), 10 ** decimals(), rounding);
  38. }
  39. }