Gelato-automations/test/unit/connectors/0_ConnectGelatoProviderPayment.test.js

236 lines
6.8 KiB
JavaScript
Raw Normal View History

2020-11-16 16:55:04 +00:00
const { expect } = require("chai");
const hre = require("hardhat");
2020-11-16 16:55:04 +00:00
const { ethers, deployments } = hre;
2020-10-19 23:16:23 +00:00
const GelatoCoreLib = require("@gelatonetwork/core");
2020-10-19 23:16:23 +00:00
// #region Contracts ABI
2020-11-15 14:08:12 +00:00
const ConnectMaker = require("../../../pre-compiles/ConnectMaker.json");
const GetCdps = require("../../../pre-compiles/GetCdps.json");
const DssCdpManager = require("../../../pre-compiles/DssCdpManager.json");
const ConnectBasic = require("../../../pre-compiles/ConnectBasic.json");
const InstaList = require("../../../pre-compiles/InstaList.json");
const InstaAccount = require("../../../pre-compiles/InstaAccount.json");
const InstaIndex = require("../../../pre-compiles/InstaIndex.json");
const IERC20 = require("../../../pre-compiles/IERC20.json");
2020-10-19 23:16:23 +00:00
// #endregion
describe("ConnectGelatoProviderPayment Unit Test", function () {
2020-10-19 23:16:23 +00:00
this.timeout(0);
if (hre.network.name !== "hardhat") {
console.error("Test Suite is meant to be run on hardhat only");
2020-10-19 23:16:23 +00:00
process.exit(1);
}
let userWallet;
let userAddress;
let gelatoProviderWallet;
let gelatoProviderAddress;
2020-10-19 23:16:23 +00:00
let gelatoCore;
2020-10-19 23:16:23 +00:00
let instaList;
let instaIndex;
2020-11-02 10:51:49 +00:00
let DAI;
2020-10-19 23:16:23 +00:00
let connectBasic;
let getCdps;
let dssCdpManager;
let connectGelatoProviderPayment;
let dsa;
let cdpId;
beforeEach(async function () {
// Deploy dependencies
await deployments.fixture();
2020-10-19 23:16:23 +00:00
// Get Test Wallet for local testnet
[userWallet, gelatoProviderWallet] = await ethers.getSigners();
2020-10-19 23:16:23 +00:00
userAddress = await userWallet.getAddress();
gelatoProviderAddress = await gelatoProviderWallet.getAddress();
2020-10-19 23:16:23 +00:00
gelatoCore = await ethers.getContractAt(
GelatoCoreLib.GelatoCore.abi,
hre.network.config.GelatoCore
);
// Hardhat default accounts prefilled with 100 ETH
2020-10-19 23:16:23 +00:00
expect(await userWallet.getBalance()).to.be.gt(
ethers.utils.parseEther("10")
);
instaIndex = await ethers.getContractAt(
InstaIndex.abi,
hre.network.config.InstaIndex
2020-10-19 23:16:23 +00:00
);
instaList = await ethers.getContractAt(
InstaList.abi,
hre.network.config.InstaList
2020-10-19 23:16:23 +00:00
);
connectBasic = await ethers.getContractAt(
ConnectBasic.abi,
hre.network.config.ConnectBasic
2020-10-19 23:16:23 +00:00
);
getCdps = await ethers.getContractAt(
GetCdps.abi,
hre.network.config.GetCdps
2020-10-19 23:16:23 +00:00
);
dssCdpManager = await ethers.getContractAt(
DssCdpManager.abi,
hre.network.config.DssCdpManager
2020-10-19 23:16:23 +00:00
);
2020-11-02 10:51:49 +00:00
DAI = await ethers.getContractAt(IERC20.abi, hre.network.config.DAI);
2020-10-19 23:16:23 +00:00
// ========== Test Setup ============
connectGelatoProviderPayment = await ethers.getContract(
2020-10-19 23:16:23 +00:00
"ConnectGelatoProviderPayment"
);
// ========== Create DeFi Smart Account for User account ============
const dsaAccountCount = await instaList.accounts();
await expect(instaIndex.build(userAddress, 1, userAddress)).to.emit(
instaIndex,
"LogAccountCreated"
);
const dsaID = dsaAccountCount.add(1);
await expect(await instaList.accounts()).to.be.equal(dsaID);
// ========== Instantiate the DSA ============
dsa = await ethers.getContractAt(
InstaAccount.abi,
await instaList.accountAddr(dsaID)
);
});
it("#1: ConnectGelatoProviderPayment should have been deployed with providerAddress", async function () {
expect(await connectGelatoProviderPayment.gelatoProvider()).to.be.eq(
gelatoProviderAddress
);
});
it("#2: setProvider should revert for AddressZero", async function () {
await expect(
connectGelatoProviderPayment.setProvider(ethers.constants.AddressZero)
).to.be.revertedWith("ConnectGelatoProviderPayment.noAddressZeroProvider");
});
it("#3: setProvider should change the provider address", async function () {
await connectGelatoProviderPayment.setProvider(userAddress);
2020-11-03 13:25:36 +00:00
expect(await connectGelatoProviderPayment.gelatoProvider()).to.be.equal(
userAddress
);
});
it("#4: payProvider should pay to Provider 300 Dai", async function () {
const providerDAIBalanceBefore = await DAI.balanceOf(gelatoProviderAddress);
2020-10-19 23:16:23 +00:00
await dsa.cast(
[hre.network.config.ConnectMaker],
2020-10-19 23:16:23 +00:00
[
await hre.run("abi-encode-withselector", {
2020-10-19 23:16:23 +00:00
abi: ConnectMaker.abi,
functionname: "open",
inputs: ["ETH-A"],
}),
],
userAddress
);
const cdps = await getCdps.getCdpsAsc(dssCdpManager.address, dsa.address);
2020-10-19 23:16:23 +00:00
cdpId = String(cdps.ids[0]);
expect(cdps.ids[0].isZero()).to.be.false;
await dsa.cast(
[hre.network.config.ConnectMaker],
2020-10-19 23:16:23 +00:00
[
await hre.run("abi-encode-withselector", {
2020-10-19 23:16:23 +00:00
abi: ConnectMaker.abi,
functionname: "deposit",
inputs: [cdpId, ethers.utils.parseEther("10"), 0, 0],
}),
],
userAddress,
{
value: ethers.utils.parseEther("10"),
}
);
await dsa.cast(
[hre.network.config.ConnectMaker],
2020-10-19 23:16:23 +00:00
[
await hre.run("abi-encode-withselector", {
2020-10-19 23:16:23 +00:00
abi: ConnectMaker.abi,
functionname: "borrow",
inputs: [cdpId, ethers.utils.parseUnits("1000", 18), 0, 0],
}),
],
userAddress
);
2020-11-02 10:51:49 +00:00
expect(await DAI.balanceOf(dsa.address)).to.be.equal(
2020-10-19 23:16:23 +00:00
ethers.utils.parseEther("1000")
);
await dsa.cast(
[connectGelatoProviderPayment.address],
[
await hre.run("abi-encode-withselector", {
abi: (
await hre.artifacts.readArtifact("ConnectGelatoProviderPayment")
).abi,
2020-10-19 23:16:23 +00:00
functionname: "payProvider",
inputs: [DAI.address, ethers.utils.parseUnits("300", 18), 0, 0],
2020-10-19 23:16:23 +00:00
}),
],
userAddress
);
expect(await DAI.balanceOf(gelatoProviderAddress)).to.be.equal(
2020-10-19 23:16:23 +00:00
providerDAIBalanceBefore.add(ethers.utils.parseUnits("300", 18))
);
});
it("#5: payProvider should pay to Provider 1 ether", async function () {
const providerBalanceOnGelatoCoreBefore = await gelatoCore.providerFunds(
gelatoProviderAddress
);
2020-10-19 23:16:23 +00:00
await dsa.cast(
[connectBasic.address, connectGelatoProviderPayment.address],
[
await hre.run("abi-encode-withselector", {
2020-10-19 23:16:23 +00:00
abi: ConnectBasic.abi,
functionname: "deposit",
inputs: [
"0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE",
ethers.utils.parseEther("1"),
0,
"105",
],
}),
await hre.run("abi-encode-withselector", {
abi: (
await hre.artifacts.readArtifact("ConnectGelatoProviderPayment")
).abi,
2020-10-19 23:16:23 +00:00
functionname: "payProvider",
inputs: ["0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE", 0, "105", 0],
2020-10-19 23:16:23 +00:00
}),
],
userAddress,
{
value: ethers.utils.parseEther("1"),
}
);
expect(await gelatoCore.providerFunds(gelatoProviderAddress)).to.be.equal(
providerBalanceOnGelatoCoreBefore.add(ethers.utils.parseEther("1"))
2020-10-19 23:16:23 +00:00
);
});
});