import { beforeAll, expect, test } from "@jest/globals"; import { Wallet } from "@project-serum/anchor"; import { ASSOCIATED_TOKEN_PROGRAM_ID, getAssociatedTokenAddressSync, getMint, } from "@solana/spl-token"; import { Keypair, LAMPORTS_PER_SOL, Transaction } from "@solana/web3.js"; import { Ruleset } from "../../sdk"; import { MintManager } from "../../sdk/generated/accounts/MintManager"; import { createInitializeMintInstruction } from "../../sdk/generated/instructions/InitializeMint"; import { createRemoveInUseByInstruction } from "../../sdk/generated/instructions/RemoveInUseBy"; import { createSetInUseByInstruction } from "../../sdk/generated/instructions/SetInUseBy"; import { findMintManagerId, findRulesetId } from "../../sdk/pda"; import type { CardinalProvider } from "../../utils"; import { executeTransaction, getProvider, tryGetAccount } from "../../utils"; const mintKeypair = Keypair.generate(); const RULESET_NAME = "ruleset-no-checks"; const RULESET_ID = findRulesetId(RULESET_NAME); const IN_USE_BY_AUTHORITY = Keypair.generate(); let provider: CardinalProvider; beforeAll(async () => { provider = await getProvider(); const signature = await provider.connection.requestAirdrop( IN_USE_BY_AUTHORITY.publicKey, LAMPORTS_PER_SOL ); await provider.connection.confirmTransaction(signature, "confirmed"); }); test("Initialize mint", async () => { const mintManagerId = findMintManagerId(mintKeypair.publicKey); const ruleset = await Ruleset.fromAccountAddress( provider.connection, RULESET_ID ); const tx = new Transaction(); tx.add( createInitializeMintInstruction({ mintManager: mintManagerId, mint: mintKeypair.publicKey, ruleset: RULESET_ID, targetTokenAccount: getAssociatedTokenAddressSync( mintKeypair.publicKey, provider.wallet.publicKey ), target: provider.wallet.publicKey, rulesetCollector: ruleset.collector, authority: provider.wallet.publicKey, payer: provider.wallet.publicKey, collector: ruleset.collector, associatedTokenProgram: ASSOCIATED_TOKEN_PROGRAM_ID, }) ); await executeTransaction(provider.connection, tx, provider.wallet, [ mintKeypair, ]); // check mint const mintInfo = await tryGetAccount(() => getMint(provider.connection, mintKeypair.publicKey) ); expect(mintInfo).not.toBeNull(); expect(mintInfo?.isInitialized).toBeTruthy(); expect(mintInfo?.supply.toString()).toBe("1"); expect(mintInfo?.decimals.toString()).toBe("0"); expect(mintInfo?.freezeAuthority?.toString()).toBe(mintManagerId.toString()); expect(mintInfo?.mintAuthority?.toString()).toBe(mintManagerId.toString()); // check mint manager const mintManager = await MintManager.fromAccountAddress( provider.connection, mintManagerId ); expect(mintManager.mint.toString()).toBe(mintKeypair.publicKey.toString()); expect(mintManager.authority.toString()).toBe( provider.wallet.publicKey.toString() ); expect(mintManager.ruleset.toString()).toBe( findRulesetId(RULESET_NAME).toString() ); }); test("Set in use by", async () => { const mintManagerId = findMintManagerId(mintKeypair.publicKey); const holderAtaId = getAssociatedTokenAddressSync( mintKeypair.publicKey, provider.wallet.publicKey ); const tx = new Transaction(); tx.add( createSetInUseByInstruction( { mintManager: mintManagerId, holder: provider.wallet.publicKey, holderTokenAccount: holderAtaId, }, { setInUseByIx: { inUseByAddress: IN_USE_BY_AUTHORITY.publicKey, }, } ) ); await executeTransaction(provider.connection, tx, provider.wallet); // check mint manager const mintManager = await MintManager.fromAccountAddress( provider.connection, mintManagerId ); expect(mintManager.mint.toString()).toBe(mintKeypair.publicKey.toString()); expect(mintManager.inUseBy?.toString()).toBe( IN_USE_BY_AUTHORITY.publicKey.toString() ); expect(mintManager.authority.toString()).toBe( provider.wallet.publicKey.toString() ); expect(mintManager.ruleset.toString()).toBe( findRulesetId(RULESET_NAME).toString() ); }); test("Remove in use by", async () => { const mintManagerId = findMintManagerId(mintKeypair.publicKey); const tx = new Transaction(); tx.add( createRemoveInUseByInstruction({ mintManager: mintManagerId, user: IN_USE_BY_AUTHORITY.publicKey, }) ); await executeTransaction( provider.connection, tx, new Wallet(IN_USE_BY_AUTHORITY) ); // check mint manager const mintManager = await MintManager.fromAccountAddress( provider.connection, mintManagerId ); expect(mintManager.mint.toString()).toBe(mintKeypair.publicKey.toString()); expect(mintManager.inUseBy).toBeNull(); expect(mintManager.authority.toString()).toBe( provider.wallet.publicKey.toString() ); expect(mintManager.ruleset.toString()).toBe( findRulesetId(RULESET_NAME).toString() ); });