From d79e19801d4c7b053e54087f4e509ac3dd2468cd Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Cl=C3=A9ment?= Date: Tue, 29 Oct 2024 18:16:14 +0100 Subject: [PATCH] lint and prettier --- .../assets/origin/OETHCollateralL2Base.sol | 72 +++- .../origin/OETHCollateralL2Base.test.ts | 347 +++++++++--------- 2 files changed, 244 insertions(+), 175 deletions(-) diff --git a/contracts/plugins/assets/origin/OETHCollateralL2Base.sol b/contracts/plugins/assets/origin/OETHCollateralL2Base.sol index 15a9f5205..d597b2b09 100644 --- a/contracts/plugins/assets/origin/OETHCollateralL2Base.sol +++ b/contracts/plugins/assets/origin/OETHCollateralL2Base.sol @@ -10,45 +10,96 @@ interface IWSuperOETHb { event Approval(address indexed owner, address indexed spender, uint256 value); event Deposit(address indexed caller, address indexed owner, uint256 assets, uint256 shares); event GovernorshipTransferred(address indexed previousGovernor, address indexed newGovernor); - event PendingGovernorshipTransfer(address indexed previousGovernor, address indexed newGovernor); + event PendingGovernorshipTransfer( + address indexed previousGovernor, + address indexed newGovernor + ); event Transfer(address indexed from, address indexed to, uint256 value); event Withdraw( - address indexed caller, address indexed receiver, address indexed owner, uint256 assets, uint256 shares + address indexed caller, + address indexed receiver, + address indexed owner, + uint256 assets, + uint256 shares ); function allowance(address owner, address spender) external view returns (uint256); + function approve(address spender, uint256 amount) external returns (bool); + function asset() external view returns (address); + function balanceOf(address account) external view returns (uint256); + function claimGovernance() external; + function convertToAssets(uint256 shares) external view returns (uint256 assets); + function convertToShares(uint256 assets) external view returns (uint256 shares); + function decimals() external view returns (uint8); + function decreaseAllowance(address spender, uint256 subtractedValue) external returns (bool); + function deposit(uint256 assets, address receiver) external returns (uint256); + function governor() external view returns (address); + function increaseAllowance(address spender, uint256 addedValue) external returns (bool); + function initialize() external; + function isGovernor() external view returns (bool); + function maxDeposit(address) external view returns (uint256); + function maxMint(address) external view returns (uint256); + function maxRedeem(address owner) external view returns (uint256); + function maxWithdraw(address owner) external view returns (uint256); + function mint(uint256 shares, address receiver) external returns (uint256); + function name() external view returns (string memory); + function previewDeposit(uint256 assets) external view returns (uint256); + function previewMint(uint256 shares) external view returns (uint256); + function previewRedeem(uint256 shares) external view returns (uint256); + function previewWithdraw(uint256 assets) external view returns (uint256); - function redeem(uint256 shares, address receiver, address owner) external returns (uint256); + + function redeem( + uint256 shares, + address receiver, + address owner + ) external returns (uint256); + function symbol() external view returns (string memory); + function totalAssets() external view returns (uint256); + function totalSupply() external view returns (uint256); + function transfer(address recipient, uint256 amount) external returns (bool); - function transferFrom(address sender, address recipient, uint256 amount) external returns (bool); + + function transferFrom( + address sender, + address recipient, + uint256 amount + ) external returns (bool); + function transferGovernance(address _newGovernor) external; + function transferToken(address asset_, uint256 amount_) external; - function withdraw(uint256 assets, address receiver, address owner) external returns (uint256); + + function withdraw( + uint256 assets, + address receiver, + address owner + ) external returns (uint256); } interface IMorphoChainlinkOracleV2 { @@ -99,7 +150,16 @@ contract OETHCollateralL2Base is AppreciatingFiatCollateral { /// @return low {UoA/tok} The low price estimate /// @return high {UoA/tok} The high price estimate /// @return pegPrice {target/ref} The actual price observed in the peg - function tryPrice() external view override returns (uint192 low, uint192 high, uint192 pegPrice) { + function tryPrice() + external + view + override + returns ( + uint192 low, + uint192 high, + uint192 pegPrice + ) + { // {tar/tok} // {ETH/wsuperOETHb} uint192 targetPerTok = _safeWrap(targetPerTokChainlinkFeed.price()) / 1e18; diff --git a/test/plugins/individual-collateral/origin/OETHCollateralL2Base.test.ts b/test/plugins/individual-collateral/origin/OETHCollateralL2Base.test.ts index 62330b864..ed216d64e 100644 --- a/test/plugins/individual-collateral/origin/OETHCollateralL2Base.test.ts +++ b/test/plugins/individual-collateral/origin/OETHCollateralL2Base.test.ts @@ -6,27 +6,27 @@ import { expect } from 'chai' import { ethers } from 'hardhat' import { ContractFactory, BigNumber, BigNumberish } from 'ethers' import { - ERC20Mock, - MockV3Aggregator, - MockV3Aggregator__factory, - TestICollateral, - IWSuperOETHb, + ERC20Mock, + MockV3Aggregator, + MockV3Aggregator__factory, + TestICollateral, + IWSuperOETHb, } from '../../../../typechain' import { pushOracleForward } from '../../../utils/oracles' import { bn, fp } from '../../../../common/numbers' import { ZERO_ADDRESS } from '../../../../common/constants' import { SignerWithAddress } from '@nomiclabs/hardhat-ethers/signers' import { - PRICE_TIMEOUT, - MAX_TRADE_VOL, - DEFAULT_THRESHOLD, - DELAY_UNTIL_DEFAULT, - FORK_BLOCK_BASE, - BASE_PRICE_FEEDS, - BASE_FEEDS_TIMEOUT, - BASE_ORACLE_ERROR, - BASE_WSUPEROETHB, - BASE_WSUPEROETHB_WHALE, + PRICE_TIMEOUT, + MAX_TRADE_VOL, + DEFAULT_THRESHOLD, + DELAY_UNTIL_DEFAULT, + FORK_BLOCK_BASE, + BASE_PRICE_FEEDS, + BASE_FEEDS_TIMEOUT, + BASE_ORACLE_ERROR, + BASE_WSUPEROETHB, + BASE_WSUPEROETHB_WHALE, } from './constants' import { getResetFork } from '../helpers' @@ -34,9 +34,9 @@ import { getResetFork } from '../helpers' Define interfaces */ interface WSUPEROETHBCollateralFixtureContext extends CollateralFixtureContext { - wsuperoethb: IWSuperOETHb - targetPerRefChainlinkFeed: MockV3Aggregator - uoaPerTargetChainlinkFeed: MockV3Aggregator + wsuperoethb: IWSuperOETHb + targetPerRefChainlinkFeed: MockV3Aggregator + uoaPerTargetChainlinkFeed: MockV3Aggregator } /* @@ -44,113 +44,119 @@ interface WSUPEROETHBCollateralFixtureContext extends CollateralFixtureContext { */ interface WSUPEROETHBCollateralOpts extends CollateralOpts { - targetPerTokChainlinkFeed?: string - uoaPerTargetChainlinkFeed?: string - uoaPerTargetChainlinkTimeout?: BigNumberish + targetPerTokChainlinkFeed?: string + uoaPerTargetChainlinkFeed?: string + uoaPerTargetChainlinkTimeout?: BigNumberish } export const defaultWSUPEROETHBCollateralOpts: WSUPEROETHBCollateralOpts = { - erc20: BASE_WSUPEROETHB, - targetName: ethers.utils.formatBytes32String('ETH'), - rewardERC20: ZERO_ADDRESS, - priceTimeout: PRICE_TIMEOUT, - chainlinkFeed: BASE_PRICE_FEEDS.wsuperOETHb_ETH, // ignored - oracleTimeout: '1000', // ignored - oracleError: BASE_ORACLE_ERROR, - maxTradeVolume: MAX_TRADE_VOL, - defaultThreshold: DEFAULT_THRESHOLD, - delayUntilDefault: DELAY_UNTIL_DEFAULT, - targetPerTokChainlinkFeed: BASE_PRICE_FEEDS.wsuperOETHb_ETH, - uoaPerTargetChainlinkFeed: BASE_PRICE_FEEDS.ETH_USD, - uoaPerTargetChainlinkTimeout: BASE_FEEDS_TIMEOUT.ETH_USD, - revenueHiding: fp('1e-4'), + erc20: BASE_WSUPEROETHB, + targetName: ethers.utils.formatBytes32String('ETH'), + rewardERC20: ZERO_ADDRESS, + priceTimeout: PRICE_TIMEOUT, + chainlinkFeed: BASE_PRICE_FEEDS.wsuperOETHb_ETH, // ignored + oracleTimeout: '1000', // ignored + oracleError: BASE_ORACLE_ERROR, + maxTradeVolume: MAX_TRADE_VOL, + defaultThreshold: DEFAULT_THRESHOLD, + delayUntilDefault: DELAY_UNTIL_DEFAULT, + targetPerTokChainlinkFeed: BASE_PRICE_FEEDS.wsuperOETHb_ETH, + uoaPerTargetChainlinkFeed: BASE_PRICE_FEEDS.ETH_USD, + uoaPerTargetChainlinkTimeout: BASE_FEEDS_TIMEOUT.ETH_USD, + revenueHiding: fp('1e-4'), } export const deployCollateral = async ( - opts: WSUPEROETHBCollateralOpts = {} + opts: WSUPEROETHBCollateralOpts = {} ): Promise => { - opts = { ...defaultWSUPEROETHBCollateralOpts, ...opts } - - const WSuperOETHbCollateralFactory: ContractFactory = await ethers.getContractFactory( - 'OETHCollateralL2Base' - ) - - const collateral = await WSuperOETHbCollateralFactory.deploy( - { - erc20: opts.erc20, - targetName: opts.targetName, - rewardERC20: opts.rewardERC20, - priceTimeout: opts.priceTimeout, - chainlinkFeed: opts.chainlinkFeed, - oracleError: opts.oracleError, - oracleTimeout: opts.oracleTimeout, - maxTradeVolume: opts.maxTradeVolume, - defaultThreshold: opts.defaultThreshold, - delayUntilDefault: opts.delayUntilDefault, - }, - opts.revenueHiding, - opts.targetPerTokChainlinkFeed, - opts.chainlinkFeed ?? opts.uoaPerTargetChainlinkFeed, - opts.uoaPerTargetChainlinkTimeout, - { gasLimit: 2000000000 } - ) - - // Push forward chainlink feed - await pushOracleForward(opts.uoaPerTargetChainlinkFeed!) - - await collateral.deployed() - // sometimes we are trying to test a negative test case and we want this to fail silently - // fortunately this syntax fails silently because our tools are terrible - await expect(collateral.refresh()) - - return collateral + opts = { ...defaultWSUPEROETHBCollateralOpts, ...opts } + + const WSuperOETHbCollateralFactory: ContractFactory = await ethers.getContractFactory( + 'OETHCollateralL2Base' + ) + + const collateral = await WSuperOETHbCollateralFactory.deploy( + { + erc20: opts.erc20, + targetName: opts.targetName, + rewardERC20: opts.rewardERC20, + priceTimeout: opts.priceTimeout, + chainlinkFeed: opts.chainlinkFeed, + oracleError: opts.oracleError, + oracleTimeout: opts.oracleTimeout, + maxTradeVolume: opts.maxTradeVolume, + defaultThreshold: opts.defaultThreshold, + delayUntilDefault: opts.delayUntilDefault, + }, + opts.revenueHiding, + opts.targetPerTokChainlinkFeed, + opts.chainlinkFeed ?? opts.uoaPerTargetChainlinkFeed, + opts.uoaPerTargetChainlinkTimeout, + { gasLimit: 2000000000 } + ) + + // Push forward chainlink feed + await pushOracleForward(opts.uoaPerTargetChainlinkFeed!) + + await collateral.deployed() + // sometimes we are trying to test a negative test case and we want this to fail silently + // fortunately this syntax fails silently because our tools are terrible + await expect(collateral.refresh()) + + return collateral } const defaultAnswers = { - targetPerRefChainlinkFeed: bn('1e18'), - uoaPerTargetChainlinkFeed: bn('2000e8'), - refPerTokenChainlinkFeed: bn('1.1e18'), + targetPerRefChainlinkFeed: bn('1e18'), + uoaPerTargetChainlinkFeed: bn('2000e8'), + refPerTokenChainlinkFeed: bn('1.1e18'), } type Fixture = () => Promise const makeCollateralFixtureContext = ( - alice: SignerWithAddress, - opts: CollateralOpts = {} + alice: SignerWithAddress, + opts: CollateralOpts = {} ): Fixture => { - const collateralOpts = { ...defaultWSUPEROETHBCollateralOpts, ...opts } - - const makeCollateralFixtureContext = async () => { - const MockV3AggregatorFactory = ( - await ethers.getContractFactory('MockV3Aggregator') - ) - - const targetPerRefChainlinkFeed = await MockV3AggregatorFactory.deploy( - 18, - defaultAnswers.targetPerRefChainlinkFeed - ) - const uoaPerTargetChainlinkFeed = await MockV3AggregatorFactory.deploy(8, defaultAnswers.uoaPerTargetChainlinkFeed) - - collateralOpts.chainlinkFeed = uoaPerTargetChainlinkFeed.address - collateralOpts.uoaPerTargetChainlinkFeed = uoaPerTargetChainlinkFeed.address - - const wsuperOETHb = (await ethers.getContractAt('IWSuperOETHb', BASE_WSUPEROETHB)) as IWSuperOETHb - const rewardToken = (await ethers.getContractAt('ERC20Mock', ZERO_ADDRESS)) as ERC20Mock - const collateral = await deployCollateral(collateralOpts) - - return { - alice, - collateral, - wsuperoethb: wsuperOETHb, - tok: wsuperOETHb, - rewardToken, - chainlinkFeed: uoaPerTargetChainlinkFeed, - targetPerRefChainlinkFeed: targetPerRefChainlinkFeed, - uoaPerTargetChainlinkFeed, - } + const collateralOpts = { ...defaultWSUPEROETHBCollateralOpts, ...opts } + + const makeCollateralFixtureContext = async () => { + const MockV3AggregatorFactory = ( + await ethers.getContractFactory('MockV3Aggregator') + ) + + const targetPerRefChainlinkFeed = await MockV3AggregatorFactory.deploy( + 18, + defaultAnswers.targetPerRefChainlinkFeed + ) + const uoaPerTargetChainlinkFeed = await MockV3AggregatorFactory.deploy( + 8, + defaultAnswers.uoaPerTargetChainlinkFeed + ) + + collateralOpts.chainlinkFeed = uoaPerTargetChainlinkFeed.address + collateralOpts.uoaPerTargetChainlinkFeed = uoaPerTargetChainlinkFeed.address + + const wsuperOETHb = (await ethers.getContractAt( + 'IWSuperOETHb', + BASE_WSUPEROETHB + )) as IWSuperOETHb + const rewardToken = (await ethers.getContractAt('ERC20Mock', ZERO_ADDRESS)) as ERC20Mock + const collateral = await deployCollateral(collateralOpts) + + return { + alice, + collateral, + wsuperoethb: wsuperOETHb, + tok: wsuperOETHb, + rewardToken, + chainlinkFeed: uoaPerTargetChainlinkFeed, + targetPerRefChainlinkFeed: targetPerRefChainlinkFeed, + uoaPerTargetChainlinkFeed, } + } - return makeCollateralFixtureContext + return makeCollateralFixtureContext } /* @@ -158,101 +164,104 @@ const makeCollateralFixtureContext = ( */ const mintCollateralTo: MintCollateralFunc = async ( - ctx: WSUPEROETHBCollateralFixtureContext, - amount: BigNumberish, - user: SignerWithAddress, - recipient: string + ctx: WSUPEROETHBCollateralFixtureContext, + amount: BigNumberish, + user: SignerWithAddress, + recipient: string ) => { - await mintWSUPEROETHB(ctx.wsuperoethb, user, amount, recipient, BASE_WSUPEROETHB_WHALE) + await mintWSUPEROETHB(ctx.wsuperoethb, user, amount, recipient, BASE_WSUPEROETHB_WHALE) } const reduceTargetPerRef = async ( - ctx: WSUPEROETHBCollateralFixtureContext, - pctDecrease: BigNumberish + ctx: WSUPEROETHBCollateralFixtureContext, + pctDecrease: BigNumberish ) => { - const lastRound = await ctx.chainlinkFeed.latestRoundData() - const nextAnswer = lastRound.answer.sub(lastRound.answer.mul(pctDecrease).div(100)) - await ctx.chainlinkFeed.updateAnswer(nextAnswer) + const lastRound = await ctx.chainlinkFeed.latestRoundData() + const nextAnswer = lastRound.answer.sub(lastRound.answer.mul(pctDecrease).div(100)) + await ctx.chainlinkFeed.updateAnswer(nextAnswer) } const increaseTargetPerRef = async ( - ctx: WSUPEROETHBCollateralFixtureContext, - pctIncrease: BigNumberish + ctx: WSUPEROETHBCollateralFixtureContext, + pctIncrease: BigNumberish ) => { - const lastRound = await ctx.chainlinkFeed.latestRoundData() - const nextAnswer = lastRound.answer.add(lastRound.answer.mul(pctIncrease).div(100)) - await ctx.chainlinkFeed.updateAnswer(nextAnswer) + const lastRound = await ctx.chainlinkFeed.latestRoundData() + const nextAnswer = lastRound.answer.add(lastRound.answer.mul(pctIncrease).div(100)) + await ctx.chainlinkFeed.updateAnswer(nextAnswer) } -const reduceRefPerTok = async (ctx: WSUPEROETHBCollateralFixtureContext, pctDecrease: BigNumberish) => { - const slot = 2 - const storedTotalSupply = BigNumber.from(await getStorageAt(ctx.tok.address, slot)) - const newStoredTotalAssets = storedTotalSupply.add(storedTotalSupply.mul(pctDecrease).div(100)) - await setStorageAt(ctx.tok.address, slot, newStoredTotalAssets) +const reduceRefPerTok = async ( + ctx: WSUPEROETHBCollateralFixtureContext, + pctDecrease: BigNumberish +) => { + const slot = 2 + const storedTotalSupply = BigNumber.from(await getStorageAt(ctx.tok.address, slot)) + const newStoredTotalAssets = storedTotalSupply.add(storedTotalSupply.mul(pctDecrease).div(100)) + await setStorageAt(ctx.tok.address, slot, newStoredTotalAssets) } const increaseRefPerTok = async ( - ctx: WSUPEROETHBCollateralFixtureContext, - pctIncrease: BigNumberish + ctx: WSUPEROETHBCollateralFixtureContext, + pctIncrease: BigNumberish ) => { - const slot = 2 - const storedTotalSupply = BigNumber.from(await getStorageAt(ctx.tok.address, slot)) - const newStoredTotalAssets = storedTotalSupply.sub(storedTotalSupply.mul(pctIncrease).div(100)) - await setStorageAt(ctx.tok.address, slot, newStoredTotalAssets) + const slot = 2 + const storedTotalSupply = BigNumber.from(await getStorageAt(ctx.tok.address, slot)) + const newStoredTotalAssets = storedTotalSupply.sub(storedTotalSupply.mul(pctIncrease).div(100)) + await setStorageAt(ctx.tok.address, slot, newStoredTotalAssets) } const getExpectedPrice = async (ctx: WSUPEROETHBCollateralFixtureContext): Promise => { - const uoaPerTargetChainlinkFeedAnswer = await ctx.uoaPerTargetChainlinkFeed.latestAnswer() - const uoaPerTargetChainlinkFeedDecimals = await ctx.uoaPerTargetChainlinkFeed.decimals() + const uoaPerTargetChainlinkFeedAnswer = await ctx.uoaPerTargetChainlinkFeed.latestAnswer() + const uoaPerTargetChainlinkFeedDecimals = await ctx.uoaPerTargetChainlinkFeed.decimals() - const refPerTok = await ctx.collateral.refPerTok() + const refPerTok = await ctx.collateral.refPerTok() - const result = uoaPerTargetChainlinkFeedAnswer - .mul(bn(10).pow(18 - uoaPerTargetChainlinkFeedDecimals)) - .mul(refPerTok) - .div(fp('1')) + const result = uoaPerTargetChainlinkFeedAnswer + .mul(bn(10).pow(18 - uoaPerTargetChainlinkFeedDecimals)) + .mul(refPerTok) + .div(fp('1')) - return result + return result } -const collateralSpecificConstructorTests = () => { } +const collateralSpecificConstructorTests = () => {} // eslint-disable-next-line @typescript-eslint/no-empty-function -const collateralSpecificStatusTests = () => { } +const collateralSpecificStatusTests = () => {} // eslint-disable-next-line @typescript-eslint/no-empty-function -const beforeEachRewardsTest = async () => { } +const beforeEachRewardsTest = async () => {} /* Run the test suite */ const opts = { - deployCollateral, - collateralSpecificConstructorTests, - collateralSpecificStatusTests, - beforeEachRewardsTest, - makeCollateralFixtureContext, - mintCollateralTo, - reduceTargetPerRef, - increaseTargetPerRef, - reduceRefPerTok, - increaseRefPerTok, - getExpectedPrice, - itClaimsRewards: it.skip, - itChecksTargetPerRefDefault: it.skip, - itChecksTargetPerRefDefaultUp: it.skip, - itChecksRefPerTokDefault: it, - itChecksPriceChanges: it, - itChecksNonZeroDefaultThreshold: it, - itHasRevenueHiding: it, - resetFork: getResetFork(FORK_BLOCK_BASE), - collateralName: 'OETHCollateralL2Base', - chainlinkDefaultAnswer: defaultAnswers.uoaPerTargetChainlinkFeed, - itIsPricedByPeg: true, - itHasOracleRefPerTok: true, - targetNetwork: 'base', - toleranceDivisor: bn('1e2'), + deployCollateral, + collateralSpecificConstructorTests, + collateralSpecificStatusTests, + beforeEachRewardsTest, + makeCollateralFixtureContext, + mintCollateralTo, + reduceTargetPerRef, + increaseTargetPerRef, + reduceRefPerTok, + increaseRefPerTok, + getExpectedPrice, + itClaimsRewards: it.skip, + itChecksTargetPerRefDefault: it.skip, + itChecksTargetPerRefDefaultUp: it.skip, + itChecksRefPerTokDefault: it, + itChecksPriceChanges: it, + itChecksNonZeroDefaultThreshold: it, + itHasRevenueHiding: it, + resetFork: getResetFork(FORK_BLOCK_BASE), + collateralName: 'OETHCollateralL2Base', + chainlinkDefaultAnswer: defaultAnswers.uoaPerTargetChainlinkFeed, + itIsPricedByPeg: true, + itHasOracleRefPerTok: true, + targetNetwork: 'base', + toleranceDivisor: bn('1e2'), } collateralTests(opts)