mirror of
				https://github.com/Instadapp/dsa-connectors-2.0.git
				synced 2024-07-29 21:57:39 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			168 lines
		
	
	
		
			6.0 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			168 lines
		
	
	
		
			6.0 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import hre from "hardhat";
 | |
| import { expect } from "chai";
 | |
| const { ethers } = hre;
 | |
| import { deployAndEnableConnector } from "../../../scripts/tests/deployAndEnableConnector";
 | |
| import { buildDSAv2 } from "../../../scripts/tests/buildDSAv2";
 | |
| import { encodeSpells } from "../../../scripts/tests/encodeSpells";
 | |
| import { getMasterSigner } from "../../../scripts/tests/getMasterSigner";
 | |
| import { addresses } from "../../../scripts/tests/mainnet/addresses";
 | |
| import { abis } from "../../../scripts/constant/abis";
 | |
| import { ConnectV2WEETH__factory } from "../../../typechain";
 | |
| import type { Signer, Contract } from "ethers";
 | |
| 
 | |
| describe("Wrapping / Unwrapping eETH", function () {
 | |
|   const connectorName = "weETH-test";
 | |
| 
 | |
|   let dsaWallet0: Contract;
 | |
|   let wallet0: Signer, wallet1: Signer;
 | |
|   let masterSigner: Signer;
 | |
|   let instaConnectorsV2: Contract;
 | |
|   let connector: Contract;
 | |
| 
 | |
|   before(async () => {
 | |
|     [wallet0, wallet1] = await ethers.getSigners();
 | |
|     masterSigner = await getMasterSigner();
 | |
|     instaConnectorsV2 = await ethers.getContractAt(
 | |
|       abis.core.connectorsV2,
 | |
|       addresses.core.connectorsV2
 | |
|     );
 | |
|     connector = await deployAndEnableConnector({
 | |
|       connectorName,
 | |
|       contractArtifact: ConnectV2WEETH__factory,
 | |
|       signer: masterSigner,
 | |
|       connectors: instaConnectorsV2,
 | |
|     });
 | |
|     console.log("Connector address", connector.address);
 | |
|   });
 | |
| 
 | |
|   it("Should have contracts deployed.", async function () {
 | |
|     expect(!!instaConnectorsV2.address).to.be.true;
 | |
|     expect(!!connector.address).to.be.true;
 | |
|     expect(!!(await masterSigner.getAddress())).to.be.true;
 | |
|   });
 | |
| 
 | |
|   describe("DSA wallet setup", function () {
 | |
|     it("Should build DSA v2", async function () {
 | |
|       dsaWallet0 = await buildDSAv2(await wallet0.getAddress());
 | |
|       expect(!!dsaWallet0.address).to.be.true;
 | |
|     });
 | |
| 
 | |
|     it("Deposit ETH into DSA wallet", async function () {
 | |
|       await wallet0.sendTransaction({
 | |
|         to: dsaWallet0.address,
 | |
|         value: ethers.utils.parseEther("10"),
 | |
|       });
 | |
|       expect(await ethers.provider.getBalance(dsaWallet0.address)).to.be.gte(
 | |
|         ethers.utils.parseEther("10")
 | |
|       );
 | |
|     });
 | |
| 
 | |
|     it("Topup eETH into DSA wallet", async function () {
 | |
|       const eETHTAddress = "0x35fA164735182de50811E8e2E824cFb9B6118ac2";
 | |
|       const IERC20ABI = [
 | |
|         "function approve(address spender, uint256 amount) external returns (bool)",
 | |
|         "function balanceOf(address account) external view returns (uint256)",
 | |
|         "function transfer(address recipient, uint256 amount) external returns (bool)",
 | |
|       ];
 | |
|       const eETHHolder = "0xCd5fE23C85820F7B72D0926FC9b05b43E359b7ee";
 | |
|       const amount = ethers.utils.parseEther("10");
 | |
| 
 | |
|       const eETHContract = await ethers.getContractAt(IERC20ABI, eETHTAddress);
 | |
|       await hre.network.provider.send("hardhat_setBalance", [
 | |
|         eETHHolder,
 | |
|         "0x56BC75E2D63100000",
 | |
|       ]);
 | |
| 
 | |
|       console.log(
 | |
|         "Holder eETH Balance before topup:",
 | |
|         ethers.utils.formatEther(await eETHContract.balanceOf(eETHHolder))
 | |
|       );
 | |
|       console.log(
 | |
|         "holder ETH Balance before topup:",
 | |
|         ethers.utils.formatEther(await ethers.provider.getBalance(eETHHolder))
 | |
|       );
 | |
|       await hre.network.provider.request({
 | |
|         method: "hardhat_impersonateAccount",
 | |
|         params: [eETHHolder],
 | |
|       });
 | |
|       const eETHHolderSigner = await ethers.getSigner(eETHHolder);
 | |
|       await eETHContract
 | |
|         .connect(eETHHolderSigner)
 | |
|         .approve(dsaWallet0.address, amount);
 | |
|       await eETHContract
 | |
|         .connect(eETHHolderSigner)
 | |
|         .transfer(dsaWallet0.address, amount);
 | |
|       const balance = await eETHContract.balanceOf(dsaWallet0.address);
 | |
|       console.log(
 | |
|         "DSA eETH Balance after topup:",
 | |
|         ethers.utils.formatEther(balance)
 | |
|       );
 | |
| 
 | |
|       await hre.network.provider.request({
 | |
|         method: "hardhat_stopImpersonatingAccount",
 | |
|         params: [eETHHolder],
 | |
|       });
 | |
|     });
 | |
|   });
 | |
|   describe("Main", function () {
 | |
|     it("Should wrap and unwrap eETH", async function () {
 | |
|       const eETHTAddress = "0x35fA164735182de50811E8e2E824cFb9B6118ac2";
 | |
|       const weETHAddress = "0xCd5fE23C85820F7B72D0926FC9b05b43E359b7ee";
 | |
|       const IERC20ABI = [
 | |
|         "function balanceOf(address account) external view returns (uint256)",
 | |
|       ];
 | |
|       const eETHContract = await ethers.getContractAt(IERC20ABI, eETHTAddress);
 | |
|       const weETHContract = await ethers.getContractAt(IERC20ABI, weETHAddress);
 | |
|       const amount = ethers.utils.parseEther("10");
 | |
|       const initialBalance = await weETHContract.balanceOf(dsaWallet0.address);
 | |
|       console.log(
 | |
|         "weETH Balance before wrapping:",
 | |
|         ethers.utils.formatEther(initialBalance)
 | |
|       );
 | |
|       console.log("Wrapping 10 eETH to weETH");
 | |
|       const spells = [
 | |
|         {
 | |
|           connector: connectorName,
 | |
|           method: "deposit",
 | |
|           args: [amount, 0, 0],
 | |
|         },
 | |
|       ];
 | |
|       const spellsEncoded = encodeSpells(spells);
 | |
|       const tx = await dsaWallet0
 | |
|         .connect(wallet0)
 | |
|         .cast(...spellsEncoded, await wallet1.getAddress());
 | |
|       const receipt = await tx.wait();
 | |
|       const finalBalance = await weETHContract.balanceOf(dsaWallet0.address);
 | |
|       console.log(
 | |
|         "weETH Balance after wrapping:",
 | |
|         ethers.utils.formatEther(finalBalance)
 | |
|       );
 | |
| 
 | |
|       const uint256Max = ethers.BigNumber.from(2).pow(256).sub(1);
 | |
|       const initialBalance2 = await eETHContract.balanceOf(dsaWallet0.address);
 | |
|       console.log(
 | |
|         "eETH Balance before unwrapping:",
 | |
|         ethers.utils.formatEther(initialBalance2)
 | |
|       );
 | |
|       console.log("Unwrapping all eETH to ETH");
 | |
|       const spells2 = [
 | |
|         {
 | |
|           connector: connectorName,
 | |
|           method: "withdraw",
 | |
|           args: [uint256Max, 0, 0],
 | |
|         },
 | |
|       ];
 | |
|       const spellsEncoded2 = encodeSpells(spells2);
 | |
|       const tx2 = await dsaWallet0
 | |
|         .connect(wallet0)
 | |
|         .cast(...spellsEncoded2, await wallet1.getAddress());
 | |
|       const receipt2 = await tx2.wait();
 | |
|       const finalBalance2 = await eETHContract.balanceOf(dsaWallet0.address);
 | |
|       console.log(
 | |
|         "eETH Balance after unwrapping:",
 | |
|         ethers.utils.formatEther(finalBalance2)
 | |
|       );
 | |
|     });
 | |
|   });
 | |
| });
 | 
