mirror of
https://github.com/Instadapp/dsa-connectors.git
synced 2024-07-29 22:37:00 +00:00
testcases updated
This commit is contained in:
parent
cc8e7b71b0
commit
dfe82d308d
|
@ -20,6 +20,8 @@ const DAI = '0x6b175474e89094c44da98b954eedeac495271d0f'
|
||||||
const ACC_DAI = '0xcd6Eb888e76450eF584E8B51bB73c76ffBa21FF2'
|
const ACC_DAI = '0xcd6Eb888e76450eF584E8B51bB73c76ffBa21FF2'
|
||||||
const Dai = parseUnits('1', 18)
|
const Dai = parseUnits('1', 18)
|
||||||
|
|
||||||
|
const user = "0x41bc7d0687e6cea57fa26da78379dfdc5627c56d"
|
||||||
|
|
||||||
const token_usdc = new ethers.Contract(
|
const token_usdc = new ethers.Contract(
|
||||||
USDC,
|
USDC,
|
||||||
IERC20Minimal__factory.abi,
|
IERC20Minimal__factory.abi,
|
||||||
|
@ -49,7 +51,7 @@ describe("Morpho-Aave", function () {
|
||||||
forking: {
|
forking: {
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
jsonRpcUrl: hre.config.networks.hardhat.forking.url,
|
jsonRpcUrl: hre.config.networks.hardhat.forking.url,
|
||||||
blockNumber: 15718631,
|
blockNumber: 15714501,
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
],
|
],
|
||||||
|
@ -81,13 +83,13 @@ describe("Morpho-Aave", function () {
|
||||||
expect(!!dsaWallet0.address).to.be.true;
|
expect(!!dsaWallet0.address).to.be.true;
|
||||||
});
|
});
|
||||||
|
|
||||||
it("Deposit 10 ETH into DSA wallet", async function () {
|
it("Deposit 1000 ETH into DSA wallet", async function () {
|
||||||
await wallet0.sendTransaction({
|
await wallet0.sendTransaction({
|
||||||
to: dsaWallet0.address,
|
to: dsaWallet0.address,
|
||||||
value: parseEther("10"),
|
value: parseEther("1000"),
|
||||||
});
|
});
|
||||||
expect(await ethers.provider.getBalance(dsaWallet0.address)).to.be.gte(
|
expect(await ethers.provider.getBalance(dsaWallet0.address)).to.be.gte(
|
||||||
parseEther("10")
|
parseEther("1000")
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -138,12 +140,12 @@ describe("Morpho-Aave", function () {
|
||||||
|
|
||||||
describe("Main", function () {
|
describe("Main", function () {
|
||||||
|
|
||||||
it("Should deposit ETH max", async function () {
|
it("Should deposit 10 ETH", async function () {
|
||||||
const spells = [
|
const spells = [
|
||||||
{
|
{
|
||||||
connector: connectorName,
|
connector: connectorName,
|
||||||
method: "deposit",
|
method: "deposit",
|
||||||
args: [tokens.eth.address, tokens.eth.aTokenAddress, dsaMaxValue, "0", "0"], // 10 ETH
|
args: [tokens.eth.address, tokens.eth.aTokenAddress, "10000000000000000000", "0", "0"], // 10 ETH
|
||||||
},
|
},
|
||||||
];
|
];
|
||||||
|
|
||||||
|
@ -153,7 +155,7 @@ describe("Morpho-Aave", function () {
|
||||||
|
|
||||||
await tx.wait();
|
await tx.wait();
|
||||||
expect(expect(await ethers.provider.getBalance(dsaWallet0.address)).to.be.lte(
|
expect(expect(await ethers.provider.getBalance(dsaWallet0.address)).to.be.lte(
|
||||||
parseUnits('0', 18))
|
parseUnits('990', 18))
|
||||||
);
|
);
|
||||||
})
|
})
|
||||||
|
|
||||||
|
@ -176,6 +178,25 @@ describe("Morpho-Aave", function () {
|
||||||
);
|
);
|
||||||
})
|
})
|
||||||
|
|
||||||
|
it("Should deposit 100 USDC on behalf", async function () {
|
||||||
|
const spells = [
|
||||||
|
{
|
||||||
|
connector: connectorName,
|
||||||
|
method: "depositOnBehalf",
|
||||||
|
args: [tokens.usdc.address, tokens.usdc.aTokenAddress, user, "100000000", "0", "0"], // 100 USDC
|
||||||
|
},
|
||||||
|
];
|
||||||
|
|
||||||
|
const tx = await dsaWallet0
|
||||||
|
.connect(wallet0)
|
||||||
|
.cast(...encodeSpells(spells), wallet1.getAddress());
|
||||||
|
|
||||||
|
await tx.wait();
|
||||||
|
expect(await token_usdc.connect(wallet0).balanceOf(dsaWallet0.address)).to.be.lte(
|
||||||
|
parseUnits('390', 18)
|
||||||
|
);
|
||||||
|
})
|
||||||
|
|
||||||
it("Should borrow DAI into DSA", async function () {
|
it("Should borrow DAI into DSA", async function () {
|
||||||
const spells = [
|
const spells = [
|
||||||
{
|
{
|
||||||
|
@ -213,6 +234,25 @@ describe("Morpho-Aave", function () {
|
||||||
);
|
);
|
||||||
})
|
})
|
||||||
|
|
||||||
|
it("Should payback ETH on behalf", async function () {
|
||||||
|
const spells = [
|
||||||
|
{
|
||||||
|
connector: connectorName,
|
||||||
|
method: "paybackOnBehalf",
|
||||||
|
args: [tokens.eth.address, tokens.eth.aTokenAddress, user, dsaMaxValue, "0", "0"], // Max ETH
|
||||||
|
},
|
||||||
|
];
|
||||||
|
|
||||||
|
const tx = await dsaWallet0
|
||||||
|
.connect(wallet0)
|
||||||
|
.cast(...encodeSpells(spells), wallet1.getAddress());
|
||||||
|
|
||||||
|
await tx.wait();
|
||||||
|
expect(await ethers.provider.getBalance(dsaWallet0.address)).to.be.lte(
|
||||||
|
parseUnits('125', 18)
|
||||||
|
);
|
||||||
|
})
|
||||||
|
|
||||||
it("Should withdraw ETH max", async function () {
|
it("Should withdraw ETH max", async function () {
|
||||||
const spells = [
|
const spells = [
|
||||||
{
|
{
|
||||||
|
@ -228,7 +268,7 @@ describe("Morpho-Aave", function () {
|
||||||
|
|
||||||
await tx.wait();
|
await tx.wait();
|
||||||
expect(expect(await ethers.provider.getBalance(dsaWallet0.address)).to.be.gte(
|
expect(expect(await ethers.provider.getBalance(dsaWallet0.address)).to.be.gte(
|
||||||
parseUnits('10', 18))
|
parseUnits('134', 18))
|
||||||
);
|
);
|
||||||
})
|
})
|
||||||
|
|
||||||
|
@ -247,7 +287,7 @@ describe("Morpho-Aave", function () {
|
||||||
|
|
||||||
await tx.wait();
|
await tx.wait();
|
||||||
expect(expect(await token_usdc.connect(wallet0).balanceOf(dsaWallet0.address)).to.be.gte(
|
expect(expect(await token_usdc.connect(wallet0).balanceOf(dsaWallet0.address)).to.be.gte(
|
||||||
parseUnits('498', 6))
|
parseUnits('398', 6))
|
||||||
);
|
);
|
||||||
})
|
})
|
||||||
});
|
});
|
||||||
|
|
|
@ -18,7 +18,9 @@ const Usdc = parseUnits('500', 6)
|
||||||
|
|
||||||
const DAI = '0x6b175474e89094c44da98b954eedeac495271d0f'
|
const DAI = '0x6b175474e89094c44da98b954eedeac495271d0f'
|
||||||
const ACC_DAI = '0xcd6Eb888e76450eF584E8B51bB73c76ffBa21FF2'
|
const ACC_DAI = '0xcd6Eb888e76450eF584E8B51bB73c76ffBa21FF2'
|
||||||
const Dai = parseUnits('1', 18)
|
const Dai = parseUnits('400000', 18)
|
||||||
|
|
||||||
|
const user = '0x5dd596c901987a2b28c38a9c1dfbf86fffc15d77'
|
||||||
|
|
||||||
const token_usdc = new ethers.Contract(
|
const token_usdc = new ethers.Contract(
|
||||||
USDC,
|
USDC,
|
||||||
|
@ -49,7 +51,7 @@ describe("Morpho-Compound", function () {
|
||||||
forking: {
|
forking: {
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
jsonRpcUrl: hre.config.networks.hardhat.forking.url,
|
jsonRpcUrl: hre.config.networks.hardhat.forking.url,
|
||||||
blockNumber: 15718631,
|
blockNumber: 15714501,
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
],
|
],
|
||||||
|
@ -113,7 +115,7 @@ describe("Morpho-Compound", function () {
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
|
|
||||||
it("Deposit 1 DAI into DSA wallet", async function () {
|
it("Deposit 400000 DAI into DSA wallet", async function () {
|
||||||
|
|
||||||
await hre.network.provider.request({
|
await hre.network.provider.request({
|
||||||
method: 'hardhat_impersonateAccount',
|
method: 'hardhat_impersonateAccount',
|
||||||
|
@ -131,7 +133,7 @@ describe("Morpho-Compound", function () {
|
||||||
await token_dai.connect(wallet0).transfer(dsaWallet0.address, Dai);
|
await token_dai.connect(wallet0).transfer(dsaWallet0.address, Dai);
|
||||||
|
|
||||||
expect(await token_dai.connect(masterSigner).balanceOf(dsaWallet0.address)).to.be.gte(
|
expect(await token_dai.connect(masterSigner).balanceOf(dsaWallet0.address)).to.be.gte(
|
||||||
parseUnits('1', 18)
|
parseUnits('400000', 18)
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
@ -176,6 +178,25 @@ describe("Morpho-Compound", function () {
|
||||||
);
|
);
|
||||||
})
|
})
|
||||||
|
|
||||||
|
it("Should deposit 100 USDC on behalf", async function () {
|
||||||
|
const spells = [
|
||||||
|
{
|
||||||
|
connector: connectorName,
|
||||||
|
method: "depositOnBehalf",
|
||||||
|
args: [tokens.usdc.address, tokens.usdc.cTokenAddress, user, "100000000", "0", "0"], // 100 USDC
|
||||||
|
},
|
||||||
|
];
|
||||||
|
|
||||||
|
const tx = await dsaWallet0
|
||||||
|
.connect(wallet0)
|
||||||
|
.cast(...encodeSpells(spells), wallet1.getAddress());
|
||||||
|
|
||||||
|
await tx.wait();
|
||||||
|
expect(await token_usdc.connect(wallet0).balanceOf(dsaWallet0.address)).to.be.lte(
|
||||||
|
parseUnits('390', 18)
|
||||||
|
);
|
||||||
|
})
|
||||||
|
|
||||||
it("Should borrow DAI into DSA", async function () {
|
it("Should borrow DAI into DSA", async function () {
|
||||||
const spells = [
|
const spells = [
|
||||||
{
|
{
|
||||||
|
@ -191,10 +212,10 @@ describe("Morpho-Compound", function () {
|
||||||
|
|
||||||
await tx.wait();
|
await tx.wait();
|
||||||
expect(await token_dai.connect(masterSigner).balanceOf(dsaWallet0.address))
|
expect(await token_dai.connect(masterSigner).balanceOf(dsaWallet0.address))
|
||||||
.to.be.gte(parseUnits('11', 18));
|
.to.be.gte(parseUnits('400010', 18));
|
||||||
})
|
})
|
||||||
|
|
||||||
it("Should payback DAI MAX", async function () {
|
it("Should payback DAI max", async function () {
|
||||||
const spells = [
|
const spells = [
|
||||||
{
|
{
|
||||||
connector: connectorName,
|
connector: connectorName,
|
||||||
|
@ -209,10 +230,26 @@ describe("Morpho-Compound", function () {
|
||||||
|
|
||||||
await tx.wait();
|
await tx.wait();
|
||||||
expect(await token_dai.connect(masterSigner).balanceOf(dsaWallet0.address)).to.be.lte(
|
expect(await token_dai.connect(masterSigner).balanceOf(dsaWallet0.address)).to.be.lte(
|
||||||
parseUnits('1', 18)
|
parseUnits('400000', 18)
|
||||||
);
|
);
|
||||||
})
|
})
|
||||||
|
|
||||||
|
it("Should payback DAI on behalf", async function () {
|
||||||
|
const spells = [
|
||||||
|
{
|
||||||
|
connector: connectorName,
|
||||||
|
method: "paybackOnBehalf",
|
||||||
|
args: [tokens.dai.address, tokens.dai.cTokenAddress, user, dsaMaxValue, "0", "0"],
|
||||||
|
},
|
||||||
|
];
|
||||||
|
|
||||||
|
const tx = await dsaWallet0
|
||||||
|
.connect(wallet0)
|
||||||
|
.cast(...encodeSpells(spells), wallet1.getAddress());
|
||||||
|
|
||||||
|
await tx.wait();
|
||||||
|
})
|
||||||
|
|
||||||
it("Should withdraw ETH max", async function () {
|
it("Should withdraw ETH max", async function () {
|
||||||
const spells = [
|
const spells = [
|
||||||
{
|
{
|
||||||
|
@ -231,24 +268,5 @@ describe("Morpho-Compound", function () {
|
||||||
parseUnits('10', 18))
|
parseUnits('10', 18))
|
||||||
);
|
);
|
||||||
})
|
})
|
||||||
|
|
||||||
it("Should withdraw 8 USDC max", async function () {
|
|
||||||
const spells = [
|
|
||||||
{
|
|
||||||
connector: connectorName,
|
|
||||||
method: "withdraw",
|
|
||||||
args: [tokens.usdc.address, tokens.usdc.cTokenAddress, "8000000", "0", "0"], // 8 USDC
|
|
||||||
},
|
|
||||||
];
|
|
||||||
|
|
||||||
const tx = await dsaWallet0
|
|
||||||
.connect(wallet0)
|
|
||||||
.cast(...encodeSpells(spells), wallet1.getAddress());
|
|
||||||
|
|
||||||
await tx.wait();
|
|
||||||
expect(expect(await token_usdc.connect(wallet0).balanceOf(dsaWallet0.address)).to.be.gte(
|
|
||||||
parseUnits('498', 6))
|
|
||||||
);
|
|
||||||
})
|
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
Loading…
Reference in New Issue
Block a user