123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107 |
- import * as anchor from "@coral-xyz/anchor";
- import { Program } from "@coral-xyz/anchor";
- import { SwapExample } from "../target/types/swap_example";
- import { expect } from "chai";
- import { TestValues, createValues, mintingTokens } from "./utils";
- describe("Withdraw liquidity", () => {
- const provider = anchor.AnchorProvider.env();
- const connection = provider.connection;
- anchor.setProvider(provider);
- const program = anchor.workspace.SwapExample as Program<SwapExample>;
- let values: TestValues;
- beforeEach(async () => {
- values = createValues();
- await program.methods
- .createAmm(values.id, values.fee)
- .accounts({ amm: values.ammKey, admin: values.admin.publicKey })
- .rpc();
- await mintingTokens({
- connection,
- creator: values.admin,
- mintAKeypair: values.mintAKeypair,
- mintBKeypair: values.mintBKeypair,
- });
- await program.methods
- .createPool()
- .accounts({
- amm: values.ammKey,
- pool: values.poolKey,
- poolAuthority: values.poolAuthority,
- mintLiquidity: values.mintLiquidity,
- mintA: values.mintAKeypair.publicKey,
- mintB: values.mintBKeypair.publicKey,
- poolAccountA: values.poolAccountA,
- poolAccountB: values.poolAccountB,
- })
- .rpc();
- await program.methods
- .depositLiquidity(values.depositAmountA, values.depositAmountA)
- .accounts({
- pool: values.poolKey,
- poolAuthority: values.poolAuthority,
- depositor: values.admin.publicKey,
- mintLiquidity: values.mintLiquidity,
- mintA: values.mintAKeypair.publicKey,
- mintB: values.mintBKeypair.publicKey,
- poolAccountA: values.poolAccountA,
- poolAccountB: values.poolAccountB,
- depositorAccountLiquidity: values.liquidityAccount,
- depositorAccountA: values.holderAccountA,
- depositorAccountB: values.holderAccountB,
- })
- .signers([values.admin])
- .rpc({ skipPreflight: true });
- });
- it("Withdraw everything", async () => {
- await program.methods
- .withdrawLiquidity(values.depositAmountA.sub(values.minimumLiquidity))
- .accounts({
- amm: values.ammKey,
- pool: values.poolKey,
- poolAuthority: values.poolAuthority,
- depositor: values.admin.publicKey,
- mintLiquidity: values.mintLiquidity,
- mintA: values.mintAKeypair.publicKey,
- mintB: values.mintBKeypair.publicKey,
- poolAccountA: values.poolAccountA,
- poolAccountB: values.poolAccountB,
- depositorAccountLiquidity: values.liquidityAccount,
- depositorAccountA: values.holderAccountA,
- depositorAccountB: values.holderAccountB,
- })
- .signers([values.admin])
- .rpc({ skipPreflight: true });
- const liquidityTokenAccount = await connection.getTokenAccountBalance(
- values.liquidityAccount
- );
- const depositTokenAccountA = await connection.getTokenAccountBalance(
- values.holderAccountA
- );
- const depositTokenAccountB = await connection.getTokenAccountBalance(
- values.holderAccountB
- );
- expect(liquidityTokenAccount.value.amount).to.equal("0");
- expect(Number(depositTokenAccountA.value.amount)).to.be.lessThan(
- values.defaultSupply.toNumber()
- );
- expect(Number(depositTokenAccountA.value.amount)).to.be.greaterThan(
- values.defaultSupply.sub(values.depositAmountA).toNumber()
- );
- expect(Number(depositTokenAccountB.value.amount)).to.be.lessThan(
- values.defaultSupply.toNumber()
- );
- expect(Number(depositTokenAccountB.value.amount)).to.be.greaterThan(
- values.defaultSupply.sub(values.depositAmountA).toNumber()
- );
- });
- });
|