mirror of
https://github.com/Instadapp/aave-protocol-v2.git
synced 2024-07-29 21:47:30 +00:00
test: fixed the accrued to treasury test
This commit is contained in:
parent
ce052c669f
commit
42a07e75ab
|
@ -1,79 +1,69 @@
|
|||
import { makeSuite, TestEnv } from './helpers/make-suite';
|
||||
import { ProtocolErrors, RateMode } from '../../helpers/types';
|
||||
import { APPROVAL_AMOUNT_LENDING_POOL, oneEther, ONE_YEAR, RAY } from '../../helpers/constants';
|
||||
import { RateMode } from '../../helpers/types';
|
||||
import { APPROVAL_AMOUNT_LENDING_POOL, ONE_YEAR } from '../../helpers/constants';
|
||||
import { convertToCurrencyDecimals } from '../../helpers/contracts-helpers';
|
||||
import { parseEther, parseUnits } from 'ethers/lib/utils';
|
||||
import { BigNumber } from 'bignumber.js';
|
||||
import { MockFlashLoanReceiver } from '../../types/MockFlashLoanReceiver';
|
||||
import { getMockFlashLoanReceiver } from '../../helpers/contracts-getters';
|
||||
import { advanceTimeAndBlock, timeLatest, waitForTx } from '../../helpers/misc-utils';
|
||||
import { advanceTimeAndBlock, waitForTx } from '../../helpers/misc-utils';
|
||||
import './helpers/utils/math';
|
||||
import { calcCompoundedInterest } from './helpers/utils/calculations';
|
||||
import {getTxCostAndTimestamp } from './helpers/actions';
|
||||
|
||||
const { expect } = require('chai');
|
||||
|
||||
makeSuite('Mint to treasury', (testEnv: TestEnv) => {
|
||||
let _mockFlashLoanReceiver = {} as MockFlashLoanReceiver;
|
||||
|
||||
const {
|
||||
LP_IS_PAUSED,
|
||||
INVALID_FROM_BALANCE_AFTER_TRANSFER,
|
||||
INVALID_TO_BALANCE_AFTER_TRANSFER,
|
||||
} = ProtocolErrors;
|
||||
|
||||
before(async () => {
|
||||
_mockFlashLoanReceiver = await getMockFlashLoanReceiver();
|
||||
});
|
||||
|
||||
it('User 0 deposits 1000 DAI. Borrower borrows 100 DAI. Clock moved forward one year. Calculates and verifies the amount earned by the treasury', async () => {
|
||||
const { users, pool, dai, helpersContract } = testEnv;
|
||||
|
||||
const amountDAItoDeposit = await convertToCurrencyDecimals(dai.address, '1000');
|
||||
const amountDAItoBorrow = await convertToCurrencyDecimals(dai.address, '100');
|
||||
|
||||
await dai.connect(users[0].signer).mint(amountDAItoDeposit);
|
||||
await waitForTx(await dai.connect(users[0].signer).mint(amountDAItoDeposit));
|
||||
|
||||
// user 0 deposits 1000 DAI
|
||||
await dai.connect(users[0].signer).approve(pool.address, APPROVAL_AMOUNT_LENDING_POOL);
|
||||
await pool
|
||||
.connect(users[0].signer)
|
||||
.deposit(dai.address, amountDAItoDeposit, users[0].address, '0');
|
||||
await waitForTx(
|
||||
await dai.connect(users[0].signer).approve(pool.address, APPROVAL_AMOUNT_LENDING_POOL)
|
||||
);
|
||||
await waitForTx(
|
||||
await pool
|
||||
.connect(users[0].signer)
|
||||
.deposit(dai.address, amountDAItoDeposit, users[0].address, '0')
|
||||
);
|
||||
|
||||
const borrowTx = await waitForTx(await pool
|
||||
.connect(users[0].signer)
|
||||
.borrow(dai.address, amountDAItoBorrow, RateMode.Variable, '0', users[0].address));
|
||||
await waitForTx(
|
||||
await pool
|
||||
.connect(users[0].signer)
|
||||
.borrow(dai.address, amountDAItoBorrow, RateMode.Variable, '0', users[0].address)
|
||||
);
|
||||
|
||||
const {txTimestamp : lastUpdateTimestamp} = await getTxCostAndTimestamp(borrowTx);
|
||||
|
||||
|
||||
const {
|
||||
currentLiquidityRate: liquidityRate,
|
||||
currentVariableBorrowRate: variableBorrowRate,
|
||||
} = await pool.getReserveData(dai.address);
|
||||
const { reserveFactor } = await helpersContract.getReserveConfigurationData(dai.address);
|
||||
|
||||
await advanceTimeAndBlock(parseInt(ONE_YEAR));
|
||||
|
||||
await dai.connect(users[0].signer).mint(amountDAItoDeposit);
|
||||
await waitForTx(await dai.connect(users[0].signer).mint(amountDAItoDeposit));
|
||||
|
||||
const depositTx = await waitForTx(await pool
|
||||
.connect(users[0].signer)
|
||||
.deposit(dai.address, amountDAItoDeposit, users[0].address, '0'));
|
||||
await waitForTx(
|
||||
await pool
|
||||
.connect(users[0].signer)
|
||||
.deposit(dai.address, amountDAItoDeposit, users[0].address, '0')
|
||||
);
|
||||
|
||||
|
||||
const {txTimestamp : currTimestamp} = await getTxCostAndTimestamp(depositTx);
|
||||
const { liquidityIndex, variableBorrowIndex } = await pool.getReserveData(dai.address);
|
||||
|
||||
const interestNormalized = calcCompoundedInterest(new BigNumber(variableBorrowRate.toString()), currTimestamp, lastUpdateTimestamp).minus(RAY);
|
||||
const amountBorrowedBN = new BigNumber(amountDAItoBorrow.toString());
|
||||
const liquidityIndexBN = new BigNumber(liquidityIndex.toString());
|
||||
const variableBorrowIndexBN = new BigNumber(variableBorrowIndex.toString());
|
||||
|
||||
|
||||
const expectedReserveFactor = new BigNumber(amountDAItoBorrow.toString())
|
||||
.rayMul(interestNormalized)
|
||||
const expectedAccruedToTreasury = amountBorrowedBN
|
||||
.rayMul(variableBorrowIndexBN)
|
||||
.minus(amountBorrowedBN)
|
||||
.times(reserveFactor.toString())
|
||||
.div(10000);
|
||||
.div(10000)
|
||||
.rayDiv(liquidityIndexBN)
|
||||
.toFixed(0);
|
||||
|
||||
const reserveData = await pool.getReserveData(dai.address);
|
||||
const { accruedToTreasury } = await pool.getReserveData(dai.address);
|
||||
|
||||
console.log(reserveData.accruedToTreasury.toString(), expectedReserveFactor.toString());
|
||||
expect(accruedToTreasury.toString()).to.be.bignumber.almostEqual(
|
||||
expectedAccruedToTreasury,
|
||||
'Invalid amount accrued to treasury'
|
||||
);
|
||||
});
|
||||
});
|
||||
|
|
Loading…
Reference in New Issue
Block a user