2020-07-13 08:54:08 +00:00
|
|
|
import {TestEnv, makeSuite} from './helpers/make-suite';
|
2020-08-25 15:15:27 +00:00
|
|
|
import {RAY} from '../helpers/constants';
|
2020-07-13 08:54:08 +00:00
|
|
|
import {convertToCurrencyDecimals} from '../helpers/contracts-helpers';
|
|
|
|
import {ProtocolErrors} from '../helpers/types';
|
2020-08-25 15:15:27 +00:00
|
|
|
import {CommonsConfig} from '../config/commons';
|
|
|
|
|
|
|
|
const APPROVAL_AMOUNT_LENDING_POOL =
|
|
|
|
CommonsConfig.ProtocolGlobalParams.ApprovalAmountLendingPoolCore;
|
2020-07-13 08:54:08 +00:00
|
|
|
|
|
|
|
const {expect} = require('chai');
|
|
|
|
|
|
|
|
makeSuite('LendingPoolConfigurator', (testEnv: TestEnv) => {
|
2020-09-16 12:09:42 +00:00
|
|
|
const {CALLER_NOT_AAVE_ADMIN, RESERVE_LIQUIDITY_NOT_0} = ProtocolErrors;
|
2020-06-12 08:39:42 +00:00
|
|
|
|
2020-07-13 08:54:08 +00:00
|
|
|
it('Deactivates the ETH reserve', async () => {
|
2020-08-13 11:06:23 +00:00
|
|
|
const {configurator, pool, weth} = testEnv;
|
|
|
|
await configurator.deactivateReserve(weth.address);
|
|
|
|
const {isActive} = await pool.getReserveConfigurationData(weth.address);
|
2020-06-12 07:41:30 +00:00
|
|
|
expect(isActive).to.be.equal(false);
|
|
|
|
});
|
|
|
|
|
2020-07-13 08:54:08 +00:00
|
|
|
it('Rectivates the ETH reserve', async () => {
|
2020-08-13 11:06:23 +00:00
|
|
|
const {configurator, pool, weth} = testEnv;
|
|
|
|
await configurator.activateReserve(weth.address);
|
2020-06-12 07:41:30 +00:00
|
|
|
|
2020-08-13 11:06:23 +00:00
|
|
|
const {isActive} = await pool.getReserveConfigurationData(weth.address);
|
2020-06-12 07:41:30 +00:00
|
|
|
expect(isActive).to.be.equal(true);
|
|
|
|
});
|
|
|
|
|
2020-09-16 12:09:42 +00:00
|
|
|
it('Check the onlyAaveAdmin on deactivateReserve ', async () => {
|
2020-08-13 11:06:23 +00:00
|
|
|
const {configurator, users, weth} = testEnv;
|
2020-06-12 07:41:30 +00:00
|
|
|
await expect(
|
2020-08-13 11:06:23 +00:00
|
|
|
configurator.connect(users[2].signer).deactivateReserve(weth.address),
|
2020-09-16 12:09:42 +00:00
|
|
|
CALLER_NOT_AAVE_ADMIN
|
|
|
|
).to.be.revertedWith(CALLER_NOT_AAVE_ADMIN);
|
2020-06-12 07:41:30 +00:00
|
|
|
});
|
|
|
|
|
2020-09-16 12:09:42 +00:00
|
|
|
it('Check the onlyAaveAdmin on activateReserve ', async () => {
|
2020-08-13 11:06:23 +00:00
|
|
|
const {configurator, users, weth} = testEnv;
|
2020-06-12 07:41:30 +00:00
|
|
|
await expect(
|
2020-08-13 11:06:23 +00:00
|
|
|
configurator.connect(users[2].signer).activateReserve(weth.address),
|
2020-09-16 12:09:42 +00:00
|
|
|
CALLER_NOT_AAVE_ADMIN
|
|
|
|
).to.be.revertedWith(CALLER_NOT_AAVE_ADMIN);
|
2020-06-12 07:41:30 +00:00
|
|
|
});
|
|
|
|
|
2020-07-13 08:54:08 +00:00
|
|
|
it('Freezes the ETH reserve', async () => {
|
2020-08-13 11:06:23 +00:00
|
|
|
const {configurator, pool, weth} = testEnv;
|
|
|
|
await configurator.freezeReserve(weth.address);
|
2020-10-06 08:59:33 +00:00
|
|
|
const {
|
|
|
|
decimals,
|
|
|
|
ltv,
|
|
|
|
liquidationBonus,
|
|
|
|
liquidationThreshold,
|
|
|
|
reserveFactor,
|
|
|
|
stableBorrowRateEnabled,
|
|
|
|
borrowingEnabled,
|
|
|
|
isActive,
|
2020-10-06 09:02:34 +00:00
|
|
|
isFreezed,
|
2020-10-06 08:59:33 +00:00
|
|
|
} = await pool.getReserveConfigurationData(weth.address);
|
|
|
|
|
|
|
|
expect(borrowingEnabled).to.be.equal(true);
|
|
|
|
expect(isActive).to.be.equal(true);
|
2020-06-12 07:41:30 +00:00
|
|
|
expect(isFreezed).to.be.equal(true);
|
2020-10-06 08:59:33 +00:00
|
|
|
expect(decimals).to.be.equal(18);
|
|
|
|
expect(ltv).to.be.equal(7500);
|
|
|
|
expect(liquidationThreshold).to.be.equal(8000);
|
|
|
|
expect(liquidationBonus).to.be.equal(10500);
|
|
|
|
expect(stableBorrowRateEnabled).to.be.equal(true);
|
2020-10-06 09:02:34 +00:00
|
|
|
expect(reserveFactor).to.be.equal(0);
|
2020-06-12 07:41:30 +00:00
|
|
|
});
|
|
|
|
|
2020-07-13 08:54:08 +00:00
|
|
|
it('Unfreezes the ETH reserve', async () => {
|
2020-08-13 11:06:23 +00:00
|
|
|
const {configurator, pool, weth} = testEnv;
|
|
|
|
await configurator.unfreezeReserve(weth.address);
|
2020-06-12 07:41:30 +00:00
|
|
|
|
2020-10-06 09:02:34 +00:00
|
|
|
const {
|
|
|
|
decimals,
|
|
|
|
ltv,
|
|
|
|
liquidationBonus,
|
|
|
|
liquidationThreshold,
|
|
|
|
reserveFactor,
|
|
|
|
stableBorrowRateEnabled,
|
|
|
|
borrowingEnabled,
|
|
|
|
isActive,
|
|
|
|
isFreezed,
|
|
|
|
} = await pool.getReserveConfigurationData(weth.address);
|
|
|
|
|
|
|
|
expect(borrowingEnabled).to.be.equal(true);
|
|
|
|
expect(isActive).to.be.equal(true);
|
2020-06-12 07:41:30 +00:00
|
|
|
expect(isFreezed).to.be.equal(false);
|
2020-10-06 09:02:34 +00:00
|
|
|
expect(decimals).to.be.equal(18);
|
|
|
|
expect(ltv).to.be.equal(7500);
|
|
|
|
expect(liquidationThreshold).to.be.equal(8000);
|
|
|
|
expect(liquidationBonus).to.be.equal(10500);
|
|
|
|
expect(stableBorrowRateEnabled).to.be.equal(true);
|
|
|
|
expect(reserveFactor).to.be.equal(0);
|
2020-06-12 07:41:30 +00:00
|
|
|
});
|
|
|
|
|
2020-09-16 12:09:42 +00:00
|
|
|
it('Check the onlyAaveAdmin on freezeReserve ', async () => {
|
2020-08-13 11:06:23 +00:00
|
|
|
const {configurator, users, weth} = testEnv;
|
2020-06-12 07:41:30 +00:00
|
|
|
await expect(
|
2020-08-13 11:06:23 +00:00
|
|
|
configurator.connect(users[2].signer).freezeReserve(weth.address),
|
2020-09-16 12:09:42 +00:00
|
|
|
CALLER_NOT_AAVE_ADMIN
|
|
|
|
).to.be.revertedWith(CALLER_NOT_AAVE_ADMIN);
|
2020-06-12 07:41:30 +00:00
|
|
|
});
|
|
|
|
|
2020-09-16 12:09:42 +00:00
|
|
|
it('Check the onlyAaveAdmin on unfreezeReserve ', async () => {
|
2020-08-13 11:06:23 +00:00
|
|
|
const {configurator, users, weth} = testEnv;
|
2020-06-12 07:41:30 +00:00
|
|
|
await expect(
|
2020-08-13 11:06:23 +00:00
|
|
|
configurator.connect(users[2].signer).unfreezeReserve(weth.address),
|
2020-09-16 12:09:42 +00:00
|
|
|
CALLER_NOT_AAVE_ADMIN
|
|
|
|
).to.be.revertedWith(CALLER_NOT_AAVE_ADMIN);
|
2020-06-12 07:41:30 +00:00
|
|
|
});
|
|
|
|
|
2020-07-13 08:54:08 +00:00
|
|
|
it('Deactivates the ETH reserve for borrowing', async () => {
|
2020-08-13 11:06:23 +00:00
|
|
|
const {configurator, pool, weth} = testEnv;
|
|
|
|
await configurator.disableBorrowingOnReserve(weth.address);
|
2020-10-06 08:59:33 +00:00
|
|
|
const {
|
|
|
|
decimals,
|
|
|
|
ltv,
|
|
|
|
liquidationBonus,
|
|
|
|
liquidationThreshold,
|
|
|
|
reserveFactor,
|
|
|
|
stableBorrowRateEnabled,
|
|
|
|
borrowingEnabled,
|
|
|
|
isActive,
|
2020-10-06 09:02:34 +00:00
|
|
|
isFreezed,
|
2020-10-06 08:59:33 +00:00
|
|
|
} = await pool.getReserveConfigurationData(weth.address);
|
|
|
|
|
2020-06-27 02:13:32 +00:00
|
|
|
expect(borrowingEnabled).to.be.equal(false);
|
2020-10-06 08:59:33 +00:00
|
|
|
expect(isActive).to.be.equal(true);
|
|
|
|
expect(isFreezed).to.be.equal(false);
|
|
|
|
expect(decimals).to.be.equal(18);
|
|
|
|
expect(ltv).to.be.equal(7500);
|
|
|
|
expect(liquidationThreshold).to.be.equal(8000);
|
|
|
|
expect(liquidationBonus).to.be.equal(10500);
|
|
|
|
expect(stableBorrowRateEnabled).to.be.equal(true);
|
|
|
|
expect(reserveFactor).to.be.equal(0);
|
2020-06-12 07:41:30 +00:00
|
|
|
});
|
|
|
|
|
2020-07-13 08:54:08 +00:00
|
|
|
it('Activates the ETH reserve for borrowing', async () => {
|
2020-08-13 11:06:23 +00:00
|
|
|
const {configurator, pool, weth} = testEnv;
|
|
|
|
await configurator.enableBorrowingOnReserve(weth.address, true);
|
|
|
|
const {variableBorrowIndex} = await pool.getReserveData(weth.address);
|
2020-10-06 09:03:51 +00:00
|
|
|
|
|
|
|
const {
|
|
|
|
decimals,
|
|
|
|
ltv,
|
|
|
|
liquidationBonus,
|
|
|
|
liquidationThreshold,
|
|
|
|
reserveFactor,
|
|
|
|
stableBorrowRateEnabled,
|
|
|
|
borrowingEnabled,
|
|
|
|
isActive,
|
|
|
|
isFreezed,
|
|
|
|
} = await pool.getReserveConfigurationData(weth.address);
|
|
|
|
|
2020-06-27 02:13:32 +00:00
|
|
|
expect(borrowingEnabled).to.be.equal(true);
|
2020-10-06 09:03:51 +00:00
|
|
|
expect(isActive).to.be.equal(true);
|
|
|
|
expect(isFreezed).to.be.equal(false);
|
|
|
|
expect(decimals).to.be.equal(18);
|
|
|
|
expect(ltv).to.be.equal(7500);
|
|
|
|
expect(liquidationThreshold).to.be.equal(8000);
|
|
|
|
expect(liquidationBonus).to.be.equal(10500);
|
|
|
|
expect(stableBorrowRateEnabled).to.be.equal(true);
|
|
|
|
expect(reserveFactor).to.be.equal(0);
|
|
|
|
|
2020-06-27 02:13:32 +00:00
|
|
|
expect(variableBorrowIndex.toString()).to.be.equal(RAY);
|
2020-06-12 07:41:30 +00:00
|
|
|
});
|
|
|
|
|
2020-09-16 12:09:42 +00:00
|
|
|
it('Check the onlyAaveAdmin on disableBorrowingOnReserve ', async () => {
|
2020-08-13 11:06:23 +00:00
|
|
|
const {configurator, users, weth} = testEnv;
|
2020-06-12 07:41:30 +00:00
|
|
|
await expect(
|
2020-08-13 11:06:23 +00:00
|
|
|
configurator.connect(users[2].signer).disableBorrowingOnReserve(weth.address),
|
2020-09-16 12:09:42 +00:00
|
|
|
CALLER_NOT_AAVE_ADMIN
|
|
|
|
).to.be.revertedWith(CALLER_NOT_AAVE_ADMIN);
|
2020-06-12 07:41:30 +00:00
|
|
|
});
|
|
|
|
|
2020-09-16 12:09:42 +00:00
|
|
|
it('Check the onlyAaveAdmin on enableBorrowingOnReserve ', async () => {
|
2020-08-13 11:06:23 +00:00
|
|
|
const {configurator, users, weth} = testEnv;
|
2020-06-12 07:41:30 +00:00
|
|
|
await expect(
|
2020-08-13 11:06:23 +00:00
|
|
|
configurator.connect(users[2].signer).enableBorrowingOnReserve(weth.address, true),
|
2020-09-16 12:09:42 +00:00
|
|
|
CALLER_NOT_AAVE_ADMIN
|
|
|
|
).to.be.revertedWith(CALLER_NOT_AAVE_ADMIN);
|
2020-06-12 07:41:30 +00:00
|
|
|
});
|
|
|
|
|
2020-07-13 08:54:08 +00:00
|
|
|
it('Deactivates the ETH reserve as collateral', async () => {
|
2020-08-13 11:06:23 +00:00
|
|
|
const {configurator, pool, weth} = testEnv;
|
|
|
|
await configurator.disableReserveAsCollateral(weth.address);
|
2020-10-06 09:20:45 +00:00
|
|
|
const {
|
|
|
|
decimals,
|
|
|
|
ltv,
|
|
|
|
liquidationBonus,
|
|
|
|
liquidationThreshold,
|
|
|
|
reserveFactor,
|
|
|
|
stableBorrowRateEnabled,
|
|
|
|
borrowingEnabled,
|
|
|
|
isActive,
|
|
|
|
isFreezed,
|
|
|
|
} = await pool.getReserveConfigurationData(weth.address);
|
|
|
|
|
|
|
|
expect(borrowingEnabled).to.be.equal(true);
|
|
|
|
expect(isActive).to.be.equal(true);
|
|
|
|
expect(isFreezed).to.be.equal(false);
|
|
|
|
expect(decimals).to.be.equal(18);
|
|
|
|
expect(ltv).to.be.equal(0);
|
|
|
|
expect(liquidationThreshold).to.be.equal(8000);
|
|
|
|
expect(liquidationBonus).to.be.equal(10500);
|
|
|
|
expect(stableBorrowRateEnabled).to.be.equal(true);
|
|
|
|
expect(reserveFactor).to.be.equal(0);
|
2020-06-12 07:41:30 +00:00
|
|
|
});
|
|
|
|
|
2020-07-13 08:54:08 +00:00
|
|
|
it('Activates the ETH reserve as collateral', async () => {
|
2020-08-13 11:06:23 +00:00
|
|
|
const {configurator, pool, weth} = testEnv;
|
2020-10-06 09:27:53 +00:00
|
|
|
await configurator.enableReserveAsCollateral(weth.address, '7500', '8000', '10500');
|
2020-07-13 08:54:08 +00:00
|
|
|
|
2020-10-06 09:27:53 +00:00
|
|
|
const {
|
|
|
|
decimals,
|
|
|
|
ltv,
|
|
|
|
liquidationBonus,
|
|
|
|
liquidationThreshold,
|
|
|
|
reserveFactor,
|
|
|
|
stableBorrowRateEnabled,
|
|
|
|
borrowingEnabled,
|
|
|
|
isActive,
|
|
|
|
isFreezed,
|
|
|
|
} = await pool.getReserveConfigurationData(weth.address);
|
2020-07-13 08:54:08 +00:00
|
|
|
|
2020-10-06 09:27:53 +00:00
|
|
|
expect(borrowingEnabled).to.be.equal(true);
|
|
|
|
expect(isActive).to.be.equal(true);
|
|
|
|
expect(isFreezed).to.be.equal(false);
|
|
|
|
expect(decimals).to.be.equal(18);
|
|
|
|
expect(ltv).to.be.equal(7500);
|
|
|
|
expect(liquidationThreshold).to.be.equal(8000);
|
|
|
|
expect(liquidationBonus).to.be.equal(10500);
|
|
|
|
expect(stableBorrowRateEnabled).to.be.equal(true);
|
|
|
|
expect(reserveFactor).to.be.equal(0);
|
2020-06-12 07:41:30 +00:00
|
|
|
});
|
|
|
|
|
2020-09-16 12:09:42 +00:00
|
|
|
it('Check the onlyAaveAdmin on disableReserveAsCollateral ', async () => {
|
2020-08-13 11:06:23 +00:00
|
|
|
const {configurator, users, weth} = testEnv;
|
2020-06-12 07:41:30 +00:00
|
|
|
await expect(
|
2020-08-13 11:06:23 +00:00
|
|
|
configurator.connect(users[2].signer).disableReserveAsCollateral(weth.address),
|
2020-09-16 12:09:42 +00:00
|
|
|
CALLER_NOT_AAVE_ADMIN
|
|
|
|
).to.be.revertedWith(CALLER_NOT_AAVE_ADMIN);
|
2020-06-12 07:41:30 +00:00
|
|
|
});
|
|
|
|
|
2020-09-16 12:09:42 +00:00
|
|
|
it('Check the onlyAaveAdmin on enableReserveAsCollateral ', async () => {
|
2020-08-13 11:06:23 +00:00
|
|
|
const {configurator, users, weth} = testEnv;
|
2020-06-12 07:41:30 +00:00
|
|
|
await expect(
|
|
|
|
configurator
|
|
|
|
.connect(users[2].signer)
|
2020-08-13 11:06:23 +00:00
|
|
|
.enableReserveAsCollateral(weth.address, '75', '80', '105'),
|
2020-09-16 12:09:42 +00:00
|
|
|
CALLER_NOT_AAVE_ADMIN
|
|
|
|
).to.be.revertedWith(CALLER_NOT_AAVE_ADMIN);
|
2020-06-12 07:41:30 +00:00
|
|
|
});
|
|
|
|
|
2020-07-13 08:54:08 +00:00
|
|
|
it('Disable stable borrow rate on the ETH reserve', async () => {
|
2020-08-13 11:06:23 +00:00
|
|
|
const {configurator, pool, weth} = testEnv;
|
|
|
|
await configurator.disableReserveStableRate(weth.address);
|
2020-10-06 09:27:53 +00:00
|
|
|
const {
|
|
|
|
decimals,
|
|
|
|
ltv,
|
|
|
|
liquidationBonus,
|
|
|
|
liquidationThreshold,
|
|
|
|
reserveFactor,
|
|
|
|
stableBorrowRateEnabled,
|
|
|
|
borrowingEnabled,
|
|
|
|
isActive,
|
|
|
|
isFreezed,
|
|
|
|
} = await pool.getReserveConfigurationData(weth.address);
|
|
|
|
|
|
|
|
expect(borrowingEnabled).to.be.equal(true);
|
|
|
|
expect(isActive).to.be.equal(true);
|
|
|
|
expect(isFreezed).to.be.equal(false);
|
|
|
|
expect(decimals).to.be.equal(18);
|
|
|
|
expect(ltv).to.be.equal(7500);
|
|
|
|
expect(liquidationThreshold).to.be.equal(8000);
|
|
|
|
expect(liquidationBonus).to.be.equal(10500);
|
2020-06-27 02:13:32 +00:00
|
|
|
expect(stableBorrowRateEnabled).to.be.equal(false);
|
2020-10-06 09:27:53 +00:00
|
|
|
expect(reserveFactor).to.be.equal(0);
|
2020-06-12 07:41:30 +00:00
|
|
|
});
|
|
|
|
|
2020-07-13 08:54:08 +00:00
|
|
|
it('Enables stable borrow rate on the ETH reserve', async () => {
|
2020-08-13 11:06:23 +00:00
|
|
|
const {configurator, pool, weth} = testEnv;
|
|
|
|
await configurator.enableReserveStableRate(weth.address);
|
2020-10-06 09:28:46 +00:00
|
|
|
const {
|
|
|
|
decimals,
|
|
|
|
ltv,
|
|
|
|
liquidationBonus,
|
|
|
|
liquidationThreshold,
|
|
|
|
reserveFactor,
|
|
|
|
stableBorrowRateEnabled,
|
|
|
|
borrowingEnabled,
|
|
|
|
isActive,
|
|
|
|
isFreezed,
|
|
|
|
} = await pool.getReserveConfigurationData(weth.address);
|
|
|
|
|
|
|
|
expect(borrowingEnabled).to.be.equal(true);
|
|
|
|
expect(isActive).to.be.equal(true);
|
|
|
|
expect(isFreezed).to.be.equal(false);
|
|
|
|
expect(decimals).to.be.equal(18);
|
|
|
|
expect(ltv).to.be.equal(7500);
|
|
|
|
expect(liquidationThreshold).to.be.equal(8000);
|
|
|
|
expect(liquidationBonus).to.be.equal(10500);
|
2020-06-27 02:13:32 +00:00
|
|
|
expect(stableBorrowRateEnabled).to.be.equal(true);
|
2020-10-06 09:34:50 +00:00
|
|
|
expect(reserveFactor).to.be.equal(0);
|
2020-06-12 07:41:30 +00:00
|
|
|
});
|
|
|
|
|
2020-09-16 12:09:42 +00:00
|
|
|
it('Check the onlyAaveAdmin on disableReserveStableRate', async () => {
|
2020-08-13 11:06:23 +00:00
|
|
|
const {configurator, users, weth} = testEnv;
|
2020-06-12 07:41:30 +00:00
|
|
|
await expect(
|
2020-08-13 11:06:23 +00:00
|
|
|
configurator.connect(users[2].signer).disableReserveStableRate(weth.address),
|
2020-09-16 12:09:42 +00:00
|
|
|
CALLER_NOT_AAVE_ADMIN
|
|
|
|
).to.be.revertedWith(CALLER_NOT_AAVE_ADMIN);
|
2020-06-12 07:41:30 +00:00
|
|
|
});
|
|
|
|
|
2020-09-16 12:09:42 +00:00
|
|
|
it('Check the onlyAaveAdmin on enableReserveStableRate', async () => {
|
2020-08-13 11:06:23 +00:00
|
|
|
const {configurator, users, weth} = testEnv;
|
2020-06-12 07:41:30 +00:00
|
|
|
await expect(
|
2020-08-13 11:06:23 +00:00
|
|
|
configurator.connect(users[2].signer).enableReserveStableRate(weth.address),
|
2020-09-16 12:09:42 +00:00
|
|
|
CALLER_NOT_AAVE_ADMIN
|
|
|
|
).to.be.revertedWith(CALLER_NOT_AAVE_ADMIN);
|
2020-06-12 07:41:30 +00:00
|
|
|
});
|
|
|
|
|
2020-07-13 08:54:08 +00:00
|
|
|
it('Changes LTV of the reserve', async () => {
|
2020-08-13 11:06:23 +00:00
|
|
|
const {configurator, pool, weth} = testEnv;
|
2020-10-06 09:30:10 +00:00
|
|
|
await configurator.setLtv(weth.address, '6000');
|
2020-10-06 09:34:50 +00:00
|
|
|
const {
|
2020-10-06 09:30:10 +00:00
|
|
|
decimals,
|
|
|
|
ltv,
|
|
|
|
liquidationBonus,
|
|
|
|
liquidationThreshold,
|
|
|
|
reserveFactor,
|
|
|
|
stableBorrowRateEnabled,
|
|
|
|
borrowingEnabled,
|
|
|
|
isActive,
|
|
|
|
isFreezed,
|
|
|
|
} = await pool.getReserveConfigurationData(weth.address);
|
|
|
|
|
|
|
|
expect(borrowingEnabled).to.be.equal(true);
|
|
|
|
expect(isActive).to.be.equal(true);
|
|
|
|
expect(isFreezed).to.be.equal(false);
|
|
|
|
expect(decimals).to.be.equal(18);
|
|
|
|
expect(ltv).to.be.equal(6000);
|
|
|
|
expect(liquidationThreshold).to.be.equal(8000);
|
|
|
|
expect(liquidationBonus).to.be.equal(10500);
|
|
|
|
expect(stableBorrowRateEnabled).to.be.equal(true);
|
|
|
|
expect(reserveFactor).to.be.equal(0);
|
2020-06-12 07:41:30 +00:00
|
|
|
});
|
|
|
|
|
2020-09-16 12:09:42 +00:00
|
|
|
it('Check the onlyAaveAdmin on setLtv', async () => {
|
2020-08-13 11:06:23 +00:00
|
|
|
const {configurator, users, weth} = testEnv;
|
2020-06-12 07:41:30 +00:00
|
|
|
await expect(
|
2020-08-13 11:06:23 +00:00
|
|
|
configurator.connect(users[2].signer).setLtv(weth.address, '75'),
|
2020-09-16 12:09:42 +00:00
|
|
|
CALLER_NOT_AAVE_ADMIN
|
|
|
|
).to.be.revertedWith(CALLER_NOT_AAVE_ADMIN);
|
2020-06-12 07:41:30 +00:00
|
|
|
});
|
|
|
|
|
2020-09-10 11:52:07 +00:00
|
|
|
it('Changes the reserve factor of the reserve', async () => {
|
|
|
|
const {configurator, pool, weth} = testEnv;
|
|
|
|
await configurator.setReserveFactor(weth.address, '1000');
|
2020-10-06 09:34:50 +00:00
|
|
|
const {
|
|
|
|
decimals,
|
|
|
|
ltv,
|
|
|
|
liquidationBonus,
|
|
|
|
liquidationThreshold,
|
|
|
|
reserveFactor,
|
|
|
|
stableBorrowRateEnabled,
|
|
|
|
borrowingEnabled,
|
|
|
|
isActive,
|
|
|
|
isFreezed,
|
|
|
|
} = await pool.getReserveConfigurationData(weth.address);
|
|
|
|
|
|
|
|
expect(borrowingEnabled).to.be.equal(true);
|
|
|
|
expect(isActive).to.be.equal(true);
|
|
|
|
expect(isFreezed).to.be.equal(false);
|
|
|
|
expect(decimals).to.be.equal(18);
|
|
|
|
expect(ltv).to.be.equal(6000);
|
|
|
|
expect(liquidationThreshold).to.be.equal(8000);
|
|
|
|
expect(liquidationBonus).to.be.equal(10500);
|
|
|
|
expect(stableBorrowRateEnabled).to.be.equal(true);
|
|
|
|
expect(reserveFactor).to.be.equal(1000);
|
2020-09-10 11:52:07 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
it('Check the onlyLendingPoolManager on setReserveFactor', async () => {
|
|
|
|
const {configurator, users, weth} = testEnv;
|
|
|
|
await expect(
|
|
|
|
configurator.connect(users[2].signer).setReserveFactor(weth.address, '2000'),
|
2020-09-17 14:37:51 +00:00
|
|
|
CALLER_NOT_AAVE_ADMIN
|
|
|
|
).to.be.revertedWith(CALLER_NOT_AAVE_ADMIN);
|
2020-09-10 11:52:07 +00:00
|
|
|
});
|
|
|
|
|
2020-07-13 08:54:08 +00:00
|
|
|
it('Changes liquidation threshold of the reserve', async () => {
|
2020-08-13 11:06:23 +00:00
|
|
|
const {configurator, pool, weth} = testEnv;
|
2020-10-06 09:34:50 +00:00
|
|
|
await configurator.setLiquidationThreshold(weth.address, '7500');
|
|
|
|
const {
|
|
|
|
decimals,
|
|
|
|
ltv,
|
|
|
|
liquidationBonus,
|
|
|
|
liquidationThreshold,
|
|
|
|
reserveFactor,
|
|
|
|
stableBorrowRateEnabled,
|
|
|
|
borrowingEnabled,
|
|
|
|
isActive,
|
|
|
|
isFreezed,
|
|
|
|
} = await pool.getReserveConfigurationData(weth.address);
|
|
|
|
|
|
|
|
expect(borrowingEnabled).to.be.equal(true);
|
|
|
|
expect(isActive).to.be.equal(true);
|
|
|
|
expect(isFreezed).to.be.equal(false);
|
|
|
|
expect(decimals).to.be.equal(18);
|
|
|
|
expect(ltv).to.be.equal(6000);
|
|
|
|
expect(liquidationThreshold).to.be.equal(7500);
|
|
|
|
expect(liquidationBonus).to.be.equal(10500);
|
|
|
|
expect(stableBorrowRateEnabled).to.be.equal(true);
|
|
|
|
expect(reserveFactor).to.be.equal(1000);
|
2020-06-12 07:41:30 +00:00
|
|
|
});
|
|
|
|
|
2020-09-16 12:09:42 +00:00
|
|
|
it('Check the onlyAaveAdmin on setLiquidationThreshold', async () => {
|
2020-08-13 11:06:23 +00:00
|
|
|
const {configurator, users, weth} = testEnv;
|
2020-06-12 07:41:30 +00:00
|
|
|
await expect(
|
2020-08-13 11:06:23 +00:00
|
|
|
configurator.connect(users[2].signer).setLiquidationThreshold(weth.address, '80'),
|
2020-09-16 12:09:42 +00:00
|
|
|
CALLER_NOT_AAVE_ADMIN
|
|
|
|
).to.be.revertedWith(CALLER_NOT_AAVE_ADMIN);
|
2020-06-12 07:41:30 +00:00
|
|
|
});
|
|
|
|
|
2020-07-13 08:54:08 +00:00
|
|
|
it('Changes liquidation bonus of the reserve', async () => {
|
2020-08-13 11:06:23 +00:00
|
|
|
const {configurator, pool, weth} = testEnv;
|
2020-10-06 09:36:29 +00:00
|
|
|
await configurator.setLiquidationBonus(weth.address, '11000');
|
|
|
|
const {
|
|
|
|
decimals,
|
|
|
|
ltv,
|
|
|
|
liquidationBonus,
|
|
|
|
liquidationThreshold,
|
|
|
|
reserveFactor,
|
|
|
|
stableBorrowRateEnabled,
|
|
|
|
borrowingEnabled,
|
|
|
|
isActive,
|
|
|
|
isFreezed,
|
|
|
|
} = await pool.getReserveConfigurationData(weth.address);
|
|
|
|
|
|
|
|
expect(borrowingEnabled).to.be.equal(true);
|
|
|
|
expect(isActive).to.be.equal(true);
|
|
|
|
expect(isFreezed).to.be.equal(false);
|
|
|
|
expect(decimals).to.be.equal(18);
|
|
|
|
expect(ltv).to.be.equal(6000);
|
|
|
|
expect(liquidationThreshold).to.be.equal(7500);
|
|
|
|
expect(liquidationBonus).to.be.equal(11000);
|
|
|
|
expect(stableBorrowRateEnabled).to.be.equal(true);
|
|
|
|
expect(reserveFactor).to.be.equal(1000);
|
2020-06-12 07:41:30 +00:00
|
|
|
});
|
|
|
|
|
2020-09-16 12:09:42 +00:00
|
|
|
it('Check the onlyAaveAdmin on setLiquidationBonus', async () => {
|
2020-08-13 11:06:23 +00:00
|
|
|
const {configurator, users, weth} = testEnv;
|
2020-06-12 07:41:30 +00:00
|
|
|
await expect(
|
2020-08-13 11:06:23 +00:00
|
|
|
configurator.connect(users[2].signer).setLiquidationBonus(weth.address, '80'),
|
2020-09-16 12:09:42 +00:00
|
|
|
CALLER_NOT_AAVE_ADMIN
|
|
|
|
).to.be.revertedWith(CALLER_NOT_AAVE_ADMIN);
|
2020-06-12 07:41:30 +00:00
|
|
|
});
|
|
|
|
|
2020-09-16 12:09:42 +00:00
|
|
|
it('Check the onlyAaveAdmin on setReserveDecimals', async () => {
|
2020-08-13 11:06:23 +00:00
|
|
|
const {configurator, users, weth} = testEnv;
|
2020-06-12 07:41:30 +00:00
|
|
|
await expect(
|
2020-08-13 11:06:23 +00:00
|
|
|
configurator.connect(users[2].signer).setReserveDecimals(weth.address, '80'),
|
2020-09-16 12:09:42 +00:00
|
|
|
CALLER_NOT_AAVE_ADMIN
|
|
|
|
).to.be.revertedWith(CALLER_NOT_AAVE_ADMIN);
|
2020-06-12 07:41:30 +00:00
|
|
|
});
|
|
|
|
|
2020-09-16 12:09:42 +00:00
|
|
|
it('Check the onlyAaveAdmin on setLiquidationBonus', async () => {
|
2020-08-13 11:06:23 +00:00
|
|
|
const {configurator, users, weth} = testEnv;
|
2020-06-12 07:41:30 +00:00
|
|
|
await expect(
|
2020-08-13 11:06:23 +00:00
|
|
|
configurator.connect(users[2].signer).setLiquidationBonus(weth.address, '80'),
|
2020-09-16 12:09:42 +00:00
|
|
|
CALLER_NOT_AAVE_ADMIN
|
|
|
|
).to.be.revertedWith(CALLER_NOT_AAVE_ADMIN);
|
2020-06-12 07:41:30 +00:00
|
|
|
});
|
|
|
|
|
2020-07-13 08:54:08 +00:00
|
|
|
it('Reverts when trying to disable the DAI reserve with liquidity on it', async () => {
|
|
|
|
const {dai, pool, configurator} = testEnv;
|
2020-09-09 10:47:27 +00:00
|
|
|
const userAddress = await pool.signer.getAddress();
|
2020-07-13 08:54:08 +00:00
|
|
|
await dai.mint(await convertToCurrencyDecimals(dai.address, '1000'));
|
2020-06-12 07:41:30 +00:00
|
|
|
|
|
|
|
//approve protocol to access depositor wallet
|
2020-06-20 23:40:03 +00:00
|
|
|
await dai.approve(pool.address, APPROVAL_AMOUNT_LENDING_POOL);
|
2020-07-13 08:54:08 +00:00
|
|
|
const amountDAItoDeposit = await convertToCurrencyDecimals(dai.address, '1000');
|
2020-06-12 07:41:30 +00:00
|
|
|
|
|
|
|
//user 1 deposits 1000 DAI
|
2020-09-09 10:47:27 +00:00
|
|
|
await pool.deposit(dai.address, amountDAItoDeposit, userAddress, '0');
|
2020-06-12 07:41:30 +00:00
|
|
|
|
|
|
|
await expect(
|
|
|
|
configurator.deactivateReserve(dai.address),
|
2020-09-02 15:54:34 +00:00
|
|
|
RESERVE_LIQUIDITY_NOT_0
|
|
|
|
).to.be.revertedWith(RESERVE_LIQUIDITY_NOT_0);
|
2020-06-12 07:41:30 +00:00
|
|
|
});
|
|
|
|
});
|