mirror of
https://github.com/Instadapp/dsa-connectors.git
synced 2024-07-29 22:37:00 +00:00
fixed test
This commit is contained in:
parent
96573dc193
commit
6a5784d067
|
@ -9,19 +9,17 @@ import { abis } from "../../../scripts/constant/abis";
|
||||||
import { getMasterSigner } from "../../../scripts/tests/getMasterSigner";
|
import { getMasterSigner } from "../../../scripts/tests/getMasterSigner";
|
||||||
import { parseEther, parseUnits } from "ethers/lib/utils";
|
import { parseEther, parseUnits } from "ethers/lib/utils";
|
||||||
import { encodeSpells } from "../../../scripts/tests/encodeSpells";
|
import { encodeSpells } from "../../../scripts/tests/encodeSpells";
|
||||||
|
import encodeFlashcastData from "../../../scripts/tests/encodeFlashcastData";
|
||||||
import { ConnectV2CompoundImport__factory, ConnectV2InstaPoolV4__factory } from "../../../typechain";
|
import { ConnectV2CompoundImport__factory } from "../../../typechain";
|
||||||
const { provider } = waffle;
|
const { provider } = waffle;
|
||||||
|
|
||||||
const encodeFlashcastData = require("../../../scripts/tests/encodeFlashcastData").default;
|
|
||||||
const cEthAddress = "0x4Ddc2D193948926D02f9B1fE9e1daa0718270ED5";
|
const cEthAddress = "0x4Ddc2D193948926D02f9B1fE9e1daa0718270ED5";
|
||||||
const cDaiAddress = "0x5d3a536E4D6DbD6114cc1Ead35777bAB948E3643";
|
const cDaiAddress = "0x5d3a536E4D6DbD6114cc1Ead35777bAB948E3643";
|
||||||
const daiAddress = "0x6B175474E89094C44Da98b954EedeAC495271d0F";
|
const daiAddress = "0x6B175474E89094C44Da98b954EedeAC495271d0F";
|
||||||
const comptrollerAddress = "0x3d9819210A31b4961b30EF54bE2aeD79B9c9Cd3B";
|
const comptrollerAddress = "0x3d9819210A31b4961b30EF54bE2aeD79B9c9Cd3B";
|
||||||
|
|
||||||
describe("Import Compound", function () {
|
describe("Import Compound", function () {
|
||||||
const connectorName = "COMPOUND-IMPORT-C";
|
const connectorName = "COMPOUND-IMPORT-X";
|
||||||
const account = "0x26eD8119c45E3871df446a13F7Fdc9E2C527DaCD";
|
|
||||||
|
|
||||||
const cEthAbi = [
|
const cEthAbi = [
|
||||||
{
|
{
|
||||||
|
@ -51,6 +49,18 @@ describe("Import Compound", function () {
|
||||||
payable: false,
|
payable: false,
|
||||||
stateMutability: "nonpayable",
|
stateMutability: "nonpayable",
|
||||||
type: "function"
|
type: "function"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
constant: false,
|
||||||
|
inputs: [
|
||||||
|
{ internalType: "address", name: "usr", type: "address" },
|
||||||
|
{ internalType: "uint256", name: "wad", type: "uint256" }
|
||||||
|
],
|
||||||
|
name: "approve",
|
||||||
|
outputs: [{ internalType: "bool", name: "", type: "bool" }],
|
||||||
|
payable: false,
|
||||||
|
stateMutability: "nonpayable",
|
||||||
|
type: "function"
|
||||||
}
|
}
|
||||||
];
|
];
|
||||||
|
|
||||||
|
@ -76,6 +86,15 @@ describe("Import Compound", function () {
|
||||||
stateMutability: "nonpayable",
|
stateMutability: "nonpayable",
|
||||||
type: "function",
|
type: "function",
|
||||||
signature: "0xc5ebeaec"
|
signature: "0xc5ebeaec"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
constant: false,
|
||||||
|
inputs: [{ internalType: "address", name: "account", type: "address" }],
|
||||||
|
name: "borrowBalanceCurrent",
|
||||||
|
outputs: [{ internalType: "uint256", name: "", type: "uint256" }],
|
||||||
|
payable: false,
|
||||||
|
stateMutability: "nonpayable",
|
||||||
|
type: "function"
|
||||||
}
|
}
|
||||||
];
|
];
|
||||||
|
|
||||||
|
@ -104,9 +123,7 @@ describe("Import Compound", function () {
|
||||||
}
|
}
|
||||||
];
|
];
|
||||||
|
|
||||||
let connector2;
|
|
||||||
let cEth: Contract, cDai: Contract, comptroller, Dai: any;
|
let cEth: Contract, cDai: Contract, comptroller, Dai: any;
|
||||||
let owner: any;
|
|
||||||
|
|
||||||
let dsaWallet0: any;
|
let dsaWallet0: any;
|
||||||
let masterSigner: Signer;
|
let masterSigner: Signer;
|
||||||
|
@ -115,7 +132,13 @@ describe("Import Compound", function () {
|
||||||
|
|
||||||
const wallets = provider.getWallets();
|
const wallets = provider.getWallets();
|
||||||
const [wallet0, wallet1, wallet2, wallet3] = wallets;
|
const [wallet0, wallet1, wallet2, wallet3] = wallets;
|
||||||
|
let snapshot: any;
|
||||||
|
// this.beforeAll(async () => {
|
||||||
|
// snapshot = await ethers.provider.send("evm_snapshot", []);
|
||||||
|
// });
|
||||||
|
// this.afterAll(async () => {
|
||||||
|
// snapshot = await ethers.provider.send("evm_revert", [snapshot]);
|
||||||
|
// });
|
||||||
before(async () => {
|
before(async () => {
|
||||||
await hre.network.provider.request({
|
await hre.network.provider.request({
|
||||||
method: "hardhat_reset",
|
method: "hardhat_reset",
|
||||||
|
@ -124,7 +147,7 @@ describe("Import Compound", function () {
|
||||||
forking: {
|
forking: {
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
jsonRpcUrl: hre.config.networks.hardhat.forking.url,
|
jsonRpcUrl: hre.config.networks.hardhat.forking.url,
|
||||||
blockNumber: 13300000
|
blockNumber: 14441991
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
|
@ -141,39 +164,22 @@ describe("Import Compound", function () {
|
||||||
});
|
});
|
||||||
console.log("Connector address", connector.address);
|
console.log("Connector address", connector.address);
|
||||||
|
|
||||||
connector2 = await deployAndEnableConnector({
|
|
||||||
connectorName: "INSTAPOOL-C",
|
|
||||||
contractArtifact: ConnectV2InstaPoolV4__factory,
|
|
||||||
signer: masterSigner,
|
|
||||||
connectors: instaConnectorsV2
|
|
||||||
});
|
|
||||||
console.log("Connector address", connector2.address);
|
|
||||||
|
|
||||||
await hre.network.provider.request({
|
|
||||||
method: "hardhat_impersonateAccount",
|
|
||||||
params: [account]
|
|
||||||
});
|
|
||||||
|
|
||||||
await hre.network.provider.send("hardhat_setBalance", [account, ethers.utils.parseEther("100000").toHexString()]);
|
|
||||||
|
|
||||||
owner = await ethers.getSigner(account);
|
|
||||||
|
|
||||||
cEth = new ethers.Contract(cEthAddress, cEthAbi);
|
cEth = new ethers.Contract(cEthAddress, cEthAbi);
|
||||||
cDai = new ethers.Contract(cDaiAddress, cDaiAbi);
|
cDai = new ethers.Contract(cDaiAddress, cDaiAbi);
|
||||||
Dai = new ethers.Contract(daiAddress, abis.basic.erc20);
|
Dai = new ethers.Contract(daiAddress, abis.basic.erc20);
|
||||||
comptroller = new ethers.Contract(comptrollerAddress, comptrollerAbi);
|
comptroller = new ethers.Contract(comptrollerAddress, comptrollerAbi);
|
||||||
|
|
||||||
// deposit ether to Compound: ETH-A
|
// deposit ether to Compound: ETH-A
|
||||||
await cEth.connect(owner).mint({
|
await cEth.connect(wallet0).mint({
|
||||||
value: parseEther("9")
|
value: parseEther("9")
|
||||||
});
|
});
|
||||||
|
|
||||||
// enter markets with deposits
|
// enter markets with deposits
|
||||||
const cTokens = [cEth.address];
|
const cTokens = [cEth.address];
|
||||||
await comptroller.connect(owner).enterMarkets(cTokens);
|
await comptroller.connect(wallet0).enterMarkets(cTokens);
|
||||||
|
|
||||||
// borrow dai from Compound: DAI-A
|
// borrow dai from Compound: DAI-A
|
||||||
await cDai.connect(owner).borrow(parseUnits("100"));
|
await cDai.connect(wallet0).borrow(parseUnits("100"));
|
||||||
});
|
});
|
||||||
|
|
||||||
describe("Deployment", async () => {
|
describe("Deployment", async () => {
|
||||||
|
@ -184,23 +190,22 @@ describe("Import Compound", function () {
|
||||||
|
|
||||||
describe("checks", async () => {
|
describe("checks", async () => {
|
||||||
it("Should check user COMPOUND position", async () => {
|
it("Should check user COMPOUND position", async () => {
|
||||||
const ethExchangeRate = (await cEth.connect(owner).callStatic.exchangeRateCurrent()) / 1e28;
|
const ethExchangeRate = (await cEth.connect(wallet0).callStatic.exchangeRateCurrent()) / 1e28;
|
||||||
expect(new BigNumber(await cEth.connect(owner).balanceOf(owner.address)).dividedBy(1e8).toFixed(0)).to.eq(
|
expect(new BigNumber(await cEth.connect(wallet0).balanceOf(wallet0.address)).dividedBy(1e8).toFixed(0)).to.eq(
|
||||||
new BigNumber(9).dividedBy(ethExchangeRate).toFixed(0)
|
new BigNumber(9).dividedBy(ethExchangeRate).toFixed(0)
|
||||||
);
|
);
|
||||||
expect(await Dai.connect(owner).balanceOf(owner.address)).to.eq("100000000000000000000");
|
expect(await Dai.connect(wallet0).balanceOf(wallet0.address)).to.eq("100000000000000000000");
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
describe("DSA wallet setup", async () => {
|
describe("DSA wallet setup", async () => {
|
||||||
it("Should build DSA v2", async () => {
|
it("Should build DSA v2", async () => {
|
||||||
dsaWallet0 = await buildDSAv2(owner.address);
|
dsaWallet0 = await buildDSAv2(wallet0.address);
|
||||||
console.log(dsaWallet0.address);
|
|
||||||
expect(!!dsaWallet0.address).to.be.true;
|
expect(!!dsaWallet0.address).to.be.true;
|
||||||
});
|
});
|
||||||
|
|
||||||
it("Deposit ETH into DSA wallet", async function () {
|
it("Deposit ETH into DSA wallet", async function () {
|
||||||
await owner.sendTransaction({
|
await wallet0.sendTransaction({
|
||||||
to: dsaWallet0.address,
|
to: dsaWallet0.address,
|
||||||
value: ethers.utils.parseEther("10")
|
value: ethers.utils.parseEther("10")
|
||||||
});
|
});
|
||||||
|
@ -210,17 +215,27 @@ describe("Import Compound", function () {
|
||||||
|
|
||||||
describe("Compound position migration", async () => {
|
describe("Compound position migration", async () => {
|
||||||
it("Should migrate Compound position", async () => {
|
it("Should migrate Compound position", async () => {
|
||||||
const amount = new BigNumber(ethers.utils.parseEther("100").toString()).multipliedBy(9).dividedBy(1e4);
|
const tx0 = await cEth
|
||||||
|
.connect(wallet0)
|
||||||
|
.approve(dsaWallet0.address, await cEth.connect(wallet0).balanceOf(wallet0.address));
|
||||||
|
|
||||||
|
await tx0.wait();
|
||||||
|
|
||||||
|
// const amount0 = await cDai.connect(wallet0).callStatic.borrowBalanceCurrent(wallet0.address);
|
||||||
|
const amount0 = new BigNumber("100000007061117456728");
|
||||||
|
const amount = new BigNumber(amount0.toString()).multipliedBy(5).dividedBy(1e4);
|
||||||
|
|
||||||
|
const amountWithFee = amount0.plus(amount);
|
||||||
const flashSpells = [
|
const flashSpells = [
|
||||||
{
|
{
|
||||||
connector: "COMPOUND-IMPORT-C",
|
connector: "COMPOUND-IMPORT-X",
|
||||||
method: "importCompound",
|
method: "importCompound",
|
||||||
args: [owner.address, ["ETH-A"], ["DAI-A"], [amount.toString()]]
|
args: [wallet0.address, ["ETH-A"], ["DAI-A"], [amount.toFixed(0)]]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
connector: "INSTAPOOL-C",
|
connector: "INSTAPOOL-C",
|
||||||
method: "flashPayback",
|
method: "flashPayback",
|
||||||
args: [daiAddress, amount, 0, 0]
|
args: [daiAddress, amountWithFee.toFixed(0), 0, 0]
|
||||||
}
|
}
|
||||||
];
|
];
|
||||||
|
|
||||||
|
@ -228,10 +243,10 @@ describe("Import Compound", function () {
|
||||||
{
|
{
|
||||||
connector: "INSTAPOOL-C",
|
connector: "INSTAPOOL-C",
|
||||||
method: "flashBorrowAndCast",
|
method: "flashBorrowAndCast",
|
||||||
args: [daiAddress, ethers.utils.parseEther("100"), 0, encodeFlashcastData(flashSpells), "0x"]
|
args: [daiAddress, amount0.toString(), 5, encodeFlashcastData(flashSpells), "0x"]
|
||||||
}
|
}
|
||||||
];
|
];
|
||||||
const tx = await dsaWallet0.connect(owner).cast(...encodeSpells(spells), owner.address);
|
const tx = await dsaWallet0.connect(wallet0).cast(...encodeSpells(spells), wallet0.address);
|
||||||
const receipt = await tx.wait();
|
const receipt = await tx.wait();
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
Loading…
Reference in New Issue
Block a user