diff --git a/.env.example b/.env.example index abbda89..3f24a57 100644 --- a/.env.example +++ b/.env.example @@ -2,19 +2,12 @@ WALLET_PRIVATE_KEY_A=0x0000000000000000000000000000000000000000 WALLET_PRIVATE_KEY_B=0x0000000000000000000000000000000000000000 WALLET_PRIVATE_KEY_C=0x0000000000000000000000000000000000000000 -STORY_RPC_PROVIDER_URL=https://story-network.rpc.caldera.xyz/http -STORY_NFT_CONTRACT_ADDRESS=0x0000000000000000000000000000000000000000 -STORY_LICENSING_MODULE_ADDRESS=0x0000000000000000000000000000000000000000 -STORY_ROYALTY_POLICY_ADDRESS=0x0000000000000000000000000000000000000000 -STORY_MINTING_FEE_TOKEN=0x0000000000000000000000000000000000000000 -STORY_ROYALTY_POLICY_LAP_ADDRESS=0x0000000000000000000000000000000000000000 -STORY_ROYALTY_ERC20=0x0000000000000000000000000000000000000000 -STORY_ARBITRATION_POLICY_ADDRESS=0x0000000000000000000000000000000000000000 - -SEPOLIA_RPC_PROVIDER_URL=https://rpc-sepolia.rockx.com -SEPOLIA_NFT_CONTRACT_ADDRESS=0x0000000000000000000000000000000000000000 -SEPOLIA_LICENSING_MODULE_ADDRESS=0x0000000000000000000000000000000000000000 -SEPOLIA_ROYALTY_POLICY_ADDRESS=0x0000000000000000000000000000000000000000 -SEPOLIA_MINTING_FEE_TOKEN=0x0000000000000000000000000000000000000000 -SEPOLIA_ROYALTY_POLICY_LAP_ADDRESS=0x0000000000000000000000000000000000000000 -SEPOLIA_ARBITRATION_POLICY_ADDRESS=0x0000000000000000000000000000000000000000 \ No newline at end of file +RPC_PROVIDER_URL=https://odyssey.storyrpc.io +MOCK_ERC721_ADDRESS=0x0000000000000000000000000000000000000000 +LICENSING_MODULE_ADDRESS=0x0000000000000000000000000000000000000000 +ROYALTY_POLICY_LAP_ADDRESS=0x0000000000000000000000000000000000000000 +MOCK_ERC20_ADDRESS=0x0000000000000000000000000000000000000000 +IPASSET_REGISTRY_ADDRESS=0x0000000000000000000000000000000000000000 +ARBITRATION_POLICY_ADDRESS= +DISPUTE_MODULE_ADDRESS=0x0000000000000000000000000000000000000000 +LICENSE_TEMPLATE_ADDRESS=0x0000000000000000000000000000000000000000 diff --git a/.gitignore b/.gitignore index fb9d4fe..6fe21b8 100644 --- a/.gitignore +++ b/.gitignore @@ -13,6 +13,7 @@ dist dist-ssr *.local .env +test-reports # Editor directories and files .vscode/* diff --git a/config/config.ts b/config/config.ts index 73eb9b1..a7b32d7 100644 --- a/config/config.ts +++ b/config/config.ts @@ -1,49 +1,44 @@ -import { Hex, http, Address, Chain, defineChain } from "viem"; +import { Hex, http, Address, defineChain, Chain } from "viem"; import { privateKeyToAccount } from "viem/accounts"; import { StoryClient, StoryConfig } from "@story-protocol/core-sdk"; import { SupportedChainIds } from "@story-protocol/core-sdk/dist/declarations/src/types/config"; -const TEST_ENV = process.env.TEST_ENV as SupportedChainIds; - export let licensingModuleAddress: Hex; export let licenseTokenAddress: Hex; export let nftContractAddress: Hex; export let royaltyPolicyAddress: Hex; export let royaltyPolicyLAPAddress: Hex; export let royaltyApproveAddress: Hex; -export let mintingFeeTokenAddress: Hex; +export let mockERC20Address: Hex; export let arbitrationPolicyAddress: Hex; export let disputeModuleAddress: Hex; export let ipAssetRegistryAddress: Hex; +export let licenseTemplateAddress: Hex; export let rpcProviderUrl: string; export let chainId: number; -if (String(TEST_ENV) === "sepolia") { - chainId = 11155111; - rpcProviderUrl = process.env.SEPOLIA_RPC_PROVIDER_URL as string; - licensingModuleAddress = process.env.SEPOLIA_LICENSING_MODULE_ADDRESS as Hex; - licenseTokenAddress = process.env.SEPOLIA_LICENSE_TOKEN_ADDRESS as Hex; - nftContractAddress = process.env.SEPOLIA_MOCK_ERC721_ADDRESS as Hex; - royaltyPolicyAddress = process.env.SEPOLIA_ROYALTY_POLICY_ADDRESS as Hex; - royaltyPolicyLAPAddress = process.env.SEPOLIA_ROYALTY_POLICY_LAP_ADDRESS as Hex; - royaltyApproveAddress = process.env.SEPOLIA_ROYALTY_ERC20 as Hex; - mintingFeeTokenAddress = process.env.SEPOLIA_MINTING_FEE_TOKEN as Hex; - arbitrationPolicyAddress = process.env.SEPOLIA_ARBITRATION_POLICY_ADDRESS as Hex; - disputeModuleAddress = process.env.SEPOLIA_DISPUTE_MODULE_ADDRESS as Hex; - ipAssetRegistryAddress = process.env.SEPOLIA_IPASSET_REGISTRY_ADDRESS as Hex; -} else if (String(TEST_ENV) === "storyTestnet") { - rpcProviderUrl = process.env.STORY_RPC_PROVIDER_URL as string; - licensingModuleAddress = process.env.STORY_LICENSING_MODULE_ADDRESS as Hex; - nftContractAddress = process.env.STORY_MOCK_ERC721_ADDRESS as Hex; - royaltyPolicyAddress = process.env.STORY_ROYALTY_POLICY_ADDRESS as Hex; - royaltyPolicyLAPAddress = process.env.STORY_ROYALTY_POLICY_LAP_ADDRESS as Hex; - royaltyApproveAddress = process.env.STORY_ROYALTY_ERC20 as Hex; - mintingFeeTokenAddress = process.env.STORY_MINTING_FEE_TOKEN as Hex; - arbitrationPolicyAddress = process.env.STORY_ARBITRATION_POLICY_ADDRESS as Hex; - ipAssetRegistryAddress = process.env.STORY_IPASSET_REGISTRY_ADDRESS as Hex; - disputeModuleAddress = process.env.STORY_DISPUTE_MODULE_ADDRESS as Hex; -} else { - throw new Error(`Unknown TEST_ENV value: ${TEST_ENV}`); +chainId = 1516; +rpcProviderUrl = process.env.RPC_PROVIDER_URL as string; +licensingModuleAddress = process.env.LICENSING_MODULE_ADDRESS as Hex; +licenseTokenAddress = process.env.LICENSING_TOKEN_ADDRESS as Hex; +nftContractAddress = process.env.MOCK_ERC721_ADDRESS as Hex; +royaltyPolicyAddress = process.env.SEPOLIA_ROYALTY_POLICY_ADDRESS as Hex; +royaltyPolicyLAPAddress = process.env.ROYALTY_POLICY_LAP_ADDRESS as Hex; +royaltyApproveAddress = process.env.MOCK_ERC20_ADDRESS as Hex; +mockERC20Address = process.env.MOCK_ERC20_ADDRESS as Hex; +arbitrationPolicyAddress = process.env.ARBITRATION_POLICY_ADDRESS as Hex; +disputeModuleAddress = process.env.DISPUTE_MODULE_ADDRESS as Hex; +ipAssetRegistryAddress = process.env.IPASSET_REGISTRY_ADDRESS as Hex; +licenseTemplateAddress = process.env.LICENSE_TEMPLATE_ADDRESS as Hex; + +export function chainStringToViemChain(chainId: SupportedChainIds): Chain { + switch (chainId.toString()) { + case "1516": + case "odyssey": + return odyssey; + default: + throw new Error(`chainId ${chainId as string} not supported`); + } } export const privateKeyA = process.env.WALLET_PRIVATE_KEY_A as Hex; @@ -56,19 +51,16 @@ export const accountC = privateKeyToAccount(privateKeyC as Address); export const configA: StoryConfig = { account: accountA, - chainId: TEST_ENV, transport: http(rpcProviderUrl), } export const configB: StoryConfig = { account: accountB, - chainId: TEST_ENV, transport: http(rpcProviderUrl), } export const configC: StoryConfig = { account: accountC, - chainId: TEST_ENV, transport: http(rpcProviderUrl), } @@ -76,34 +68,27 @@ export const clientA = StoryClient.newClient(configA) export const clientB = StoryClient.newClient(configB) export const clientC = StoryClient.newClient(configC) -export function chainStringToViemChain(chainId: SupportedChainIds): Chain { - switch (chainId) { - case "sepolia": - // case "storyTestnet": - // return storyTestnet; - default: - throw new Error(`chainId ${chainId as string} not supported`); - } -} - -export const storyTestnet = defineChain({ - id: 15_13, - name: "story-network", - nativeCurrency: { name: "Ether", symbol: "SEP", decimals: 18 }, +export const odyssey = defineChain({ + id: 15_16, + name: "odyssey", + nativeCurrency: { name: "IP", symbol: "IP", decimals: 18 }, rpcUrls: { - default: { - http: ["https://story-network.rpc.caldera.xyz/http"], - webSocket: ["wss://story-network.rpc.caldera.xyz/ws"], - } + default: { + http: ["https://odyssey.storyrpc.io/"], + }, }, blockExplorers: { - default: { name: "Explorer", url: "https://story-network.explorer.caldera.xyz" }, + default: { + name: "Explorer", + url: "https://odyssey-testnet-explorer.storyscan.xyz/", + }, }, contracts: { + //TODO: need to confirm the addresses multicall3: { address: "0xcA11bde05977b3631167028862bE2a173976CA11", blockCreated: 5882, }, }, - testnet: true + testnet: true, }); \ No newline at end of file diff --git a/package.json b/package.json index 3bc2bd8..81fec4d 100644 --- a/package.json +++ b/package.json @@ -4,12 +4,12 @@ "description": "", "main": "index.js", "scripts": { - "test:sepolia:smoke": "env TEST_ENV='sepolia' mocha -r ts-node/register -r mocha-steps --grep '\\[smoke\\]' './test/**/**/*.test.ts' --timeout 240000 --reporter mochawesome --reporter-options reportDir='test-reports',reportFilename='[status]_[datetime]_sdk-test-report',timestamp='mm-dd-yyyy_HHMMss',reportTitle='SDK Test Report'", - "test:story:smoke": "env TEST_ENV='storyTestnet' mocha -r ts-node/register -r mocha-steps --grep '\\[smoke\\]' './test/**/**/*.test.ts' --timeout 240000 --reporter mochawesome --reporter-options reportDir='test-reports',reportFilename='[status]_[datetime]_sdk-test-report',timestamp='mm-dd-yyyy_HHMMss',reportTitle='SDK Test Report'", - "test:sepolia:e2e": "env TEST_ENV='sepolia' mocha -r ts-node/register -r mocha-steps './test/**/e2e/*.test.ts' --timeout 240000 --reporter mochawesome --reporter-options reportDir='test-reports',reportFilename='[status]_[datetime]_sdk-test-report',timestamp='mm-dd-yyyy_HHMMss',reportTitle='SDK Test Report'", - "test:story:e2e": "env TEST_ENV='storyTestnet' mocha -r ts-node/register -r mocha-steps './test/**/e2e/*.test.ts' --timeout 240000 --reporter mochawesome --reporter-options reportDir='test-reports',reportFilename='[status]_[datetime]_sdk-test-report',timestamp='mm-dd-yyyy_HHMMss',reportTitle='SDK Test Report'", - "test:sepolia": "env TEST_ENV='sepolia' mocha -r ts-node/register -r mocha-steps './test/**/**/**.test.ts' --timeout 240000 --reporter mochawesome --reporter-options reportDir='test-reports',reportFilename='[status]_[datetime]_sdk-test-report',timestamp='mm-dd-yyyy_HHMMss',reportTitle='SDK Test Report'", - "test:story": "env TEST_ENV='storyTestnet' mocha -r ts-node/register -r mocha-steps './test/**/**/*.test.ts' --timeout 240000 --reporter mochawesome --reporter-options reportDir='test-reports',reportFilename='[status]_[datetime]_sdk-test-report',timestamp='mm-dd-yyyy_HHMMss',reportTitle='SDK Test Report'", + "test:smoke": "mocha -r ts-node/register -r mocha-steps --grep '\\[smoke\\]' './test/**/**/*.test.ts' --timeout 240000 --reporter mochawesome --reporter-options reportDir='test-reports',reportFilename='[status]_[datetime]_sdk-test-report',timestamp='mm-dd-yyyy_HHMMss',reportTitle='SDK Test Report'", + "test:ipAsset": "mocha -r ts-node/register -r mocha-steps './test/ipAsset/**.test.ts' --timeout 240000 --reporter mochawesome --reporter-options reportDir='test-reports',reportFilename='[status]_[datetime]_sdk-test-report',timestamp='mm-dd-yyyy_HHMMss',reportTitle='SDK Test Report'", + "test:license": "mocha -r ts-node/register -r mocha-steps './test/license/**.test.ts' --timeout 240000 --reporter mochawesome --reporter-options reportDir='test-reports',reportFilename='[status]_[datetime]_sdk-test-report',timestamp='mm-dd-yyyy_HHMMss',reportTitle='SDK Test Report'", + "test:nftClient": "mocha -r ts-node/register -r mocha-steps './test/nftClient/**.test.ts' --timeout 240000 --reporter mochawesome --reporter-options reportDir='test-reports',reportFilename='[status]_[datetime]_sdk-test-report',timestamp='mm-dd-yyyy_HHMMss',reportTitle='SDK Test Report'", + "test:permission": "mocha -r ts-node/register -r mocha-steps './test/permission/**.test.ts' --timeout 240000 --reporter mochawesome --reporter-options reportDir='test-reports',reportFilename='[status]_[datetime]_sdk-test-report',timestamp='mm-dd-yyyy_HHMMss',reportTitle='SDK Test Report'", + "test:e2e": "mocha -r ts-node/register -r mocha-steps './test/**/e2e/**.test.ts' --timeout 240000 --reporter mochawesome --reporter-options reportDir='test-reports',reportFilename='[status]_[datetime]_sdk-test-report',timestamp='mm-dd-yyyy_HHMMss',reportTitle='SDK Test Report'", "open:report": "open test-reports/*.html", "test:sepolia:open:report": "rm -rf test-reports && npm run test:sepolia && npm run open:report" }, @@ -18,7 +18,7 @@ "url": "https://github.com/storyprotocol/sdk-e2e-tests.git" }, "dependencies": { - "@story-protocol/core-sdk": "1.0.0-rc.14", + "@story-protocol/core-sdk": "1.2.0-rc.1", "viem": "^2.8.12" }, "devDependencies": { diff --git a/test/dispute/raiseDispute.test.ts b/test/dispute/raiseDispute.test.ts index 76547c6..42d3b53 100644 --- a/test/dispute/raiseDispute.test.ts +++ b/test/dispute/raiseDispute.test.ts @@ -34,19 +34,19 @@ describe("SDK Test", function () { let ipIdA: any; const response = await expect( raiseDispute("B", ipIdA, arbitrationPolicyAddress, "test", "PLAGIARISM", waitForTransaction) - ).to.be.rejectedWith("Failed to raise dispute: Address \"undefined\" is invalid."); + ).to.be.rejectedWith(`Failed to raise dispute: request.targetIpId address is invalid: undefined, Address must be a hex value of 20 bytes (40 hex characters) and match its checksum counterpart.`); }); it("Raise dispute fail as invalid ipId", async function () { const response = await expect( raiseDispute("B", "0x0000", arbitrationPolicyAddress, "test", "PLAGIARISM", waitForTransaction) - ).to.be.rejectedWith("Failed to raise dispute: Address \"0x0000\" is invalid."); + ).to.be.rejectedWith(`Failed to raise dispute: request.targetIpId address is invalid: 0x0000, Address must be a hex value of 20 bytes (40 hex characters) and match its checksum counterpart.`); }); it("Raise dispute fail as non-existent ipId", async function () { const response = await expect( raiseDispute("B", "0x8Dcd7f0be38Be6adbe2a7d8fb58032b1e20E3681", arbitrationPolicyAddress, "test", "PLAGIARISM", waitForTransaction) - ).to.be.rejectedWith("Failed to raise dispute: Address \"0x8Dcd7f0be38Be6adbe2a7d8fb58032b1e20E3681\" is invalid."); + ).to.be.rejectedWith(`Failed to raise dispute: The contract function "raiseDispute" reverted.`, `Error: DisputeModule__NotRegisteredIpId()`); }); it("Raise dispute fail as undefined linkToDisputeEvidence", async function () { diff --git a/test/dispute/resolveDispute.test.ts b/test/dispute/resolveDispute.test.ts index fbc13aa..3a95404 100644 --- a/test/dispute/resolveDispute.test.ts +++ b/test/dispute/resolveDispute.test.ts @@ -51,41 +51,41 @@ describe("SDK Test", function () { let disputeId1: any; const response = await expect( resolveDispute("B", disputeId1, "0x", true) - ).to.be.rejectedWith("Failed to cancel dispute: Cannot convert undefined to a BigInt"); + ).to.be.rejectedWith(`Failed to resolve dispute: Cannot convert undefined to a BigInt`); }); it("Resolve dispute fail as invalid disputeId", async function () { const response = await expect( resolveDispute("B", "test", "0x", true) - ).to.be.rejectedWith("Failed to cancel dispute: Cannot convert test to a BigInt"); + ).to.be.rejectedWith(`Failed to resolve dispute: Cannot convert test to a BigInt`); }); it("Resolve dispute fail as non-existent disputeId", async function () { const response = await expect( resolveDispute("B", "999999", "0x", true) - ).to.be.rejectedWith("Failed to cancel dispute: The contract function \"resolveDispute\" reverted.", - "Error: DisputeModule__NotDisputeInitiator()"); + ).to.be.rejectedWith(`Failed to resolve dispute: The contract function "resolveDispute" reverted.`, + `Error: DisputeModule__NotDisputeInitiator()`); }); it("Resolve dispute fail as undefined data", async function () { let data: any; const response = await expect( resolveDispute("B", disputeId1, data, true) - ).to.be.rejectedWith("Failed to cancel dispute: Cannot read properties of undefined (reading 'length')"); + ).to.be.rejectedWith(`Failed to resolve dispute: Cannot read properties of undefined (reading 'length')`); }); it("Resolve dispute fail as not dispute initiator", async function () { const response = await expect( resolveDispute("A", disputeId1, "0x", true) - ).to.be.rejectedWith("Failed to cancel dispute: The contract function \"resolveDispute\" reverted.", - "Error: DisputeModule__NotDisputeInitiator()"); + ).to.be.rejectedWith(`Failed to resolve dispute: The contract function "resolveDispute" reverted.`, + `Error: DisputeModule__NotDisputeInitiator()`); }); it("Resolve dispute fail as not set judgement", async function () { const response = await expect( resolveDispute("B", disputeId1, "0x0000", true) - ).to.be.rejectedWith("Failed to cancel dispute: The contract function \"resolveDispute\" reverted.", - "Error: DisputeModule__NotAbleToResolve()"); + ).to.be.rejectedWith(`Failed to resolve dispute: The contract function "resolveDispute" reverted.`, + `Error: DisputeModule__NotAbleToResolve()`); }); it("Resolve dispute fail as judgement decision is false", async function () { @@ -94,15 +94,15 @@ describe("SDK Test", function () { const response = await expect( resolveDispute("B", disputeId1, "0x0000", true) - ).to.be.rejectedWith("Failed to cancel dispute: The contract function \"resolveDispute\" reverted.", - "Error: DisputeModule__NotAbleToResolve()"); + ).to.be.rejectedWith(`Failed to resolve dispute: The contract function "resolveDispute" reverted.`, + `Error: DisputeModule__NotAbleToResolve()`); }); it("Resolve dispute faile as already resolved", async function () { const response = await expect( resolveDispute("B", disputeId1, "0x0000", false) - ).to.be.rejectedWith("Failed to cancel dispute: The contract function \"resolveDispute\" reverted.", - "Error: DisputeModule__NotDisputeInitiator()"); + ).to.be.rejectedWith(`Failed to resolve dispute: The contract function "resolveDispute" reverted.`, + `Error: DisputeModule__NotAbleToResolve()`); }); it("Resolve dispute with waitForTransaction: false", async function () { diff --git a/test/e2e/derivativeIP.comUsePIL.test.ts b/test/e2e/derivativeIP.comUsePIL.test.ts index 5a73590..7c44e84 100644 --- a/test/e2e/derivativeIP.comUsePIL.test.ts +++ b/test/e2e/derivativeIP.comUsePIL.test.ts @@ -1,7 +1,7 @@ -import { privateKeyA, privateKeyB, privateKeyC, accountA, accountB, accountC, nftContractAddress } from '../../config/config' -import { mintNFTWithRetry } from '../../utils/utils' -import { registerIpAsset, attachLicenseTerms, mintLicenseTokens, registerDerivative, registerDerivativeWithLicenseTokens } from '../../utils/sdkUtils' -import { expect } from 'chai' +import { privateKeyA, privateKeyB, privateKeyC, accountA, accountB, accountC, nftContractAddress } from '../../config/config'; +import { mintNFTWithRetry } from '../../utils/utils'; +import { registerIpAsset, attachLicenseTerms, mintLicenseTokens, registerDerivative, registerDerivativeWithLicenseTokens } from '../../utils/sdkUtils'; +import { expect } from 'chai'; import chai from 'chai'; import chaiAsPromised from 'chai-as-promised'; diff --git a/test/e2e/derivativeIP.nonComPIL.test.ts b/test/e2e/derivativeIP.nonComPIL.test.ts index 90f4219..9729b1e 100644 --- a/test/e2e/derivativeIP.nonComPIL.test.ts +++ b/test/e2e/derivativeIP.nonComPIL.test.ts @@ -1,7 +1,7 @@ -import { privateKeyA, privateKeyB, privateKeyC, accountA, accountB, accountC,nftContractAddress } from '../../config/config' -import { mintNFTWithRetry } from '../../utils/utils' -import { registerIpAsset, attachLicenseTerms, mintLicenseTokens, registerDerivative, registerDerivativeWithLicenseTokens } from '../../utils/sdkUtils' -import { expect } from 'chai' +import { privateKeyA, privateKeyB, privateKeyC, accountA, accountB, accountC,nftContractAddress } from '../../config/config'; +import { mintNFTWithRetry } from '../../utils/utils'; +import { registerIpAsset, attachLicenseTerms, mintLicenseTokens, registerDerivative, registerDerivativeWithLicenseTokens } from '../../utils/sdkUtils'; +import { expect } from 'chai'; import chai from 'chai'; import chaiAsPromised from 'chai-as-promised'; @@ -42,14 +42,6 @@ describe("SDK E2E Test - Register Derivative IP Asset with Non-Commercial Social ipIdA = response.ipId; }); - step("Wallet A attach nonComLicenseTermsId(non-commercial social remixing PIL) to ipIdA", async function () { - const response = await expect( - attachLicenseTerms("A", ipIdA, nonComLicenseTermsId, waitForTransaction) - ).to.not.be.rejected; - - expect(response.txHash).to.be.a("string").and.not.empty; - }); - step("Wallet A mint a license token with the receiverAddress set as Wallet B, get a licenseTokenId (licenseTokenIdA)", async function () { const response = await expect( mintLicenseTokens("A", ipIdA, nonComLicenseTermsId, 2, accountB.address, waitForTransaction) @@ -143,14 +135,6 @@ describe("SDK E2E Test - Register Derivative IP Asset with Non-Commercial Social ipIdA = response.ipId; }); - step("Wallet A attach nonComLicenseTermsId(non-commercial social remixing PIL) to ipIdA", async function () { - const response = await expect( - attachLicenseTerms("A", ipIdA, nonComLicenseTermsId, waitForTransaction) - ).to.not.be.rejected; - - expect(response.txHash).to.be.a("string").and.not.empty; - }); - step("Mint a NFT to WalletB, get a tokenId (tokenidB)", async function () { tokenIdB = await mintNFTWithRetry(privateKeyB); if (tokenIdB === '') { @@ -170,14 +154,6 @@ describe("SDK E2E Test - Register Derivative IP Asset with Non-Commercial Social ipIdB = response.ipId; }); - step("Wallet B attach nonComLicenseTermsId(non-commercial social remixing PIL) to ipIdA", async function () { - const response = await expect( - attachLicenseTerms("B", ipIdB, nonComLicenseTermsId, waitForTransaction) - ).to.not.be.rejected; - - expect(response.txHash).to.be.a("string").and.not.empty; - }); - step("Mint a NFT to WalletC, get a tokenId (tokenidC)", async function () { tokenIdC = await mintNFTWithRetry(privateKeyC); if (tokenIdC === '') { @@ -226,14 +202,6 @@ describe("SDK E2E Test - Register Derivative IP Asset with Non-Commercial Social ipIdA = response.ipId; }); - step("Wallet A attach nonComLicenseTermsId(non-commercial social remixing PIL) to ipIdA", async function () { - const response = await expect( - attachLicenseTerms("A", ipIdA, nonComLicenseTermsId, waitForTransaction) - ).to.not.be.rejected; - - expect(response.txHash).to.be.a("string").and.not.empty; - }); - step("Wallet A mint a license token with the receiverAddress set as Wallet B, get a licenseId (licenseTokenIdA)", async function () { const response = await expect( mintLicenseTokens("A", ipIdA, nonComLicenseTermsId, 2, accountC.address, waitForTransaction) @@ -264,14 +232,6 @@ describe("SDK E2E Test - Register Derivative IP Asset with Non-Commercial Social ipIdB = response.ipId; }); - step("Wallet B attach nonComLicenseTermsId(non-commercial social remixing PIL) to ipIdB", async function () { - const response = await expect( - attachLicenseTerms("B", ipIdB, nonComLicenseTermsId, waitForTransaction) - ).to.not.be.rejected; - - expect(response.txHash).to.be.a("string").and.not.empty; - }); - step("Wallet B mint a license token with the receiverAddress set as Wallet C, get a licenseTokenId (licenseTokenIdB)", async function () { const response = await expect( mintLicenseTokens("B", ipIdB, nonComLicenseTermsId, 2, accountC.address, waitForTransaction) @@ -331,14 +291,6 @@ describe("SDK E2E Test - Register Derivative IP Asset with Non-Commercial Social ipIdA = response.ipId; }); - step("Wallet A attach nonComLicenseTermsId(non-commercial social remixing PIL) to ipIdA", async function () { - const response = await expect( - attachLicenseTerms("A", ipIdA, nonComLicenseTermsId, waitForTransaction) - ).to.not.be.rejected; - - expect(response.txHash).to.be.a("string").and.not.empty; - }); - step("Wallet A mint a license token with the receiverAddress set as Wallet B, get a licenseId (licenseTokenIdA)", async function () { const response = await expect( mintLicenseTokens("A", ipIdA, nonComLicenseTermsId, 2, accountB.address, waitForTransaction) @@ -369,14 +321,6 @@ describe("SDK E2E Test - Register Derivative IP Asset with Non-Commercial Social ipIdB = response.ipId; }); - step("Wallet B attach nonComLicenseTermsId(non-commercial social remixing PIL) to ipIdB", async function () { - const response = await expect( - attachLicenseTerms("B", ipIdB, nonComLicenseTermsId, waitForTransaction) - ).to.not.be.rejected; - - expect(response.txHash).to.be.a("string").and.not.empty; - }); - step("Wallet B mint a license token with the receiverAddress set as Wallet C, get a licenseTokenId (licenseTokenIdB)", async function () { const response = await expect( mintLicenseTokens("B", ipIdB, nonComLicenseTermsId, 2, accountC.address, waitForTransaction) @@ -435,14 +379,6 @@ describe("SDK E2E Test - Register Derivative IP Asset with Non-Commercial Social ipIdA = response.ipId; }); - step("Wallet A attach nonComLicenseTermsId(non-commercial social remixing PIL) to ipIdA", async function () { - const response = await expect( - attachLicenseTerms("A", ipIdA, nonComLicenseTermsId, waitForTransaction) - ).to.not.be.rejected; - - expect(response.txHash).to.be.a("string").and.not.empty; - }); - step("Wallet A mint a license token with ipIdA and get a licenseTokenId (licenseTokenIdA)", async function () { const response = await expect( mintLicenseTokens("A", ipIdA, nonComLicenseTermsId, 1, accountB.address, waitForTransaction) @@ -527,14 +463,6 @@ describe("SDK E2E Test - Register Derivative IP Asset with Non-Commercial Social ipIdA = response.ipId; }); - step("Wallet A attach nonComLicenseTermsId(non-commercial social remixing PIL) to ipIdA", async function () { - const response = await expect( - attachLicenseTerms("A", ipIdA, nonComLicenseTermsId, waitForTransaction) - ).to.not.be.rejected; - - expect(response.txHash).to.be.a("string").and.not.empty; - }); - step("Wallet A mint a license token with ipIdA and get a licenseTokenId (licenseTokenIdA)", async function () { const response = await expect( mintLicenseTokens("A", ipIdA, nonComLicenseTermsId, 1, accountB.address, waitForTransaction) @@ -565,9 +493,9 @@ describe("SDK E2E Test - Register Derivative IP Asset with Non-Commercial Social ipIdB = response.ipId; }); - step("Wallet B attach nonComLicenseTermsId(non-commercial social remixing PIL) to ipIdA", async function () { + step("Wallet B attach nonComLicenseTermsId(non-commercial social remixing PIL) to ipIdB", async function () { const response = await expect( - attachLicenseTerms("B", ipIdB, nonComLicenseTermsId, waitForTransaction) + attachLicenseTerms("B", ipIdB, 0n, waitForTransaction) ).to.not.be.rejected; expect(response.txHash).to.be.a("string").and.not.empty; @@ -575,7 +503,7 @@ describe("SDK E2E Test - Register Derivative IP Asset with Non-Commercial Social step("Wallet B mint a license token with ipIdB and get a licenseTokenId (licenseTokenIdB)", async function () { const response = await expect( - mintLicenseTokens("B", ipIdB, nonComLicenseTermsId, 1, accountA.address, waitForTransaction) + mintLicenseTokens("B", ipIdB, 0n, 1, accountA.address, waitForTransaction) ).to.not.be.rejected; expect(response.txHash).to.be.a("string").and.not.empty; diff --git a/test/e2e/dispute.test.ts b/test/e2e/dispute.test.ts index 89c9978..4cc115e 100644 --- a/test/e2e/dispute.test.ts +++ b/test/e2e/dispute.test.ts @@ -59,7 +59,7 @@ describe("SDK E2E Test - Dispute Module", function () { describe("Attach License Terms to IN_DISPUTE IP Asset", async function () { it("Attach non-commerical social remixing PIL to IN_DISPUTE IP asset", async function () { const response = await expect( - attachLicenseTerms("A", ipIdA, nonComLicenseTermsId, waitForTransaction) + attachLicenseTerms("A", ipIdA, 0n, waitForTransaction) ).to.not.be.rejected; expect(response.txHash).to.be.a("string").and.not.empty; @@ -287,7 +287,7 @@ describe("SDK E2E Test - Dispute Module", function () { describe("Attach License Terms to DISPUTED IP Asset", async function () { it("Attach non-commerical social remixing PIL to a DISPUTED IP asset", async function () { const response = await expect( - attachLicenseTerms("A", ipIdA, nonComLicenseTermsId, waitForTransaction) + attachLicenseTerms("A", ipIdA, 0n, waitForTransaction) ).to.be.rejectedWith("Failed to attach license terms: The contract function \"attachLicenseTerms\" reverted.", "Error: LicensingModule__DisputedIpId()"); }); @@ -309,23 +309,17 @@ describe("SDK E2E Test - Dispute Module", function () { describe("Mint License Tokens for DISPUTED IP asset", async function () { before("Attach license terms, raise dispute and set judgement", async function () { - const response1 = await expect( - attachLicenseTerms("B", ipIdB, nonComLicenseTermsId, waitForTransaction) - ).to.not.be.rejected; - - expect(response1.txHash).to.be.a("string").and.not.empty; - - const response2 = await expect( + const responseComUsePIL = await expect( attachLicenseTerms("B", ipIdB, comUseLicenseTermsId1, waitForTransaction) ).to.not.be.rejected; - expect(response2.txHash).to.be.a("string").and.not.empty; + expect(responseComUsePIL.txHash).to.be.a("string").and.not.empty; - const response3 = await expect( + const responsecomRemixPIL = await expect( attachLicenseTerms("B", ipIdB, comRemixLicenseTermsId2, waitForTransaction) ).to.not.be.rejected; - expect(response3.txHash).to.be.a("string").and.not.empty; + expect(responsecomRemixPIL.txHash).to.be.a("string").and.not.empty; const responseRaiseDispute = await expect( raiseDispute("A", ipIdB, arbitrationPolicyAddress, "test", "PLAGIARISM", waitForTransaction) @@ -386,7 +380,7 @@ describe("SDK E2E Test - Dispute Module", function () { step("Register derivative with non-commercial social remixing PIL, derivative IP is a DISPUTED IP asset", async function () { const responseAttachLicenseTerms = await expect( - attachLicenseTerms("A", ipIdC, nonComLicenseTermsId, waitForTransaction) + attachLicenseTerms("A", ipIdC, 0n, waitForTransaction) ).to.not.be.rejected; expect(responseAttachLicenseTerms.txHash).to.be.a("string").and.not.empty; diff --git a/test/e2e/licenseTerms.nonComPIL.test.ts b/test/e2e/licenseTerms.nonComPIL.test.ts index eebdd45..8590026 100644 --- a/test/e2e/licenseTerms.nonComPIL.test.ts +++ b/test/e2e/licenseTerms.nonComPIL.test.ts @@ -1,13 +1,12 @@ import { privateKeyA, nftContractAddress, accountA, accountB, privateKeyB } from '../../config/config'; -import { attachLicenseTerms, mintLicenseTokens, registerDerivativeIp, registerDerivativeWithLicenseTokens, registerIpAndAttachPilTerms, registerIpAsset } from '../../utils/sdkUtils'; +import { attachLicenseTerms, mintLicenseTokens, registerDerivativeIp, registerDerivativeWithLicenseTokens, registerIpAsset } from '../../utils/sdkUtils'; import { getLicenseTokenOwner, mintNFTWithRetry, transferLicenseToken } from '../../utils/utils'; -import { expect } from 'chai' +import { expect } from 'chai'; import chai from 'chai'; import chaiAsPromised from 'chai-as-promised'; chai.use(chaiAsPromised); import '../setup'; import { Address } from 'viem'; -import { PIL_TYPE } from '@story-protocol/core-sdk'; let tokenIdA: string; let tokenIdB: string; @@ -112,17 +111,16 @@ describe('SDK E2E Test', function () { expect(tokenIdA).to.be.a("string").and.not.empty; }); - step(`Wallet A register an IP Asset and attach the non-commercial remixing PIL(licenseTermsId:2 - "transferable":true"), get an ipId (ipIdA) and a licenseTermsId (licenseTermsId1)`, async function () { - const responseRegisterIpAndAttachPilTerms = await expect( - registerIpAndAttachPilTerms("A", nftContractAddress, tokenIdA, PIL_TYPE.NON_COMMERCIAL_REMIX, true) + step(`Wallet A register an IP Asset and default attach the non-commercial remixing PIL(licenseTermsId:2 - "transferable":true"), get an ipId (ipIdA) and a licenseTermsId (licenseTermsId1)`, async function () { + const responseRegisterIpAsset = await expect( + registerIpAsset("A", nftContractAddress, tokenIdA, true) ).to.not.be.rejected; - expect(responseRegisterIpAndAttachPilTerms.txHash).to.be.a("string").and.not.empty; - expect(responseRegisterIpAndAttachPilTerms.ipId).to.be.a("string").and.not.empty; - expect(responseRegisterIpAndAttachPilTerms.licenseTermsId).to.be.a("bigint").and.to.be.ok; + expect(responseRegisterIpAsset.txHash).to.be.a("string").and.not.empty; + expect(responseRegisterIpAsset.ipId).to.be.a("string").and.not.empty; - ipIdA = responseRegisterIpAndAttachPilTerms.ipId; - licenseTermsId1 = responseRegisterIpAndAttachPilTerms.licenseTermsId; + ipIdA = responseRegisterIpAsset.ipId; + licenseTermsId1 = 2n; }); step("Wallet A attach another non-commercial social remixing PIL(licenseTermsId:0) to ipIdA", async function () { diff --git a/test/e2e/multiLIcenseTerms.test.ts b/test/e2e/multiLIcenseTerms.test.ts index 5dba1cf..1aaab35 100644 --- a/test/e2e/multiLIcenseTerms.test.ts +++ b/test/e2e/multiLIcenseTerms.test.ts @@ -1,7 +1,7 @@ -import { privateKeyA, privateKeyB, nftContractAddress } from '../../config/config' -import { mintNFTWithRetry } from '../../utils/utils' -import { registerIpAsset, attachLicenseTerms, registerDerivative } from '../../utils/sdkUtils' -import { expect } from 'chai' +import { privateKeyA, privateKeyB, nftContractAddress } from '../../config/config'; +import { mintNFTWithRetry } from '../../utils/utils'; +import { registerIpAsset, attachLicenseTerms, registerDerivative } from '../../utils/sdkUtils'; +import { expect } from 'chai'; import '../setup'; import chai from 'chai'; @@ -184,8 +184,8 @@ describe("SDK E2E Test - Register Derivative IP Asset with multiple PILs", funct step("Wallet B can NOT use nonComLicenseTermsId to register ipIdC as ipIdA's derivative IP asset", async function () { const response = await expect( - registerDerivative("B", ipIdC, [ipIdA], [nonComLicenseTermsId], waitForTransaction) - ).to.be.rejectedWith("Failed to register derivative: License terms id " + nonComLicenseTermsId + " must be attached to the parent ipId " + ipIdA + " before registering derivative."); + registerDerivative("B", ipIdC, [ipIdA], [0n], waitForTransaction) + ).to.be.rejectedWith("Failed to register derivative: License terms id 0 must be attached to the parent ipId " + ipIdA + " before registering derivative."); }); step("Wallet B can use comRemixLicenseTermsId1 and comRemixLicenseTermsId2 to register ipIdC as ipIdA's derivative IP asset", async function () { @@ -230,14 +230,6 @@ describe("SDK E2E Test - Register Derivative IP Asset with multiple PILs", funct expect(response.txHash).to.be.a("string").and.not.empty; }); - step("Wallet A attach nonComLicenseTermsId(non-commercial social remixing PIL) to ipIdA", async function () { - const response = await expect( - attachLicenseTerms("A", ipIdA, nonComLicenseTermsId, waitForTransaction) - ).to.not.be.rejected; - - expect(response.txHash).to.be.a("string").and.not.empty; - }); - step("Mint a NFT to Wallet B and get a tokenId (tokenIdB)", async function () { tokenIdB = await mintNFTWithRetry(privateKeyB); expect(tokenIdB).not.empty; diff --git a/test/e2e/royalty.comRemixPIL.test.ts b/test/e2e/royalty.comRemixPIL.test.ts index b516020..125d45c 100644 --- a/test/e2e/royalty.comRemixPIL.test.ts +++ b/test/e2e/royalty.comRemixPIL.test.ts @@ -1,16 +1,14 @@ -import { privateKeyA, privateKeyB, privateKeyC, mintingFeeTokenAddress, accountC, clientC, accountB, chainId, clientA, accountA } from '../../config/config' -import { getTotalRTSupply} from '../../utils/utils' -import { getRoyaltyVaultAddress, payRoyaltyOnBehalf, registerCommercialRemixPIL } from '../../utils/sdkUtils' -import { mintNFTCreateRootIPandAttachPIL, mintNFTAndRegisterDerivative, checkRoyaltyTokensCollected, getSnapshotId,checkClaimableRevenue, claimRevenueByIPA, claimRevenueByEOA, transferTokenToEOA, transferTokenToEOAWithSig } from '../testUtils' +import { privateKeyA, privateKeyB, privateKeyC, mintingFeeTokenAddress, accountA, accountB, accountC } from '../../config/config'; +import { getTotalRTSupply} from '../../utils/utils'; +import { payRoyaltyOnBehalf, registerCommercialRemixPIL } from '../../utils/sdkUtils'; +import { mintNFTCreateRootIPandAttachPIL, mintNFTAndRegisterDerivative, checkRoyaltyTokensCollected, getSnapshotId,checkClaimableRevenue, claimRevenueByIPA, claimRevenueByEOA, transferTokenToEOA } from '../testUtils'; -import { expect } from 'chai' +import { expect } from 'chai'; import chai from 'chai'; import chaiAsPromised from 'chai-as-promised'; chai.use(chaiAsPromised); -import { Address, Hex } from 'viem'; +import { Address } from 'viem'; import '../setup'; -import { AccessPermission, getPermissionSignature } from '@story-protocol/core-sdk' -import { coreMetadataModuleAbi } from '@story-protocol/core-sdk/dist/declarations/src/abi/generated' let ipIdA: Address; let ipIdB: Address; diff --git a/test/e2e/royalty.comUsePIL.test.ts b/test/e2e/royalty.comUsePIL.test.ts index fc132e4..83f78f7 100644 --- a/test/e2e/royalty.comUsePIL.test.ts +++ b/test/e2e/royalty.comUsePIL.test.ts @@ -1,20 +1,19 @@ -import { privateKeyA, privateKeyB, privateKeyC, mintingFeeTokenAddress, accountB, accountA } from '../../config/config' -import { getTotalRTSupply} from '../../utils/utils' -import { payRoyaltyOnBehalf, registerCommercialUsePIL } from '../../utils/sdkUtils' -import { expect } from 'chai' -import { mintNFTCreateRootIPandAttachPIL, mintNFTAndRegisterDerivative, checkRoyaltyTokensCollected, getSnapshotId,checkClaimableRevenue, claimRevenueByIPA, claimRevenueByEOA, transferTokenToEOA } from '../testUtils' +import { privateKeyA, privateKeyB, privateKeyC, mintingFeeTokenAddress, accountB, accountA } from '../../config/config'; +import { getTotalRTSupply} from '../../utils/utils'; +import { payRoyaltyOnBehalf, registerCommercialUsePIL } from '../../utils/sdkUtils'; +import { expect } from 'chai'; +import { mintNFTCreateRootIPandAttachPIL, mintNFTAndRegisterDerivative, checkRoyaltyTokensCollected, getSnapshotId,checkClaimableRevenue, claimRevenueByIPA, claimRevenueByEOA, transferTokenToEOA } from '../testUtils'; import chai from 'chai'; import chaiAsPromised from 'chai-as-promised'; chai.use(chaiAsPromised); import '../setup'; import { Address } from 'viem'; -import { comUseLicenseTermsId1, mintingFee1 } from '../setup' +import { comUseLicenseTermsId1, mintingFee1 } from '../setup'; let ipIdA: Address; let ipIdB: Address; let ipIdC: Address; -let ipIdD: Address; let snapshotId1_ipIdA: bigint; let snapshotId1_ipIdB: bigint; let TOTAL_RT_SUPPLY: number; diff --git a/test/e2e/setPermissions.test.ts b/test/e2e/setPermissions.test.ts index b72ebce..2ba6d93 100644 --- a/test/e2e/setPermissions.test.ts +++ b/test/e2e/setPermissions.test.ts @@ -4,7 +4,7 @@ import { registerIpAsset, setPermission, attachLicenseTerms } from '../../utils/ import { expect } from 'chai'; import { Hex } from 'viem'; import '../setup'; -import { nonComLicenseTermsId, comUseLicenseTermsId1 } from '../setup'; +import { comUseLicenseTermsId1 } from '../setup'; import chai from 'chai'; import chaiAsPromised from 'chai-as-promised'; @@ -46,9 +46,9 @@ describe('@smoke SDK E2E Test - Permissions', function () { describe("Set permission - 1 ALLOW", async function (){ // error 0xb3e96921: AccessController__PermissionDenied(address,address,address,bytes4) - step("Wallet B(non-owner) can NOT attach licenseTermsId1 to ipIdA", async function () { + step("Wallet B(non-owner) can NOT attach licenseTermsId 0 to ipIdA", async function () { const response = await expect( - attachLicenseTerms("B", ipIdA, nonComLicenseTermsId, waitForTransaction) + attachLicenseTerms("B", ipIdA, 0n, waitForTransaction) ).to.be.rejectedWith("Failed to attach license terms: The contract function \"attachLicenseTerms\" reverted with the following signature:", "0xb3e96921"); }); @@ -62,9 +62,9 @@ describe('@smoke SDK E2E Test - Permissions', function () { expect(response.success).to.be.true; }); - step("Wallet B can attach licenseTermsId1 to ipIdA", async function () { + step("Wallet B can attach licenseTermsId 0 to ipIdA", async function () { const response = await expect( - attachLicenseTerms("B", ipIdA, nonComLicenseTermsId, waitForTransaction) + attachLicenseTerms("B", ipIdA, 0n, waitForTransaction) ).to.not.be.rejected; expect(response.txHash).to.be.a("string").and.not.empty; @@ -72,9 +72,9 @@ describe('@smoke SDK E2E Test - Permissions', function () { // wallet B is not granted any permission for ipIdB // error 0xb3e96921: AccessController__PermissionDenied(address,address,address,bytes4) - step("Wallet B can NOT attach licenseTermsId1 to ipIdB", async function () { + step("Wallet B can NOT attach licenseTermsId 0 to ipIdB", async function () { const response = await expect( - attachLicenseTerms("B", ipIdB, nonComLicenseTermsId, waitForTransaction) + attachLicenseTerms("B", ipIdB, 0n, waitForTransaction) ).to.be.rejectedWith("Failed to attach license terms: The contract function \"attachLicenseTerms\" reverted with the following signature:", "0xb3e96921"); }); }); @@ -109,9 +109,9 @@ describe('@smoke SDK E2E Test - Permissions', function () { expect(response.success).to.be.true; }); - step("Wallet B can attach licenseTermsId1 to ipIdB", async function () { + step("Wallet B can attach licenseTermsId 0 to ipIdB", async function () { const response = await expect( - attachLicenseTerms("B", ipIdB, nonComLicenseTermsId, waitForTransaction) + attachLicenseTerms("B", ipIdB, 0n, waitForTransaction) ).to.not.be.rejected; expect(response.txHash).to.be.a("string").and.not.empty; diff --git a/test/ipAccount/executeWithSig.test.ts b/test/ipAccount/executeWithSig.test.ts index 88d4f4d..383c6bf 100644 --- a/test/ipAccount/executeWithSig.test.ts +++ b/test/ipAccount/executeWithSig.test.ts @@ -1,6 +1,6 @@ import { privateKeyA, privateKeyB, clientA, accountA, chainId } from '../../config/config'; import { getDeadline, getWalletClient } from '../../utils/utils'; -import { expect } from 'chai' +import { expect } from 'chai'; import chai from 'chai'; import chaiAsPromised from 'chai-as-promised'; chai.use(chaiAsPromised); diff --git a/test/ipAsset/mintAndRegisterIpAssetWithPilTerms.test.ts b/test/ipAsset/mintAndRegisterIpAssetWithPilTerms.test.ts index baeaae6..5b6021c 100644 --- a/test/ipAsset/mintAndRegisterIpAssetWithPilTerms.test.ts +++ b/test/ipAsset/mintAndRegisterIpAssetWithPilTerms.test.ts @@ -1,4 +1,4 @@ -import { accountA, mintingFeeTokenAddress } from '../../config/config'; +import { accountA, mockERC20Address, royaltyPolicyLAPAddress } from '../../config/config'; import { createNFTCollection, mintAndRegisterIpAssetWithPilTerms } from '../../utils/sdkUtils'; import { expect } from 'chai' import chai from 'chai'; @@ -6,163 +6,191 @@ import chaiAsPromised from 'chai-as-promised'; chai.use(chaiAsPromised); import '../setup'; import { Hex, toHex } from 'viem'; -import { PIL_TYPE } from '@story-protocol/core-sdk'; +import { terms } from '../../utils/constants'; const metadataURI = "http://example.com/metadata/12345"; +const nftMetadataURI = "http://example.com/metadata/2"; const metadataHash = toHex("test-metadata-hash", { size: 32 }); const nftMetadataHash = toHex("test-nft-metadata-hash", { size: 32 }); let nftCollectionAddress: Hex; -describe('SDK Test', function () { - before("Create NFT collection",async function () { +describe.only('SDK Test', function () { + before("Create NFT collection",async function () { + const response = await expect( + createNFTCollection("A", "sdk-e2e-test", "test", true, true, accountA.address, "contract-uri", true) + ).to.not.be.rejected; + + expect(response.txHash).to.be.a("string").and.not.empty; + expect(response.spgNftContract).to.be.a("string").and.not.empty; + + nftCollectionAddress = response.spgNftContract; + }); + + describe('Test ipAsset.registerDerivativeIp Function', async function () { + it("Register an IP asset fail as undefined NFT contract address", async function () { + let nftContractAddress: any; + await expect( + mintAndRegisterIpAssetWithPilTerms("A", nftContractAddress, [terms]) + ).to.be.rejectedWith(`Failed to mint and register IP and attach PIL terms: request.spgNftContract address is invalid: undefined, Address must be a hex value of 20 bytes (40 hex characters) and match its checksum counterpart.`); + }); + + it("Register an IP asset fail as invalid NFT contract address", async function () { + await expect( + mintAndRegisterIpAssetWithPilTerms("A", "0x0000", [terms]) + ).to.be.rejectedWith(`Failed to mint and register IP and attach PIL terms: request.spgNftContract address is invalid: 0x0000, Address must be a hex value of 20 bytes (40 hex characters) and match its checksum counterpart.`); + }); + + it("Register an IP asset fail as non-existent NFT contract address", async function () { + await expect( + mintAndRegisterIpAssetWithPilTerms("A", "0x121022F354787754f39f55b9795178dA291348Ba", [terms]) + ).to.be.rejectedWith(`Failed to mint and register IP and attach PIL terms: Execution reverted for an unknown reason.`); + }); + + it("Register an IP asset fail as undefined terms", async function () { + let testTerms: any; + await expect( + mintAndRegisterIpAssetWithPilTerms("A", nftCollectionAddress, testTerms) + ).to.be.rejectedWith("Failed to mint and register IP and attach PIL terms: Cannot read properties of undefined (reading 'length')"); + }); + + it("Register an IP asset fail as invalid metadataHash", async function () { + await expect( + mintAndRegisterIpAssetWithPilTerms("A", nftCollectionAddress, [terms], true, metadataURI, "0x0000") + ).to.be.rejectedWith(`Failed to mint and register IP and attach PIL terms: Size of bytes "0x0000" (bytes2) does not match expected size (bytes32).`); + }); + + it("Register an IP asset fail as invalid nftMetadataHash", async function () { + await expect( + mintAndRegisterIpAssetWithPilTerms("A", nftCollectionAddress, [terms], true, metadataURI, undefined, undefined, "0x0000") + ).to.be.rejectedWith(`Failed to mint and register IP and attach PIL terms: Size of bytes "0x0000" (bytes2) does not match expected size (bytes32).`); + }); + + it("Register an IP asset fail as invalid recipient", async function () { + await expect( + mintAndRegisterIpAssetWithPilTerms("A", nftCollectionAddress, [terms], true, undefined, undefined, undefined, undefined, "0x000") + ).to.be.rejectedWith(`Failed to mint and register IP and attach PIL terms: request.recipient address is invalid: 0x000, Address must be a hex value of 20 bytes (40 hex characters) and match its checksum counterpart.`); + }); + + it("Register an IP asset fail as missing required parameters for commercialUse is true", async function () { + const testTerms = terms; + testTerms.commercialUse = true; + + await expect( + mintAndRegisterIpAssetWithPilTerms("A", nftCollectionAddress, [testTerms], true) + ).to.be.rejectedWith(`Failed to mint and register IP and attach PIL terms: Royalty policy is required when commercial use is enabled.`); + }); + + it.only("Register an IP asset fail as missing required parameters for commercialUse is true", async function () { + const testTerms = terms; + testTerms.commercialUse = true; + testTerms.royaltyPolicy = royaltyPolicyLAPAddress; + console.log(testTerms); + + await expect( + mintAndRegisterIpAssetWithPilTerms("A", nftCollectionAddress, [testTerms], true) + ).to.be.rejectedWith(`Failed to mint and register IP and attach PIL terms: Royalty policy requires currency token.`); + }); + + it.only("Register an IP asset with commercialUse is true", async function () { + const testTerms = terms; + testTerms.commercialUse = true; + testTerms.royaltyPolicy = royaltyPolicyLAPAddress; + testTerms.currency = mockERC20Address; + console.log(testTerms); + + await expect( + mintAndRegisterIpAssetWithPilTerms("A", nftCollectionAddress, [testTerms], true) + ).to.be.rejectedWith(`Failed to mint and register IP and attach PIL terms: Royalty policy requires currency token.`); + }); + + it("Register an IP asset fail as missing required parameters for commercial remix PIL", async function () { + await expect( + mintAndRegisterIpAssetWithPilTerms("A", nftCollectionAddress, [terms], true) + ).to.be.rejectedWith(`Failed to mint and register IP and attach PIL terms: DefaultMintingFee, currency and commercialRevShare are required for commercial remix PIL.`); + }); + + it("Non-owner register an IP asset fail", async function () { + // await expect( + await + mintAndRegisterIpAssetWithPilTerms("B", nftCollectionAddress, [terms], true) + // ).to.be.rejectedWith(`Failed to mint and register IP and attach PIL terms: The contract function "mintAndRegisterIpAndAttachPILTerms" reverted.`, `Error: SPG__CallerNotMinterRole()`); + }); + + it("Register an IP asset with waitForTransaction: false", async function () { + const response = await expect( + mintAndRegisterIpAssetWithPilTerms("A", nftCollectionAddress, [terms], false, undefined, undefined, undefined, undefined, undefined) + ).to.not.be.rejected; + + expect(response.txHash).to.be.a("string").and.not.empty; + expect(response.ipId).to.not.be.exist; + expect(response.tokenId).to.not.be.exist; + expect(response.licenseTermsId).to.not.be.exist; + }); + + it("Register an IP asset with non-commercial remix license terms id 2", async function () { + const response = await expect( + mintAndRegisterIpAssetWithPilTerms("A", nftCollectionAddress, [terms], true) + ).to.not.be.rejected; + + expect(response.txHash).to.be.a("string").and.not.empty; + expect(response.ipId).to.be.a("string").and.not.empty; + expect(response.tokenId).to.be.a("bigint").and.to.be.ok; + expect(response.licenseTermsId).to.be.a("bigint").and.to.be.ok; + }); + + it("Register an IP asset with commercial use license terms", async function () { + const response = await expect( + mintAndRegisterIpAssetWithPilTerms("A", nftCollectionAddress, [terms], true, undefined, undefined, undefined, undefined, undefined) + ).to.not.be.rejected; + + expect(response.txHash).to.be.a("string").and.not.empty; + expect(response.ipId).to.be.a("string").and.not.empty; + expect(response.tokenId).to.be.a("bigint").and.to.be.ok; + expect(response.licenseTermsId).to.be.a("bigint").and.to.be.ok; + }); + + it("Register an IP asset with commercial remix license terms", async function () { + const response = await expect( + mintAndRegisterIpAssetWithPilTerms("A", nftCollectionAddress, [terms], true, undefined, undefined, undefined, undefined, undefined) + ).to.not.be.rejected; + + expect(response.txHash).to.be.a("string").and.not.empty; + expect(response.ipId).to.be.a("string").and.not.empty; + expect(response.tokenId).to.be.a("bigint").and.to.be.ok; + expect(response.licenseTermsId).to.be.a("bigint").and.to.be.ok; + }); + + it("Register an IP asset with non-commercial remix license terms id 2 and all optional parameters", async function () { + const response = await expect( + mintAndRegisterIpAssetWithPilTerms("A", nftCollectionAddress, [terms], true, metadataURI, metadataHash, nftMetadataURI, nftMetadataHash, accountA.address) + ).to.not.be.rejected; + + expect(response.txHash).to.be.a("string").and.not.empty; + expect(response.ipId).to.be.a("string").and.not.empty; + expect(response.tokenId).to.be.a("bigint").and.to.be.ok; + expect(response.licenseTermsId).to.be.a("bigint").and.to.be.ok; + }); + + it("Register an IP asset with commercial use license terms and all optional parameters", async function () { + const response = await expect( + mintAndRegisterIpAssetWithPilTerms("A", nftCollectionAddress, [terms], true, metadataURI, metadataHash, nftMetadataURI, nftMetadataHash, accountA.address) + ).to.not.be.rejected; + + expect(response.txHash).to.be.a("string").and.not.empty; + expect(response.ipId).to.be.a("string").and.not.empty; + expect(response.tokenId).to.be.a("bigint").and.to.be.ok; + expect(response.licenseTermsId).to.be.a("bigint").and.to.be.ok; + }); + + it("Register an IP asset with commercial remix license terms and all optional parameters", async function () { const response = await expect( - createNFTCollection("A", "sdk-e2e-test", "test", true) + mintAndRegisterIpAssetWithPilTerms("A", nftCollectionAddress, [terms], true, metadataURI, metadataHash, nftMetadataURI, nftMetadataHash, accountA.address) ).to.not.be.rejected; expect(response.txHash).to.be.a("string").and.not.empty; - expect(response.nftContract).to.be.a("string").and.not.empty; - - nftCollectionAddress = response.nftContract; - }); - - describe('Test ipAsset.registerDerivativeIp Function', async function () { - it("Register an IP asset fail as undefined NFT contract address", async function () { - let nftContractAddress: any; - await expect( - mintAndRegisterIpAssetWithPilTerms("A", nftContractAddress, PIL_TYPE.NON_COMMERCIAL_REMIX) - ).to.be.rejectedWith(`Failed to mint and register IP and attach PIL terms: request.nftContract address is invalid: undefined, Address must be a hex value of 20 bytes (40 hex characters) and match its checksum counterpart.`); - }); - - it("Register an IP asset fail as invalid NFT contract address", async function () { - await expect( - mintAndRegisterIpAssetWithPilTerms("A", "0x0000", PIL_TYPE.NON_COMMERCIAL_REMIX) - ).to.be.rejectedWith(`Failed to mint and register IP and attach PIL terms: request.nftContract address is invalid: 0x0000, Address must be a hex value of 20 bytes (40 hex characters) and match its checksum counterpart.`); - }); - - it("Register an IP asset fail as non-existent NFT contract address", async function () { - await expect( - mintAndRegisterIpAssetWithPilTerms("A", "0x121022F354787754f39f55b9795178dA291348Ba", PIL_TYPE.NON_COMMERCIAL_REMIX) - ).to.be.rejectedWith(`Failed to mint and register IP and attach PIL terms: The contract function "mintAndRegisterIpAndAttachPILTerms" reverted.`); - }); - - it("Register an IP asset fail as undefined pilType", async function () { - let pilType: any; - await expect( - mintAndRegisterIpAssetWithPilTerms("A", nftCollectionAddress, pilType) - ).to.be.rejectedWith("Failed to mint and register IP and attach PIL terms: PIL type is required."); - }); - - it("Register an IP asset fail as invalid metadataHash", async function () { - await expect( - mintAndRegisterIpAssetWithPilTerms("A", nftCollectionAddress, PIL_TYPE.NON_COMMERCIAL_REMIX, true, metadataURI, "0x0000") - ).to.be.rejectedWith(`Failed to mint and register IP and attach PIL terms: Size of bytes "0x0000" (bytes2) does not match expected size (bytes32).`); - }); - - it("Register an IP asset fail as invalid nftMetadataHash", async function () { - await expect( - mintAndRegisterIpAssetWithPilTerms("A", nftCollectionAddress, PIL_TYPE.NON_COMMERCIAL_REMIX, true, metadataURI, undefined, "0x0000") - ).to.be.rejectedWith(`Failed to mint and register IP and attach PIL terms: Size of bytes "0x0000" (bytes2) does not match expected size (bytes32).`); - }); - - it("Register an IP asset fail as invalid recipient", async function () { - await expect( - mintAndRegisterIpAssetWithPilTerms("A", nftCollectionAddress, PIL_TYPE.NON_COMMERCIAL_REMIX, true, metadataURI, undefined, undefined, "0x000") - ).to.be.rejectedWith(`Failed to mint and register IP and attach PIL terms: request.recipient address is invalid: 0x000, Address must be a hex value of 20 bytes (40 hex characters) and match its checksum counterpart.`); - }); - - it("Register an IP asset fail as missing required parameters for commercial use PIL", async function () { - await expect( - mintAndRegisterIpAssetWithPilTerms("A", nftCollectionAddress, PIL_TYPE.COMMERCIAL_USE, true) - ).to.be.rejectedWith(`Failed to mint and register IP and attach PIL terms: mintingFee currency are required for commercial use PIL.`); - }); - - it("Register an IP asset fail as missing required parameters for commercial remix PIL", async function () { - await expect( - mintAndRegisterIpAssetWithPilTerms("A", nftCollectionAddress, PIL_TYPE.COMMERCIAL_REMIX, true) - ).to.be.rejectedWith(`Failed to mint and register IP and attach PIL terms: mintingFee, currency and commercialRevShare are required for commercial remix PIL.`); - }); - - it("Non-owner register an IP asset fail", async function () { - await expect( - mintAndRegisterIpAssetWithPilTerms("B", nftCollectionAddress, PIL_TYPE.NON_COMMERCIAL_REMIX, true) - ).to.be.rejectedWith(`Failed to mint and register IP and attach PIL terms: The contract function "mintAndRegisterIpAndAttachPILTerms" reverted.`, `Error: SPG__CallerNotMinterRole()`); - }); - - it("Register an IP asset with waitForTransaction: false", async function () { - const response = await expect( - mintAndRegisterIpAssetWithPilTerms("A", nftCollectionAddress, PIL_TYPE.NON_COMMERCIAL_REMIX, false) - ).to.not.be.rejected; - - expect(response.txHash).to.be.a("string").and.not.empty; - expect(response.ipId).to.not.be.exist; - expect(response.tokenId).to.not.be.exist; - expect(response.licenseTermsId).to.not.be.exist; - }); - - it("Register an IP asset with non-commercial remix license terms", async function () { - const response = await expect( - mintAndRegisterIpAssetWithPilTerms("A", nftCollectionAddress, PIL_TYPE.NON_COMMERCIAL_REMIX, true) - ).to.not.be.rejected; - - expect(response.txHash).to.be.a("string").and.not.empty; - expect(response.ipId).to.be.a("string").and.not.empty; - expect(response.tokenId).to.be.a("bigint").and.to.be.ok; - expect(response.licenseTermsId).to.be.a("bigint").and.to.be.ok; - }); - - it("Register an IP asset with commercial use license terms", async function () { - const response = await expect( - mintAndRegisterIpAssetWithPilTerms("A", nftCollectionAddress, PIL_TYPE.COMMERCIAL_USE, true, undefined, undefined, undefined, undefined, "80", undefined, mintingFeeTokenAddress) - ).to.not.be.rejected; - - expect(response.txHash).to.be.a("string").and.not.empty; - expect(response.ipId).to.be.a("string").and.not.empty; - expect(response.tokenId).to.be.a("bigint").and.to.be.ok; - expect(response.licenseTermsId).to.be.a("bigint").and.to.be.ok; - }); - - it("Register an IP asset with commercial remix license terms", async function () { - const response = await expect( - mintAndRegisterIpAssetWithPilTerms("A", nftCollectionAddress, PIL_TYPE.COMMERCIAL_REMIX, true, undefined, undefined, undefined, undefined, "60", 20, mintingFeeTokenAddress) - ).to.not.be.rejected; - - expect(response.txHash).to.be.a("string").and.not.empty; - expect(response.ipId).to.be.a("string").and.not.empty; - expect(response.tokenId).to.be.a("bigint").and.to.be.ok; - expect(response.licenseTermsId).to.be.a("bigint").and.to.be.ok; - }); - - it("Register an IP asset with non-commercial remix license terms and all optional parameters", async function () { - const response = await expect( - mintAndRegisterIpAssetWithPilTerms("A", nftCollectionAddress, PIL_TYPE.NON_COMMERCIAL_REMIX, true, metadataURI, metadataHash, nftMetadataHash, accountA.address) - ).to.not.be.rejected; - - expect(response.txHash).to.be.a("string").and.not.empty; - expect(response.ipId).to.be.a("string").and.not.empty; - expect(response.tokenId).to.be.a("bigint").and.to.be.ok; - expect(response.licenseTermsId).to.be.a("bigint").and.to.be.ok; - }); - - it("Register an IP asset with commercial use license terms and all optional parameters", async function () { - const response = await expect( - mintAndRegisterIpAssetWithPilTerms("A", nftCollectionAddress, PIL_TYPE.COMMERCIAL_USE, true, metadataURI, metadataHash, nftMetadataHash, accountA.address, "100", undefined, mintingFeeTokenAddress) - ).to.not.be.rejected; - - expect(response.txHash).to.be.a("string").and.not.empty; - expect(response.ipId).to.be.a("string").and.not.empty; - expect(response.tokenId).to.be.a("bigint").and.to.be.ok; - expect(response.licenseTermsId).to.be.a("bigint").and.to.be.ok; - }); - - it("Register an IP asset with commercial remix license terms and all optional parameters", async function () { - const response = await expect( - mintAndRegisterIpAssetWithPilTerms("A", nftCollectionAddress, PIL_TYPE.COMMERCIAL_REMIX, true, metadataURI, metadataHash, nftMetadataHash, accountA.address, "100", 10, mintingFeeTokenAddress) - ).to.not.be.rejected; - - expect(response.txHash).to.be.a("string").and.not.empty; - expect(response.ipId).to.be.a("string").and.not.empty; - expect(response.tokenId).to.be.a("bigint").and.to.be.ok; - expect(response.licenseTermsId).to.be.a("bigint").and.to.be.ok; - }); + expect(response.ipId).to.be.a("string").and.not.empty; + expect(response.tokenId).to.be.a("bigint").and.to.be.ok; + expect(response.licenseTermsId).to.be.a("bigint").and.to.be.ok; }); + }); }); diff --git a/test/ipAsset/register.test.ts b/test/ipAsset/register.test.ts index a05ed85..0e84665 100644 --- a/test/ipAsset/register.test.ts +++ b/test/ipAsset/register.test.ts @@ -1,7 +1,7 @@ import { privateKeyA, privateKeyB, privateKeyC, nftContractAddress } from '../../config/config'; import { registerIpAsset } from '../../utils/sdkUtils'; -import { checkMintResult, isRegistered, mintNFTWithRetry } from '../../utils/utils'; -import { expect } from 'chai' +import { checkMintResult, isRegistered, mintNFT, mintNFTWithRetry } from '../../utils/utils'; +import { expect } from 'chai'; import chai from 'chai'; import chaiAsPromised from 'chai-as-promised'; chai.use(chaiAsPromised); @@ -16,13 +16,13 @@ let ipIdA: Address; describe('SDK Test', function () { describe('Test ipAsset.register Function', async function () { before("Mint 3 NFTs to Wallet A", async function () { - tokenIdA = await mintNFTWithRetry(privateKeyA); + tokenIdA = await mintNFT(privateKeyA); checkMintResult(tokenIdA); - tokenIdB = await mintNFTWithRetry(privateKeyB); + tokenIdB = await mintNFT(privateKeyB); checkMintResult(tokenIdB); - tokenIdC = await mintNFTWithRetry(privateKeyC); + tokenIdC = await mintNFT(privateKeyC); checkMintResult(tokenIdC); }); @@ -63,14 +63,15 @@ describe('SDK Test', function () { ipIdA = response.ipId; // call contract to check isRegistered - const checkIpIdRegistered = await isRegistered(ipIdA); - expect(checkIpIdRegistered).to.be.equal(true); + // const checkIpIdRegistered = await isRegistered(ipIdA); + // expect(checkIpIdRegistered).to.be.equal(true); }); it("Register an IP asset that is already registered", async function () { const response = await expect( registerIpAsset("A", nftContractAddress, tokenIdA, true) ).to.not.be.rejected; + console.log(response); expect(response.txHash).not.to.be.exist; expect(response.ipId).to.be.a("string").and.not.empty; diff --git a/test/ipAsset/registerDerivative.test.ts b/test/ipAsset/registerDerivative.test.ts index b934fcb..2964ac3 100644 --- a/test/ipAsset/registerDerivative.test.ts +++ b/test/ipAsset/registerDerivative.test.ts @@ -1,7 +1,7 @@ import { privateKeyA, privateKeyB, nftContractAddress } from '../../config/config'; import { attachLicenseTerms, registerDerivative, registerIpAsset } from '../../utils/sdkUtils'; -import { checkMintResult, mintNFTWithRetry } from '../../utils/utils'; -import { expect } from 'chai' +import { checkMintResult, mintNFT, mintNFTWithRetry } from '../../utils/utils'; +import { expect } from 'chai'; import chai from 'chai'; import chaiAsPromised from 'chai-as-promised'; chai.use(chaiAsPromised); @@ -17,11 +17,11 @@ let ipIdB: Address; describe('SDK Test', function () { describe('Test ipAsset.registerDerivative Function', async function () { before("Register license terms, mint NFTs and register IP assets",async function () { - tokenIdA = await mintNFTWithRetry(privateKeyA); + tokenIdA = await mintNFT(privateKeyA); checkMintResult(tokenIdA); expect(tokenIdA).not.empty; - tokenIdB = await mintNFTWithRetry(privateKeyB); + tokenIdB = await mintNFT(privateKeyB); checkMintResult(tokenIdB); expect(tokenIdB).not.empty; @@ -46,18 +46,18 @@ describe('SDK Test', function () { it("Register a derivative IP asset fail as no license terms attached", async function () { await expect( - registerDerivative("C", ipIdB, [ipIdA], [nonComLicenseTermsId], true) - ).to.be.rejectedWith("Failed to register derivative: License terms id " + nonComLicenseTermsId + " must be attached to the parent ipId " + ipIdA + " before registering derivative."); + registerDerivative("C", ipIdB, [ipIdA], [0n], true) + ).to.be.rejectedWith("Failed to register derivative: License terms id 0 must be attached to the parent ipId " + ipIdA + " before registering derivative."); }); it("Register a derivative IP asset fail as no license terms attached", async function () { const response = await expect( - attachLicenseTerms("A", ipIdA, nonComLicenseTermsId, true) + attachLicenseTerms("A", ipIdA, 0n, true) ).to.not.be.rejected; expect(response.txHash).to.be.a("string").and.not.empty; await expect( - registerDerivative("C", ipIdB, [ipIdA], [nonComLicenseTermsId], true) + registerDerivative("C", ipIdB, [ipIdA], [0n], true) ).to.be.rejectedWith("Failed to register derivative: The contract function \"registerDerivative\" reverted with the following signature:", "0xb3e96921"); }); diff --git a/test/ipAsset/registerDerivativeIp.test.ts b/test/ipAsset/registerDerivativeIp.test.ts index c318f4a..fc59cce 100644 --- a/test/ipAsset/registerDerivativeIp.test.ts +++ b/test/ipAsset/registerDerivativeIp.test.ts @@ -1,7 +1,7 @@ -import { privateKeyA, nftContractAddress } from '../../config/config'; +import { privateKeyA, nftContractAddress, accountA, licenseTemplateAddress } from '../../config/config'; import { attachLicenseTerms, registerDerivativeIp, registerIpAsset, createNFTCollection } from '../../utils/sdkUtils'; import { checkMintResult, getBlockTimestamp, mintNFTWithRetry } from '../../utils/utils'; -import { expect } from 'chai' +import { expect } from 'chai'; import chai from 'chai'; import chaiAsPromised from 'chai-as-promised'; chai.use(chaiAsPromised); @@ -13,25 +13,31 @@ let tokenIdA: string; let tokenIdB: string; let ipIdA: Address; let nftCollectionAddress: Address; -const metadataURI = "http://example.com/metadata/12345"; +const metadataURI = "http://example.com/metadata/1"; +const nftMetadataURI = "http://example.com/metadata/2"; describe('SDK Test', function () { describe('Test ipAsset.registerDerivativeIp Function', async function () { before("Mint NFT, register IP assets and attach license terms",async function () { + console.log(accountA.address); const response = await expect( - createNFTCollection("A", "sdk-e2e-test", "test", true) + createNFTCollection("A", "sdk-e2e-test", "test", true, true, accountA.address, "contract-uri", true) ).to.not.be.rejected; expect(response.txHash).to.be.a("string").and.not.empty; - expect(response.nftContract).to.be.a("string").and.not.empty; + expect(response.spgNftContract).to.be.a("string").and.not.empty; - nftCollectionAddress = response.nftContract; + nftCollectionAddress = response.spgNftContract as Address; + console.log(nftCollectionAddress); - tokenIdA = await mintNFTWithRetry(privateKeyA, nftCollectionAddress); + + tokenIdA = await mintNFTWithRetry(privateKeyA, nftCollectionAddress, "nft-metadata-test"); checkMintResult(tokenIdA); + console.log(tokenIdA); - tokenIdB = await mintNFTWithRetry(privateKeyA, nftCollectionAddress); + tokenIdB = await mintNFTWithRetry(privateKeyA, nftCollectionAddress, "nft-metadata-test"); checkMintResult(tokenIdB); + console.log(tokenIdB); const responseRegisterIpA = await expect( registerIpAsset("A", nftCollectionAddress, tokenIdA, true) @@ -43,7 +49,7 @@ describe('SDK Test', function () { ipIdA = responseRegisterIpA.ipId; const attachLicenseTermsResponse = await expect( - attachLicenseTerms("A", ipIdA, nonComLicenseTermsId, true) + attachLicenseTerms("A", ipIdA, 0n, true) ).to.not.be.rejected; expect(attachLicenseTermsResponse.txHash).to.be.a("string").and.not.empty; @@ -140,13 +146,13 @@ describe('SDK Test', function () { it("Register a derivative IP asset fail as invalid nftMetadataHash", async function () { await expect( - registerDerivativeIp("A", nftContractAddress, tokenIdB, [ipIdA], [nonComLicenseTermsId], true, undefined, metadataURI, undefined, "0x0000") + registerDerivativeIp("A", nftContractAddress, tokenIdB, [ipIdA], [nonComLicenseTermsId], true, undefined, metadataURI, undefined, undefined, "0x0000") ).to.be.rejectedWith(`Failed to register derivative IP: Size of bytes "0x0000" (bytes2) does not match expected size (bytes32).`); }); it("Register a derivative IP asset fail as invalid deadline", async function () { await expect( - registerDerivativeIp("A", nftContractAddress, tokenIdB, [ipIdA], [nonComLicenseTermsId], true, undefined, metadataURI, undefined, undefined, "test") + registerDerivativeIp("A", nftContractAddress, tokenIdB, [ipIdA], [nonComLicenseTermsId], true, undefined, metadataURI, undefined, undefined, undefined, "test") ).to.be.rejectedWith(`Failed to register derivative IP: Invalid deadline value.`); }); @@ -201,7 +207,7 @@ describe('SDK Test', function () { }); it("Register a derivative IP asset with all optional parameters", async function () { - const licenseTemplate = "0x260B6CB6284c89dbE660c0004233f7bB99B5edE7"; + const licenseTemplate = licenseTemplateAddress; const metadataHash = toHex("test-metadata-hash", { size: 32 }); const nftMetadataHash = toHex("test-nft-metadata-hash", { size: 32 }); const deadline = await(getBlockTimestamp()) + 1000n; @@ -210,7 +216,7 @@ describe('SDK Test', function () { expect(tokenIdC).to.be.a("string").and.not.empty; const response = await expect( - registerDerivativeIp("A", nftCollectionAddress, tokenIdC, [ipIdA], [nonComLicenseTermsId], true, licenseTemplate, metadataURI, metadataHash, nftMetadataHash, deadline) + registerDerivativeIp("A", nftCollectionAddress, tokenIdC, [ipIdA], [nonComLicenseTermsId], true, licenseTemplate, metadataURI, metadataHash, nftMetadataURI, nftMetadataHash, deadline) ).to.not.be.rejected; expect(response.txHash).to.be.a("string").and.not.empty; diff --git a/test/ipAsset/registerDerivativeWithLicenseTokens.test.ts b/test/ipAsset/registerDerivativeWithLicenseTokens.test.ts index 05400cc..962f703 100644 --- a/test/ipAsset/registerDerivativeWithLicenseTokens.test.ts +++ b/test/ipAsset/registerDerivativeWithLicenseTokens.test.ts @@ -1,7 +1,7 @@ import { privateKeyA, privateKeyB, privateKeyC, accountB, accountC, nftContractAddress } from '../../config/config'; import { attachLicenseTerms, registerDerivativeWithLicenseTokens, registerIpAsset, mintLicenseTokens } from '../../utils/sdkUtils'; -import { checkMintResult, mintNFTWithRetry } from '../../utils/utils'; -import { expect } from 'chai' +import { checkMintResult, mintNFT, mintNFTWithRetry } from '../../utils/utils'; +import { expect } from 'chai'; import chai from 'chai'; import chaiAsPromised from 'chai-as-promised'; chai.use(chaiAsPromised); @@ -23,13 +23,13 @@ let licenseTokenIdD: bigint; describe('SDK Test', function () { describe('Test ipAsset.registerDerivativeWithLicenseTokens Function', async function () { before("Register license terms, register IP assets and mint license tokens",async function () { - tokenIdA = await mintNFTWithRetry(privateKeyA); + tokenIdA = await mintNFT(privateKeyA); checkMintResult(tokenIdA); - tokenIdB = await mintNFTWithRetry(privateKeyB); + tokenIdB = await mintNFT(privateKeyB); checkMintResult(tokenIdB); - tokenIdC = await mintNFTWithRetry(privateKeyC); + tokenIdC = await mintNFT(privateKeyC); checkMintResult(tokenIdC); const responseRegisterIpA = await expect( @@ -59,12 +59,6 @@ describe('SDK Test', function () { ipIdC = responseRegisterIpC.ipId; - const responseAttachLicenseTerms1 = await expect( - attachLicenseTerms("A", ipIdA, nonComLicenseTermsId, true) - ).to.not.be.rejected; - - expect(responseAttachLicenseTerms1.txHash).to.be.a("string").and.not.empty; - const responsemintLicenseTokenA = await expect( mintLicenseTokens("A", ipIdA, nonComLicenseTermsId, 2, accountB.address, true) ).to.not.be.rejected; @@ -156,7 +150,7 @@ describe('SDK Test', function () { it("Register a derivative IP asset fail as non-existent licenseTokenId", async function () { await expect( registerDerivativeWithLicenseTokens("B", ipIdB, ["999"], true) - ).to.be.rejectedWith(`Failed to register derivative with license tokens: The contract function "registerDerivativeWithLicenseTokens" reverted with the following signature:`, `0xd474000f`); + ).to.be.rejectedWith(`Failed to register derivative with license tokens: The contract function "ownerOf" reverted.`); }); it("Register a derivative IP asset fail as LicenseTokenNotCompatibleForDerivative", async function () { @@ -206,4 +200,4 @@ describe('SDK Test', function () { expect(response.txHash).to.be.a("string").and.not.empty; }); }); -}); \ No newline at end of file +}); diff --git a/test/ipAsset/registerIPA.test.ts b/test/ipAsset/registerIPA.test.ts new file mode 100644 index 0000000..128ce65 --- /dev/null +++ b/test/ipAsset/registerIPA.test.ts @@ -0,0 +1,203 @@ +import { accountA, licenseTemplateAddress, mockERC20Address, privateKeyA, royaltyPolicyLAPAddress } from '../../config/config'; +import { attachLicenseTerms, createNFTCollection, mintAndRegisterIpAssetWithPilTerms, registerDerivative, registerDerivativeIp, registerIpAsset } from '../../utils/sdkUtils'; +import { expect } from 'chai' +import chai from 'chai'; +import chaiAsPromised from 'chai-as-promised'; +chai.use(chaiAsPromised); +import '../setup'; +import { Hex, toHex, zeroAddress } from 'viem'; +import { PIL_TYPE } from '@story-protocol/core-sdk'; +import { comRemixLicenseTermsId1, comRemixLicenseTermsId2, comUseLicenseTermsId1, comUseLicenseTermsId2 } from '../setup'; +import { get } from 'http'; +import { getBlockTimestamp, mintNFTWithRetry } from '../../utils/utils'; +import { register } from 'module'; + +const metadataURI = "http://example.com/metadata/12345"; +const nftMetadataURI = "http://example.com/metadata/2"; +const metadataHash = toHex("test-metadata-hash", { size: 32 }); +const nftMetadataHash = toHex("test-nft-metadata-hash", { size: 32 }); +let nftCollectionAddress: Hex; +let ipId: Hex; +let ipIdA: Hex; +let licenseTermsId: bigint; + +const terms = { + transferable: true, + royaltyPolicy: zeroAddress as Hex, + defaultMintingFee: 0, + expiration: 0, + commercialUse: false, + commercialAttribution: false, + commercializerChecker: zeroAddress as Hex, + commercializerCheckerData: zeroAddress as Hex, + commercialRevShare: 0, + commercialRevCeiling: 0, + derivativesAllowed: true, + derivativesAttribution: true, + derivativesApproval: false, + derivativesReciprocal: true, + derivativeRevCeiling: 0, + currency: zeroAddress as Hex, + uri: "", +}; + +describe('Test script to register IPAs', function () { + // before("Create NFT collection",async function () { + // const response = await expect( + // createNFTCollection("A", "sdk-e2e-test", "test", true, true, accountA.address, "contract-uri", true) + // ).to.not.be.rejected; + + // expect(response.txHash).to.be.a("string").and.not.empty; + // expect(response.spgNftContract).to.be.a("string").and.not.empty; + + // nftCollectionAddress = response.spgNftContract; + // }); + + describe('Test ipAsset.registerDerivativeIp Function', async function () { + // it("Register an IP asset with commercial remix license terms and all optional parameters", async function () { + // const testTerms = terms; + // testTerms.commercialUse = true; + // testTerms.royaltyPolicy = royaltyPolicyLAPAddress; + // testTerms.currency = mockERC20Address; + // testTerms.defaultMintingFee = 10; + // testTerms.commercialRevShare = 10; + + // console.log(testTerms); + + // const metadata = { + // "title":"Rolex", + // "description":"Test", + // "ipType":"Brand", + // "media_url":"https://coffee-accused-lemming-213.mypinata.cloud/ipfs/bafkreid5gk7c75i6u5gtfqfotgbhbu2c2hvvvpj4xv62es4tbbanbutmd4", + // "media_hash":"7D32BE2FF51EA74D32C0AE998270D342D1EB5ABD3CBD7DA24B930840D0D26C1F", + // "tags":[ + // "Watch", + // "Rolex" + // ], + // "creators":[ + // { + // "name":"Test1", + // "address":"0x3a64F54a05EA5e3F0e33d86A199F191fe7c5F78A", + // "contributionPercent":100, + // "socialMedia":[ + // { + // "platform":"Twitter", + // "url":"https://twitter.com/storyprotocol" + // }, + // { + // "platform":"Telegram", + // "url":"https://t.me/StoryAnnouncements" + // }, + // { + // "platform":"Website", + // "url":"https://story.foundation" + // }, + // { + // "platform":"Discord", + // "url":"https://discord.gg/storyprotocol" + // }, + // { + // "platform":"YouTube", + // "url":"https://youtube.com/@storyFDN" + // } + // ] + // } + // ] + // } + + // const metadataHash = toHex("Dooldead", { size: 32 }); + + // const metadataURI = "https://coffee-accused-lemming-213.mypinata.cloud/ipfs/bafkreiepcxorzxbmmyedislhf6nd63umqa6n7ixj5c7wyobl4uwhtauh2u"; + + + // const response = await expect( + // // mintAndRegisterIpAssetWithPilTerms("A", nftCollectionAddress, testTerms, true, metadataURI, metadataHash, nftMetadataURI, nftMetadataHash, accountA.address) + // mintAndRegisterIpAssetWithPilTerms("A", nftCollectionAddress, [testTerms], true, metadataURI, undefined, undefined, undefined, accountA.address) + // ).to.not.be.rejected; + + // ipIdA = response.ipId; + + // expect(response.txHash).to.be.a("string").and.not.empty; + // expect(response.ipId).to.be.a("string").and.not.empty; + // expect(response.tokenId).to.be.a("bigint").and.to.be.ok; + // expect(response.licenseTermsIds[0]).to.be.a("bigint").and.to.be.ok; + + // licenseTermsId = response.licenseTermsIds[0]; + + // }); + + // it("Attach License Terms", async function () { + // // const ipId = "0xf021FE45bd6838AE0cF9F54a6C93DB3d82BdE0Df" as Hex; + // const response = await expect( + // attachLicenseTerms("A", ipId, comUseLicenseTermsId2, true) + // ).not.to.be.rejectedWith(Error); + // }); + + // it("Register a derivative IP asset fail as no license terms attached", async function () { + // const ipIdA = "0x5d66104AeF6c2876A547643514c047fb74c471eD" as Hex; + // const ipIdB = "0x83C5EeeAC3D4B176F1B8128e86DDC0F72C0dc6b9" as Hex; + + // const respone = await expect( + // registerDerivative("A", ipIdB, [ipIdA], [159n], true) + // ).not.to.be.rejectedWith(Error); + // }); + + + it("Register a derivative IP asset success", async function () { + + const IP = [ + '0xAa8bd0e74665355811589044B5F7e86FA03DaB0f', + '0x5BA350B25D96Ea27B1218da55391411c4100E8b4', + '0xE0303dc88cDC302A52EE1760857bE2270F57b529', + '0xC84D9eA8FB343d100bA53ba7DCE04c98ab45e3C8', + '0x525ecB5C9fC9094673a643A750D93bF86Da270EC', + '0xEC365eFda16b3248E721F1067B0EF45D6AaDd7e7' + ] + const ipIdA = "0x525ecB5C9fC9094673a643A750D93bF86Da270EC" as Hex; + const nftCollectionAddress = "0x201871dDC4596cAC35c90031C58253C1255f2CC4" as Hex; + const licenseTemplate = licenseTemplateAddress; + + const metadataURI = "https://coffee-accused-lemming-213.mypinata.cloud/ipfs/bafkreih6k4ml36pc6ghb34ahzixz74pi4zpjcumdyhotazijh26lckzjiu"; + + // const tokenIdB = await mintNFTWithRetry(privateKeyA, nftCollectionAddress); + // expect(tokenIdB).to.be.a("string").and.not.empty; + + // const registerRootIPResponse = await expect( + // registerIpAsset("A", nftCollectionAddress, tokenIdB, true) + // ).to.not.be.rejected; + + // expect(registerRootIPResponse.txHash).to.be.a("string"); + // expect(registerRootIPResponse.txHash).not.empty; + // expect(registerRootIPResponse.ipId).to.be.exist; + + // const ipIdB = registerRootIPResponse.ipId; + const ipIdB = "0xEC365eFda16b3248E721F1067B0EF45D6AaDd7e7" as Hex; + + const response = await expect( + registerDerivative("A", ipIdB, [ipIdA], [7n], true) + ).to.not.be.rejectedWith(Error); + + expect(response.txHash).to.be.a("string").and.not.empty; + }); + + it("Register a derivative IP asset with all optional parameters", async function () { + const ipIdA = "0x4c007f76C0C0D31A0fAb6A747B9C3dAc794778c8" as Hex; + const nftCollectionAddress = "0x201871dDC4596cAC35c90031C58253C1255f2CC4" as Hex; + const licenseTemplate = licenseTemplateAddress; + const deadline = await(getBlockTimestamp()) + 1000n; + const metadataURI = "https://coffee-accused-lemming-213.mypinata.cloud/ipfs/bafkreih6k4ml36pc6ghb34ahzixz74pi4zpjcumdyhotazijh26lckzjiu"; + + const tokenIdB = await mintNFTWithRetry(privateKeyA, nftCollectionAddress); + expect(tokenIdB).to.be.a("string").and.not.empty; + + const licenseTermsId = 159n; + + const response = await expect( + registerDerivativeIp("A", nftCollectionAddress, tokenIdB, [ipIdA], [licenseTermsId], true, licenseTemplate, metadataURI, undefined, undefined, undefined, deadline) + ).to.not.be.rejectedWith(Error); + + expect(response.txHash).to.be.a("string").and.not.empty; + expect(response.ipId).to.be.a("string").and.not.empty; + }); + }); +}); diff --git a/test/ipAsset/registerIpAndAttachPilTerms.test.ts b/test/ipAsset/registerIpAndAttachPilTerms.test.ts index 26d04a6..12ed551 100644 --- a/test/ipAsset/registerIpAndAttachPilTerms.test.ts +++ b/test/ipAsset/registerIpAndAttachPilTerms.test.ts @@ -1,7 +1,7 @@ -import { privateKeyA, mintingFeeTokenAddress } from '../../config/config'; +import { privateKeyA, accountA, mockERC20Address, royaltyPolicyLAPAddress } from '../../config/config'; import { createNFTCollection, registerIpAndAttachPilTerms } from '../../utils/sdkUtils'; import { checkMintResult, getBlockTimestamp, mintNFTWithRetry } from '../../utils/utils'; -import { expect } from 'chai' +import { expect } from 'chai'; import chai from 'chai'; import chaiAsPromised from 'chai-as-promised'; chai.use(chaiAsPromised); @@ -10,6 +10,7 @@ import { Address, toHex } from 'viem'; import { PIL_TYPE } from '@story-protocol/core-sdk'; const metadataURI = "http://example.com/metadata/12345"; +const nftMetadataURI = "http://example.com/metadata/2"; const metadataHash = toHex("test-metadata-hash", { size: 32 }); const nftMetadataHash = toHex("test-nft-metadata-hash", { size: 32 }); let nftCollectionAddress: Address; @@ -21,111 +22,105 @@ describe('SDK Test', function () { describe('Test ipAsset.registerIpAndAttachPilTerms Function', async function () { before("Mint NFT, register IP assets and attach license terms",async function () { const response = await expect( - createNFTCollection("A", "sdk-e2e-test", "test", true) + createNFTCollection("A", "sdk-e2e-test", "test", true, true, accountA.address, "contract-uri", true) ).to.not.be.rejected; expect(response.txHash).to.be.a("string").and.not.empty; - expect(response.nftContract).to.be.a("string").and.not.empty; + expect(response.spgNftContract).to.be.a("string").and.not.empty; - nftCollectionAddress = response.nftContract; + nftCollectionAddress = response.spgNftContract; - tokenIdA = await mintNFTWithRetry(privateKeyA, nftCollectionAddress); + tokenIdA = await mintNFTWithRetry(privateKeyA, nftCollectionAddress, "nft-metadata-test"); checkMintResult(tokenIdA); - tokenIdB = await mintNFTWithRetry(privateKeyA, nftCollectionAddress); + tokenIdB = await mintNFTWithRetry(privateKeyA, nftCollectionAddress, "nft-metadata-test"); checkMintResult(tokenIdB); - tokenIdC = await mintNFTWithRetry(privateKeyA, nftCollectionAddress); + tokenIdC = await mintNFTWithRetry(privateKeyA, nftCollectionAddress, "nft-metadata-test"); checkMintResult(tokenIdC); }); it("Register IP and attach PilTerms fail as undefined NFT contract address", async function () { let nftContractAddress: any; await expect( - registerIpAndAttachPilTerms("A", nftContractAddress, tokenIdA, PIL_TYPE.NON_COMMERCIAL_REMIX, true) + registerIpAndAttachPilTerms("A", nftContractAddress, tokenIdA, PIL_TYPE.NON_COMMERCIAL_REMIX, "10", mockERC20Address, true) ).to.be.rejectedWith(`Failed to register IP and attach PIL terms: nftContract address is invalid: undefined, Address must be a hex value of 20 bytes (40 hex characters) and match its checksum counterpart.`); }); it("Register IP and attach PilTerms fail as invalid NFT contract address", async function () { await expect( - registerIpAndAttachPilTerms("A", "0x0000", tokenIdA, PIL_TYPE.NON_COMMERCIAL_REMIX, true) + registerIpAndAttachPilTerms("A", "0x0000", tokenIdA, PIL_TYPE.NON_COMMERCIAL_REMIX, "10", mockERC20Address, true) ).to.be.rejectedWith(`Failed to register IP and attach PIL terms: nftContract address is invalid: 0x0000, Address must be a hex value of 20 bytes (40 hex characters) and match its checksum counterpart.`); }); // 0x1033cd88: IPAssetRegistry__UnsupportedIERC721(address) it("Register IP and attach PilTerms fail as non-existent NFT contract address", async function () { await expect( - registerIpAndAttachPilTerms("A", "0x121022F354787754f39f55b9795178dA291348Ba", tokenIdA, PIL_TYPE.NON_COMMERCIAL_REMIX, true) + registerIpAndAttachPilTerms("A", "0x121022F354787754f39f55b9795178dA291348Ba", tokenIdA, PIL_TYPE.NON_COMMERCIAL_REMIX, "10", mockERC20Address, true) ).to.be.rejectedWith(`Failed to register IP and attach PIL terms: The contract function "registerIpAndAttachPILTerms" reverted with the following signature:`, `0x1033cd88`); }); it("Register IP and attach PilTerms fail as undefined tokenId", async function () { let tokenId: any; await expect( - registerIpAndAttachPilTerms("A", nftCollectionAddress, tokenId, PIL_TYPE.NON_COMMERCIAL_REMIX, true) + registerIpAndAttachPilTerms("A", nftCollectionAddress, tokenId, PIL_TYPE.NON_COMMERCIAL_REMIX, "10", mockERC20Address, true) ).to.be.rejectedWith("Failed to register IP and attach PIL terms: Cannot convert undefined to a BigInt"); }); it("Register IP and attach PilTerms fail as invalid tokenId", async function () { await expect( - registerIpAndAttachPilTerms("A", nftCollectionAddress, "test", PIL_TYPE.NON_COMMERCIAL_REMIX, true) + registerIpAndAttachPilTerms("A", nftCollectionAddress, "test", PIL_TYPE.NON_COMMERCIAL_REMIX, "10", mockERC20Address, true) ).to.be.rejectedWith("Failed to register IP and attach PIL terms: Cannot convert test to a BigInt"); }); // 0x7e273289 - ERC721NonexistentToken(uint256) it("Register IP and attach PilTerms fail as non-existent tokenId", async function () { await expect( - registerIpAndAttachPilTerms("A", nftCollectionAddress, "999999999999", PIL_TYPE.NON_COMMERCIAL_REMIX, true) + registerIpAndAttachPilTerms("A", nftCollectionAddress, "999999999999", PIL_TYPE.NON_COMMERCIAL_REMIX, "10", mockERC20Address, true) ).to.be.rejectedWith(`Failed to register IP and attach PIL terms: The contract function "registerIpAndAttachPILTerms" reverted with the following signature:`, `0x7e273289`); }); it("Register IP and attach PilTerms fail as undefined pilType", async function () { let pilType: any; await expect( - registerIpAndAttachPilTerms("A", nftCollectionAddress, tokenIdA, pilType, true) + registerIpAndAttachPilTerms("A", nftCollectionAddress, tokenIdA, pilType, "10", mockERC20Address, true) ).to.be.rejectedWith(`Failed to register IP and attach PIL terms: PIL type is required.`); }); it("Register IP and attach PilTerms fail as invalid metadataHash", async function () { await expect( - registerIpAndAttachPilTerms("A", nftCollectionAddress, tokenIdA, PIL_TYPE.NON_COMMERCIAL_REMIX, true, metadataURI, "0x0000") + registerIpAndAttachPilTerms("A", nftCollectionAddress, tokenIdA, PIL_TYPE.NON_COMMERCIAL_REMIX, "10", mockERC20Address, true, metadataURI, "0x0000") ).to.be.rejectedWith(`Failed to register IP and attach PIL terms: Size of bytes "0x0000" (bytes2) does not match expected size (bytes32).`); }); it("Register IP and attach PilTerms fail as invalid nftMetadataHash", async function () { await expect( - registerIpAndAttachPilTerms("A", nftCollectionAddress, tokenIdA, PIL_TYPE.NON_COMMERCIAL_REMIX, true, metadataURI, metadataHash, "0x0000") + registerIpAndAttachPilTerms("A", nftCollectionAddress, tokenIdA, PIL_TYPE.NON_COMMERCIAL_REMIX, "10", mockERC20Address, true, metadataURI, metadataHash, nftMetadataURI, "0x0000") ).to.be.rejectedWith(`Failed to register IP and attach PIL terms: Size of bytes "0x0000" (bytes2) does not match expected size (bytes32).`); }); it("Register IP and attach PilTerms fail as invalid deadline", async function () { await expect( - registerIpAndAttachPilTerms("A", nftCollectionAddress, tokenIdA, PIL_TYPE.NON_COMMERCIAL_REMIX, true, metadataURI, metadataHash, nftMetadataHash, "test") + registerIpAndAttachPilTerms("A", nftCollectionAddress, tokenIdA, PIL_TYPE.NON_COMMERCIAL_REMIX, "10", mockERC20Address, true, metadataURI, metadataHash, nftMetadataURI, nftMetadataHash, royaltyPolicyLAPAddress, "test") ).to.be.rejectedWith(`Failed to register IP and attach PIL terms: Invalid deadline value.`); }); // 0xb3e96921 - AccessController__PermissionDenied(address,address,address,bytes4) it("Non-owner register IP and attach PilTerms fail", async function () { await expect( - registerIpAndAttachPilTerms("B", nftCollectionAddress, tokenIdA, PIL_TYPE.NON_COMMERCIAL_REMIX, true, metadataURI, metadataHash, nftMetadataHash, 1000n, "100", 20, mintingFeeTokenAddress) + registerIpAndAttachPilTerms("B", nftCollectionAddress, tokenIdA, PIL_TYPE.NON_COMMERCIAL_REMIX, "10", mockERC20Address, true, metadataURI, metadataHash, nftMetadataURI, nftMetadataHash, royaltyPolicyLAPAddress, "100", 20) ).to.be.rejectedWith(`Failed to register IP and attach PIL terms: The contract function "registerIpAndAttachPILTerms" reverted with the following signature:`, `0xb3e96921`); }); - it("Register IP and attach COMMERCIAL_USE PilTerms fail as missing required parameters", async function () { - await expect( - registerIpAndAttachPilTerms("A", nftCollectionAddress, tokenIdA, PIL_TYPE.COMMERCIAL_USE, true) - ).to.be.rejectedWith(`Failed to register IP and attach PIL terms: mintingFee currency are required for commercial use PIL.`); - }); - it("Register IP and attach COMMERCIAL_REMIX PilTerms fail as missing required parameters", async function () { await expect( - registerIpAndAttachPilTerms("A", nftCollectionAddress, tokenIdA, PIL_TYPE.COMMERCIAL_REMIX, true) - ).to.be.rejectedWith(`Failed to register IP and attach PIL terms: mintingFee, currency and commercialRevShare are required for commercial remix PIL.`); + registerIpAndAttachPilTerms("A", nftCollectionAddress, tokenIdA, PIL_TYPE.COMMERCIAL_REMIX, "10", mockERC20Address, true) + ).to.be.rejectedWith(`Failed to register IP and attach PIL terms: DefaultMintingFee, currency and commercialRevShare are required for commercial remix PIL.`); }); it("Register IP and attach NON_COMMERCIAL_REMIX PilTerms", async function () { const response = await expect( - registerIpAndAttachPilTerms("A", nftCollectionAddress, tokenIdA, PIL_TYPE.NON_COMMERCIAL_REMIX, true) + registerIpAndAttachPilTerms("A", nftCollectionAddress, tokenIdA, PIL_TYPE.NON_COMMERCIAL_REMIX, "10", mockERC20Address, true) ).to.not.be.rejected; expect(response.txHash).to.be.a("string").and.not.empty; @@ -138,18 +133,16 @@ describe('SDK Test', function () { checkMintResult(tokenIdC); const response = await expect( - registerIpAndAttachPilTerms("A", nftCollectionAddress, tokenId, PIL_TYPE.NON_COMMERCIAL_REMIX, false, metadataURI, metadataHash, nftMetadataHash, 1000n, "100", 20, mintingFeeTokenAddress) + registerIpAndAttachPilTerms("A", nftCollectionAddress, tokenId, PIL_TYPE.NON_COMMERCIAL_REMIX, "10", mockERC20Address, false, metadataURI, metadataHash, nftMetadataURI, nftMetadataHash, royaltyPolicyLAPAddress, "100", 20) ).to.not.be.rejected; expect(response.txHash).to.be.a("string").and.not.empty; - expect(response.licenseTermsId).to.not.be.exist; - expect(response.ipId).to.not.be.exist; }); it("Register IP and attach COMMERCIAL_USE PilTerms", async function () { const deadline = await(getBlockTimestamp()) + 1000n; const response = await expect( - registerIpAndAttachPilTerms("A", nftCollectionAddress, tokenIdB, PIL_TYPE.COMMERCIAL_USE, true, metadataURI, metadataHash, nftMetadataHash, deadline, "100", undefined, mintingFeeTokenAddress) + registerIpAndAttachPilTerms("A", nftCollectionAddress, tokenIdB, PIL_TYPE.COMMERCIAL_USE, "10", mockERC20Address, true, metadataURI, metadataHash, nftMetadataURI, nftMetadataHash, royaltyPolicyLAPAddress, deadline, 20) ).to.not.be.rejected; expect(response.txHash).to.be.a("string").and.not.empty; @@ -162,7 +155,7 @@ describe('SDK Test', function () { checkMintResult(tokenIdC); const response = await expect( - registerIpAndAttachPilTerms("A", nftCollectionAddress, tokenId, PIL_TYPE.COMMERCIAL_USE, undefined, metadataURI, metadataHash, nftMetadataHash, 1000n, "100", 20, mintingFeeTokenAddress) + registerIpAndAttachPilTerms("A", nftCollectionAddress, tokenId, PIL_TYPE.COMMERCIAL_USE, "10", mockERC20Address, undefined, metadataURI, metadataHash, nftMetadataURI, nftMetadataHash, royaltyPolicyLAPAddress, "100", 20) ).to.not.be.rejected; expect(response.txHash).to.be.a("string").and.not.empty; @@ -173,7 +166,7 @@ describe('SDK Test', function () { it("Register IP and attach COMMERCIAL_REMIX PilTerms", async function () { const deadline = await(getBlockTimestamp()) + 1000n; const response = await expect( - registerIpAndAttachPilTerms("A", nftCollectionAddress, tokenIdC, PIL_TYPE.COMMERCIAL_REMIX, true, metadataURI, metadataHash, nftMetadataHash, deadline, "100", 20, mintingFeeTokenAddress) + registerIpAndAttachPilTerms("A", nftCollectionAddress, tokenIdC, PIL_TYPE.COMMERCIAL_REMIX, "10", mockERC20Address, true, metadataURI, metadataHash, nftMetadataURI, nftMetadataHash, royaltyPolicyLAPAddress, "100", 20) ).to.not.be.rejected; expect(response.txHash).to.be.a("string").and.not.empty; @@ -186,7 +179,7 @@ describe('SDK Test', function () { checkMintResult(tokenIdC); const response = await expect( - registerIpAndAttachPilTerms("A", nftCollectionAddress, tokenId, PIL_TYPE.COMMERCIAL_REMIX, true, metadataURI, metadataHash, nftMetadataHash, 1000n, "100", 20, mintingFeeTokenAddress) + registerIpAndAttachPilTerms("A", nftCollectionAddress, tokenId, PIL_TYPE.COMMERCIAL_REMIX, "10", mockERC20Address, true, metadataURI, metadataHash, nftMetadataURI, nftMetadataHash, royaltyPolicyLAPAddress, "100", 20) ).to.not.be.rejected; expect(response.txHash).to.be.a("string").and.not.empty; @@ -195,4 +188,3 @@ describe('SDK Test', function () { }); }); }); - diff --git a/test/license/attachLicenseTerms.test.ts b/test/license/attachLicenseTerms.test.ts index dc13e02..77561ce 100644 --- a/test/license/attachLicenseTerms.test.ts +++ b/test/license/attachLicenseTerms.test.ts @@ -1,5 +1,5 @@ import { privateKeyA, privateKeyB, privateKeyC, nftContractAddress } from '../../config/config'; -import { checkMintResult, mintNFTWithRetry } from '../../utils/utils'; +import { checkMintResult, mintNFT, mintNFTWithRetry } from '../../utils/utils'; import { Address } from 'viem'; import chai from 'chai'; import chaiAsPromised from 'chai-as-promised'; @@ -7,7 +7,7 @@ import { expect } from 'chai'; chai.use(chaiAsPromised); import '../setup'; import { registerIpAsset, attachLicenseTerms, registerDerivative } from '../../utils/sdkUtils'; -import { nonComLicenseTermsId, comUseLicenseTermsId1, comUseLicenseTermsId2, comRemixLicenseTermsId1 } from '../setup'; +import { comUseLicenseTermsId1, comUseLicenseTermsId2, comRemixLicenseTermsId1 } from '../setup'; let tokenIdA: string; let tokenIdB: string; @@ -19,9 +19,9 @@ let ipIdC: Address; const waitForTransaction: boolean = true; describe("SDK Test", function () { - describe("Register PIL", async function () { + describe("Attach license terms - license.attachLicenseTerms", async function () { before("Register license terms and IP assets", async function () { - tokenIdA = await mintNFTWithRetry(privateKeyA); + tokenIdA = await mintNFT(privateKeyA); checkMintResult(tokenIdA); const responseA = await expect( @@ -29,7 +29,7 @@ describe("SDK Test", function () { ).to.not.be.rejected; ipIdA = responseA.ipId; - tokenIdB = await mintNFTWithRetry(privateKeyB); + tokenIdB = await mintNFT(privateKeyB); checkMintResult(tokenIdB); const responseB = await expect( @@ -37,7 +37,7 @@ describe("SDK Test", function () { ).to.not.be.rejected; ipIdB = responseB.ipId; - tokenIdC = await mintNFTWithRetry(privateKeyA); + tokenIdC = await mintNFT(privateKeyA); checkMintResult(tokenIdC); const responseC = await expect( @@ -111,7 +111,10 @@ describe("SDK Test", function () { it("Attach license terms that is already attached to the IP Asset", async function () { const response = await expect( attachLicenseTerms("A", ipIdA, comUseLicenseTermsId1, true) - ).to.be.rejectedWith("Failed to attach license terms: License terms id " + comUseLicenseTermsId1 + " is already attached to the IP with id " + ipIdA); + ).to.not.be.rejected; + + expect(response.txHash).to.be.a("string").and.empty; + expect(response.success).to.be.equals(false); }); it("Attach license terms with waitForTransaction: false", async function () { @@ -125,13 +128,13 @@ describe("SDK Test", function () { describe("Attach license terms to parent/derivative IP assets", async function () { before("Register IP assets", async function () { - tokenIdA = await mintNFTWithRetry(privateKeyA); + tokenIdA = await mintNFT(privateKeyA); checkMintResult(tokenIdA); - tokenIdB = await mintNFTWithRetry(privateKeyB); + tokenIdB = await mintNFT(privateKeyB); checkMintResult(tokenIdB); - tokenIdC = await mintNFTWithRetry(privateKeyC); + tokenIdC = await mintNFT(privateKeyC); checkMintResult(tokenIdB); }) @@ -189,7 +192,7 @@ describe("SDK Test", function () { step("Parent IP asset can attach more license terms(non-commercial PIL)", async function () { const response = await expect( - attachLicenseTerms("A", ipIdA, nonComLicenseTermsId, waitForTransaction) + attachLicenseTerms("A", ipIdA, 0n, waitForTransaction) ).to.not.be.rejected; expect(response.txHash).to.be.a("string").and.not.empty; @@ -204,7 +207,13 @@ describe("SDK Test", function () { expect(response.ipId).to.be.a("string").and.not.empty; ipIdC = response.ipId; - }) + }); + + step("Derivative IP asset (ipIdB) can NOT attach more license terms", async function () { + const response = await expect( + attachLicenseTerms("B", ipIdB, comUseLicenseTermsId2, waitForTransaction) + ).to.be.rejectedWith("Failed to attach license terms: The contract function \"attachLicenseTerms\" reverted with the following signature:", "0x1ae3058f"); + }); step("Wallet C register a derivative IP asset with ipIdC and comUseLicenseTermsId1", async function () { const response = await expect( @@ -214,12 +223,6 @@ describe("SDK Test", function () { expect(response.txHash).to.be.a("string").and.not.empty; }); - step("Derivative IP asset (ipIdB) can NOT attach more license terms", async function () { - const response = await expect( - attachLicenseTerms("B", ipIdB, comUseLicenseTermsId2, waitForTransaction) - ).to.be.rejectedWith("Failed to attach license terms: The contract function \"attachLicenseTerms\" reverted with the following signature:", "0x1ae3058f"); - }); - step("Derivative IP asset (ipIdC) can NOT attach more license terms", async function () { const response = await expect( attachLicenseTerms("C", ipIdC, comRemixLicenseTermsId1, waitForTransaction) diff --git a/test/license/getLicenseTerms.test.ts b/test/license/getLicenseTerms.test.ts index 6738ec2..28d4e20 100644 --- a/test/license/getLicenseTerms.test.ts +++ b/test/license/getLicenseTerms.test.ts @@ -16,14 +16,22 @@ describe("SDK Test", function () { ).to.not.be.rejected; expect(response.terms.transferable).to.be.a("boolean").and.to.be.false; + expect(response.terms.royaltyPolicy).to.be.a("string").and.to.be.equal('0x0000000000000000000000000000000000000000'); + expect(response.terms.defaultMintingFee).to.be.a("bigint").and.to.be.equal(0n); + expect(response.terms.expiration).to.be.a("bigint").and.to.be.equal(0n); expect(response.terms.commercialUse).to.be.a("boolean").and.to.be.false; expect(response.terms.commercialAttribution).to.be.a("boolean").and.to.be.false; + expect(response.terms.commercializerChecker).to.be.a("string").and.to.be.equal('0x0000000000000000000000000000000000000000'); + expect(response.terms.commercializerCheckerData).to.be.a("string").and.to.be.equal('0x'); + expect(response.terms.commercialRevShare).to.be.a("number").and.to.be.equal(0); + expect(response.terms.commercialRevCeiling).to.be.a("bigint").and.to.be.equal(0n); expect(response.terms.derivativesAllowed).to.be.a("boolean").and.to.be.false; expect(response.terms.derivativesAttribution).to.be.a("boolean").and.to.be.false; expect(response.terms.derivativesApproval).to.be.a("boolean").and.to.be.false; expect(response.terms.derivativesReciprocal).to.be.a("boolean").and.to.be.false; - expect(response.terms.mintingFee).to.be.a("bigint").and.to.be.equal(0n); - expect(response.terms.expiration).to.be.a("bigint").and.to.be.equal(0n); + expect(response.terms.derivativeRevCeiling).to.be.a("bigint").and.to.be.equal(0n); + expect(response.terms.currency).to.be.a("string").and.to.be.equal('0x0000000000000000000000000000000000000000'); + expect(response.terms.uri).to.be.a("string").and.to.be.equal(''); }); it("licenseTermsId: null", async function () { @@ -32,14 +40,22 @@ describe("SDK Test", function () { ).to.not.be.rejected; expect(response.terms.transferable).to.be.a("boolean").and.to.be.false; + expect(response.terms.royaltyPolicy).to.be.a("string").and.to.be.equal('0x0000000000000000000000000000000000000000'); + expect(response.terms.defaultMintingFee).to.be.a("bigint").and.to.be.equal(0n); + expect(response.terms.expiration).to.be.a("bigint").and.to.be.equal(0n); expect(response.terms.commercialUse).to.be.a("boolean").and.to.be.false; expect(response.terms.commercialAttribution).to.be.a("boolean").and.to.be.false; + expect(response.terms.commercializerChecker).to.be.a("string").and.to.be.equal('0x0000000000000000000000000000000000000000'); + expect(response.terms.commercializerCheckerData).to.be.a("string").and.to.be.equal('0x'); + expect(response.terms.commercialRevShare).to.be.a("number").and.to.be.equal(0); + expect(response.terms.commercialRevCeiling).to.be.a("bigint").and.to.be.equal(0n); expect(response.terms.derivativesAllowed).to.be.a("boolean").and.to.be.false; expect(response.terms.derivativesAttribution).to.be.a("boolean").and.to.be.false; expect(response.terms.derivativesApproval).to.be.a("boolean").and.to.be.false; expect(response.terms.derivativesReciprocal).to.be.a("boolean").and.to.be.false; - expect(response.terms.mintingFee).to.be.a("bigint").and.to.be.equal(0n); - expect(response.terms.expiration).to.be.a("bigint").and.to.be.equal(0n); + expect(response.terms.derivativeRevCeiling).to.be.a("bigint").and.to.be.equal(0n); + expect(response.terms.currency).to.be.a("string").and.to.be.equal('0x0000000000000000000000000000000000000000'); + expect(response.terms.uri).to.be.a("string").and.to.be.equal(''); }); it("Non Commercial License Terms", async function () { @@ -48,14 +64,22 @@ describe("SDK Test", function () { ).to.not.be.rejected; expect(response.terms.transferable).to.be.a("boolean").and.to.be.true; + expect(response.terms.royaltyPolicy).to.be.a("string").and.to.be.equal('0x0000000000000000000000000000000000000000'); + expect(response.terms.defaultMintingFee).to.be.a("bigint").and.to.be.equal(0n); + expect(response.terms.expiration).to.be.a("bigint").and.to.be.equal(0n); expect(response.terms.commercialUse).to.be.a("boolean").and.to.be.false; expect(response.terms.commercialAttribution).to.be.a("boolean").and.to.be.false; + expect(response.terms.commercializerChecker).to.be.a("string").and.to.be.equal('0x0000000000000000000000000000000000000000'); + expect(response.terms.commercializerCheckerData).to.be.a("string").and.to.be.equal('0x'); + expect(response.terms.commercialRevShare).to.be.a("number").and.to.be.equal(0); + expect(response.terms.commercialRevCeiling).to.be.a("bigint").and.to.be.equal(0n); expect(response.terms.derivativesAllowed).to.be.a("boolean").and.to.be.true; expect(response.terms.derivativesAttribution).to.be.a("boolean").and.to.be.true; expect(response.terms.derivativesApproval).to.be.a("boolean").and.to.be.false; expect(response.terms.derivativesReciprocal).to.be.a("boolean").and.to.be.true; - expect(response.terms.mintingFee).to.be.a("bigint").and.to.be.equal(0n); - expect(response.terms.expiration).to.be.a("bigint").and.to.be.equal(0n); + expect(response.terms.derivativeRevCeiling).to.be.a("bigint").and.to.be.equal(0n); + expect(response.terms.currency).to.be.a("string").and.to.be.equal('0x0000000000000000000000000000000000000000'); + expect(response.terms.uri).to.be.a("string").and.to.be.equal(''); }); it("Commercial Use License Terms", async function () { @@ -64,15 +88,22 @@ describe("SDK Test", function () { ).to.not.be.rejected; expect(response.terms.transferable).to.be.a("boolean").and.to.be.true; - expect(response.terms.royaltyPolicy).to.be.a("string").and.to.be.equal(royaltyPolicyLAPAddress); + expect(response.terms.royaltyPolicy).to.be.a("string").and.to.be.equal('0x28b4F70ffE5ba7A26aEF979226f77Eb57fb9Fdb6'); + expect(response.terms.defaultMintingFee).to.be.a("bigint").and.to.be.equal(100n); + expect(response.terms.expiration).to.be.a("bigint").and.to.be.equal(0n); expect(response.terms.commercialUse).to.be.a("boolean").and.to.be.true; expect(response.terms.commercialAttribution).to.be.a("boolean").and.to.be.true; + expect(response.terms.commercializerChecker).to.be.a("string").and.to.be.equal('0x0000000000000000000000000000000000000000'); + expect(response.terms.commercializerCheckerData).to.be.a("string").and.to.be.equal('0x0000000000000000000000000000000000000000'); + expect(response.terms.commercialRevShare).to.be.a("number").and.to.be.equal(0); + expect(response.terms.commercialRevCeiling).to.be.a("bigint").and.to.be.equal(0n); expect(response.terms.derivativesAllowed).to.be.a("boolean").and.to.be.true; expect(response.terms.derivativesAttribution).to.be.a("boolean").and.to.be.true; expect(response.terms.derivativesApproval).to.be.a("boolean").and.to.be.false; expect(response.terms.derivativesReciprocal).to.be.a("boolean").and.to.be.false; - expect(response.terms.mintingFee).to.be.a("bigint").and.to.be.equal(BigInt(mintingFee1)); - expect(response.terms.expiration).to.be.a("bigint").and.to.be.equal(0n); + expect(response.terms.derivativeRevCeiling).to.be.a("bigint").and.to.be.equal(0n); + expect(response.terms.currency).to.be.a("string").and.to.be.equal('0x12A8b0DcC6e3bB0915638361D9D49942Da07F455'); + expect(response.terms.uri).to.be.a("string").and.to.be.equal(''); }); it("Commercial Remix License Terms", async function () { @@ -81,16 +112,22 @@ describe("SDK Test", function () { ).to.not.be.rejected; expect(response.terms.transferable).to.be.a("boolean").and.to.be.true; - expect(response.terms.royaltyPolicy).to.be.a("string").and.to.be.equal(royaltyPolicyLAPAddress); + expect(response.terms.royaltyPolicy).to.be.a("string").and.to.be.equal('0x28b4F70ffE5ba7A26aEF979226f77Eb57fb9Fdb6'); + expect(response.terms.defaultMintingFee).to.be.a("bigint").and.to.be.equal(100n); + expect(response.terms.expiration).to.be.a("bigint").and.to.be.equal(0n); expect(response.terms.commercialUse).to.be.a("boolean").and.to.be.true; expect(response.terms.commercialAttribution).to.be.a("boolean").and.to.be.true; + expect(response.terms.commercializerChecker).to.be.a("string").and.to.be.equal('0x0000000000000000000000000000000000000000'); + expect(response.terms.commercializerCheckerData).to.be.a("string").and.to.be.equal('0x0000000000000000000000000000000000000000'); + expect(response.terms.commercialRevShare).to.be.a("number").and.to.be.equal(10000000); + expect(response.terms.commercialRevCeiling).to.be.a("bigint").and.to.be.equal(0n); expect(response.terms.derivativesAllowed).to.be.a("boolean").and.to.be.true; expect(response.terms.derivativesAttribution).to.be.a("boolean").and.to.be.true; expect(response.terms.derivativesApproval).to.be.a("boolean").and.to.be.false; expect(response.terms.derivativesReciprocal).to.be.a("boolean").and.to.be.true; - expect(response.terms.mintingFee).to.be.a("bigint").and.to.be.equal(BigInt(mintingFee1)); - expect(response.terms.commercialRevShare).to.be.a("number").and.to.be.equal(commercialRevShare1 * 1000000); - expect(response.terms.expiration).to.be.a("bigint").and.to.be.equal(0n); + expect(response.terms.derivativeRevCeiling).to.be.a("bigint").and.to.be.equal(0n); + expect(response.terms.currency).to.be.a("string").and.to.be.equal('0x12A8b0DcC6e3bB0915638361D9D49942Da07F455'); + expect(response.terms.uri).to.be.a("string").and.to.be.equal(''); }); }); diff --git a/test/license/mintLicenseTokens.test.ts b/test/license/mintLicenseTokens.test.ts index 1bdb2ff..9387811 100644 --- a/test/license/mintLicenseTokens.test.ts +++ b/test/license/mintLicenseTokens.test.ts @@ -1,6 +1,6 @@ import { privateKeyA, accountB, nftContractAddress } from '../../config/config'; import { attachLicenseTerms, mintLicenseTokens, registerIpAsset } from '../../utils/sdkUtils'; -import { checkMintResult, mintNFTWithRetry } from '../../utils/utils'; +import { checkMintResult, mintNFT, mintNFTWithRetry } from '../../utils/utils'; import { expect } from 'chai'; import chai from 'chai'; import chaiAsPromised from 'chai-as-promised'; @@ -19,10 +19,10 @@ const waitForTransaction: boolean = true; describe('SDK Test', function () { describe('Test license.mintLicenseTokens Function', async function () { before("Register license terms and IP assets",async function () { - tokenIdA = await mintNFTWithRetry(privateKeyA); + tokenIdA = await mintNFT(privateKeyA); checkMintResult(tokenIdA); - tokenIdB = await mintNFTWithRetry(privateKeyA); + tokenIdB = await mintNFT(privateKeyA); checkMintResult(tokenIdB); const responseA = await expect( @@ -34,12 +34,6 @@ describe('SDK Test', function () { ipIdA = responseA.ipId; - const response = await expect( - attachLicenseTerms("A", ipIdA, nonComLicenseTermsId, waitForTransaction) - ).to.not.be.rejected; - - expect(response.txHash).to.be.a("string").and.not.empty; - const responseB = await expect( registerIpAsset("A", nftContractAddress, tokenIdB, waitForTransaction) ).to.not.be.rejected; @@ -104,8 +98,8 @@ describe('SDK Test', function () { it("Mint a license token fail as not attached licenseTermsId", async function () { const response = await expect( - mintLicenseTokens("A", ipIdB, nonComLicenseTermsId, 2, "0x485FCfC79Ce0A082Ab2a5e729D6e6255A540342a", true) - ).to.be.rejectedWith("Failed to mint license tokens: License terms id " + nonComLicenseTermsId + " is not attached to the IP with id " + ipIdB); + mintLicenseTokens("A", ipIdB, 0n, 2, "0x485FCfC79Ce0A082Ab2a5e729D6e6255A540342a", true) + ).to.be.rejectedWith("Failed to mint license tokens: License terms id 0 is not attached to the IP with id " + ipIdB); }); }); @@ -179,23 +173,17 @@ describe('SDK Test', function () { describe("Mint License Tokens - IP asset attached multiple license terms", async function () { before("Register 2 license terms and 2 IP assets", async function () { const responseAttachLicenseTerms1 = await expect( - attachLicenseTerms("A", ipIdB, nonComLicenseTermsId, waitForTransaction) + attachLicenseTerms("A", ipIdB, comUseLicenseTermsId1, waitForTransaction) ).to.not.be.rejected; expect(responseAttachLicenseTerms1.txHash).to.be.a("string").and.not.empty; const responseAttachLicenseTerms2 = await expect( - attachLicenseTerms("A", ipIdB, comUseLicenseTermsId1, waitForTransaction) - ).to.not.be.rejected; - - expect(responseAttachLicenseTerms2.txHash).to.be.a("string").and.not.empty; - - const responseAttachLicenseTerms3 = await expect( attachLicenseTerms("A", ipIdB, comRemixLicenseTermsId1, waitForTransaction) ).to.not.be.rejected; - expect(responseAttachLicenseTerms3.txHash).to.be.a("string").and.not.empty; - }) + expect(responseAttachLicenseTerms2.txHash).to.be.a("string").and.not.empty; + }); it("Mint a license token with ipIdB and nonComLicenseTermsId", async function () { const response = await expect( diff --git a/test/license/registerPIL.test.ts b/test/license/registerPIL.test.ts index 9a36b1a..fb24ab2 100644 --- a/test/license/registerPIL.test.ts +++ b/test/license/registerPIL.test.ts @@ -1,4 +1,4 @@ -import { mintingFeeTokenAddress } from '../../config/config'; +import { mockERC20Address } from '../../config/config'; import chai from 'chai'; import chaiAsPromised from 'chai-as-promised'; import { expect } from 'chai'; @@ -36,19 +36,19 @@ describe("SDK Test", function () { it("Register Commercial Use PIL with mintingFee: undefined", async function () { let mintingFee: any; const response = await expect( - registerCommercialUsePIL("A", mintingFee, mintingFeeTokenAddress, true) - ).to.be.rejectedWith("Failed to register commercial use PIL: mintingFee currency are required for commercial use PIL."); + registerCommercialUsePIL("A", mintingFee, mockERC20Address, true) + ).to.be.rejectedWith(`Failed to register commercial use PIL: DefaultMintingFee, currency are required for commercial use PIL.`); }); it("Register Commercial Use PIL with an invalid mintingFee value (test)", async function () { const response = await expect( - registerCommercialUsePIL("A", "test", mintingFeeTokenAddress, true) + registerCommercialUsePIL("A", "test", mockERC20Address, true) ).to.be.rejectedWith("Failed to register commercial use PIL: Cannot convert test to a BigInt"); }); it("Register Commercial Use PIL with an invalid mintingFee value (-1)", async function () { const response = await expect( - registerCommercialUsePIL("A", "-1", mintingFeeTokenAddress, true) + registerCommercialUsePIL("A", "-1", mockERC20Address, true) ).to.be.rejectedWith("Failed to register commercial use PIL: Number \"-1n\" is not in safe 256-bit unsigned integer range"); }); @@ -56,7 +56,7 @@ describe("SDK Test", function () { let currency: any; const response = await expect( registerCommercialUsePIL("A", "0", currency, true) - ).to.be.rejectedWith("Failed to register commercial use PIL: mintingFee currency are required for commercial use PIL."); + ).to.be.rejectedWith("Failed to register commercial use PIL: DefaultMintingFee, currency are required for commercial use PIL."); }); it("Register Commercial Use PIL with an invalid currency address", async function () { @@ -68,21 +68,21 @@ describe("SDK Test", function () { it("Register Commercial Use PIL with waitForTransaction: undefined", async function () { let waitForTransaction: any; const response = await expect( - registerCommercialUsePIL("A", "0", mintingFeeTokenAddress, waitForTransaction) + registerCommercialUsePIL("A", "0", mockERC20Address, waitForTransaction) ).to.not.be.rejected; expect(response.licenseTermsId).to.be.a("bigint").and.to.be.ok; }); it("Register Commercial Use PIL with waitForTransaction: true", async function () { const response = await expect( - registerCommercialUsePIL("A", "0", mintingFeeTokenAddress, true) + registerCommercialUsePIL("A", "0", mockERC20Address, true) ).to.not.be.rejected; expect(response.licenseTermsId).to.be.a("bigint").and.to.be.ok; }); it("Register Commercial Use PIL with waitForTransaction: false", async function () { const response = await expect( - registerCommercialUsePIL("A", "16", mintingFeeTokenAddress, false) + registerCommercialUsePIL("A", "16", mockERC20Address, false) ).to.not.be.rejected; if (response.licenseTermsId) { @@ -98,46 +98,46 @@ describe("SDK Test", function () { it("Register Commercial Remix PIL with mintingFee: undefined", async function () { let mintingFee: any; const response = await expect( - registerCommercialRemixPIL("A", mintingFee, 100, mintingFeeTokenAddress, true) - ).to.be.rejectedWith("Failed to register commercial remix PIL: mintingFee, currency and commercialRevShare are required for commercial remix PIL."); + registerCommercialRemixPIL("A", mintingFee, 100, mockERC20Address, true) + ).to.be.rejectedWith("Failed to register commercial remix PIL: DefaultMintingFee, currency and commercialRevShare are required for commercial remix PIL."); }); it("Register Commercial Remix PIL with an invalid mintingFee value (test)", async function () { const response = await expect( - registerCommercialRemixPIL("A", "test", 100, mintingFeeTokenAddress, true) + registerCommercialRemixPIL("A", "test", 100, mockERC20Address, true) ).to.be.rejectedWith("Failed to register commercial remix PIL: Cannot convert test to a BigInt"); }); it("Register Commercial Remix PIL with an invalid mintingFee value (-1)", async function () { const response = await expect( - registerCommercialRemixPIL("A", "-1", 100, mintingFeeTokenAddress, true) + registerCommercialRemixPIL("A", "-1", 100, mockERC20Address, true) ).to.be.rejectedWith("Failed to register commercial remix PIL: Number \"-1n\" is not in safe 256-bit unsigned integer range"); }); it("Register Commercial Remix PIL with commercialRevShare: undefined", async function () { let commercialRevShare: any; const response = await expect( - registerCommercialRemixPIL("A", "0", commercialRevShare, mintingFeeTokenAddress, true) - ).to.be.rejectedWith("Failed to register commercial remix PIL: mintingFee, currency and commercialRevShare are required for commercial remix PIL."); + registerCommercialRemixPIL("A", "0", commercialRevShare, mockERC20Address, true) + ).to.be.rejectedWith("Failed to register commercial remix PIL: DefaultMintingFee, currency and commercialRevShare are required for commercial remix PIL."); }); it("Register Commercial Remix PIL with an invalid commercialRevShare value (-1)", async function () { const response = await expect( - registerCommercialRemixPIL("A", "0", -1, mintingFeeTokenAddress, true) - ).to.be.rejectedWith("Failed to register commercial remix PIL: commercialRevShare should be between 0 and 100."); + registerCommercialRemixPIL("A", "0", -1, mockERC20Address, true) + ).to.be.rejectedWith("Failed to register commercial remix PIL: CommercialRevShare should be between 0 and 100."); }); it("Register Commercial Remix PIL with an invalid commercialRevShare value (101)", async function () { const response = await expect( - registerCommercialRemixPIL("A", "0", 101, mintingFeeTokenAddress, true) - ).to.be.rejectedWith("Failed to register commercial remix PIL: commercialRevShare should be between 0 and 100."); + registerCommercialRemixPIL("A", "0", 101, mockERC20Address, true) + ).to.be.rejectedWith("Failed to register commercial remix PIL: CommercialRevShare should be between 0 and 100."); }); it("Register Commercial Remix PIL with currency: undefined", async function () { let currency: any; const response = await expect( registerCommercialRemixPIL("A", "0", 0, currency, true) - ).to.be.rejectedWith("Failed to register commercial remix PIL: mintingFee, currency and commercialRevShare are required for commercial remix PIL."); + ).to.be.rejectedWith("Failed to register commercial remix PIL: DefaultMintingFee, currency and commercialRevShare are required for commercial remix PIL."); }); it("Register Commercial Remix PIL with an invalid currency address", async function () { @@ -149,7 +149,7 @@ describe("SDK Test", function () { it("Register Commercial Remix PIL with waitForTransaction: undefined", async function () { let waitForTransaction: any; const response = await expect( - registerCommercialRemixPIL("A", "0", 0, mintingFeeTokenAddress, waitForTransaction) + registerCommercialRemixPIL("A", "0", 0, mockERC20Address, waitForTransaction) ).to.not.be.rejected; if (response.licenseTermsId) { @@ -162,14 +162,14 @@ describe("SDK Test", function () { it("Register Commercial Remix PIL with waitForTransaction: true", async function () { const response = await expect( - registerCommercialRemixPIL("A", "0", 100, mintingFeeTokenAddress, true) + registerCommercialRemixPIL("A", "0", 100, mockERC20Address, true) ).to.not.be.rejected; expect(response.licenseTermsId).to.be.a("bigint").and.to.be.ok; }); it("Register Commercial Remix PIL with waitForTransaction: false", async function () { const response = await expect( - registerCommercialRemixPIL("A", "16", 100, mintingFeeTokenAddress, false) + registerCommercialRemixPIL("A", "16", 100, mockERC20Address, false) ).to.not.be.rejected; if (response.licenseTermsId) { @@ -181,4 +181,4 @@ describe("SDK Test", function () { }); }) }); -}); \ No newline at end of file +}); diff --git a/test/nftClient/createNFTCollection.test.ts b/test/nftClient/createNFTCollection.test.ts index e1ea9af..6dfda0f 100644 --- a/test/nftClient/createNFTCollection.test.ts +++ b/test/nftClient/createNFTCollection.test.ts @@ -4,155 +4,96 @@ import { expect } from 'chai'; chai.use(chaiAsPromised); import '../setup'; import { createNFTCollection } from '../../utils/sdkUtils'; -import { accountA, mintingFeeTokenAddress } from '../../config/config'; +import { accountA, mockERC20Address } from '../../config/config'; +import { Address } from 'viem'; describe("SDK Test", function () { describe("Create NFT Collection - nftClient.createNFTCollection", async function () { it("Create NFT collection", async function () { const response = await expect( - createNFTCollection("A", "sdk-e2e-test", "test", true) + createNFTCollection("A", "sdk-e2e-test", "test", true, true, accountA.address, "contract-uri", true) ).to.not.be.rejected; expect(response.txHash).to.be.a("string").and.not.empty; - expect(response.nftContract).to.be.a("string").and.not.empty; + expect(response.spgNftContract).to.be.a("string").and.not.empty; }); it("Create NFT collection with empyt name and symbol", async function () { const response = await expect( - createNFTCollection("A", "", "", true) + createNFTCollection("A", "", "", true, true, accountA.address, "contract-uri", true) ).to.not.be.rejected; expect(response.txHash).to.be.a("string").and.not.empty; - expect(response.nftContract).to.be.a("string").and.not.empty; + expect(response.spgNftContract).to.be.a("string").and.not.empty; }); it("Create NFT collection with waitForTransaction: undefined", async function () { let waitForTransaction: any; const response = await expect( - createNFTCollection("A", "sdk-e2e-test", "test", waitForTransaction) + createNFTCollection("A", "sdk-e2e-test", "test", true, true, accountA.address, "contract-uri", waitForTransaction) ).to.not.be.rejected; expect(response.txHash).to.be.a("string").and.not.empty; - expect(response.nftContract).to.not.be.exist; + expect(response.spgNftContract).to.not.be.exist; }); it("Create NFT collection with waitForTransaction: false", async function () { const response = await expect( - createNFTCollection("A", "sdk-e2e-test", "test", false) + createNFTCollection("A", "sdk-e2e-test", "test", true, true, accountA.address, "contract-uri", false) ).to.not.be.rejected; expect(response.txHash).to.be.a("string").and.not.empty; - expect(response.nftContract).to.not.be.exist; + expect(response.spgNftContract).to.not.be.exist; }); it("Create NFT collection with optional parameters", async function () { const options = { + baseURI: "base-uri", maxSupply: 100n, - mintCost: 1, - mintToken: mintingFeeTokenAddress, - owner: accountA.address + mintFee: 1, + mintToken: mockERC20Address, + owner: accountA.address as Address }; const response = await expect( - createNFTCollection("A", "sdk-e2e-test", "test", true, options) + createNFTCollection("A", "sdk-e2e-test", "test", true, true, accountA.address, "contract-uri", true, "base-uri", 100, 1n, mockERC20Address, accountA.address) ).to.not.be.rejected; expect(response.txHash).to.be.a("string").and.not.empty; - expect(response.nftContract).to.be.a("string").and.not.empty; - }); - - it.skip("Create NFT collection with mintCost and invalid mintToken", async function () { - let mintToken: any; - const options = { - maxSupply: 10n, - mintCost: 1, - mintToken: mintToken, - owner: accountA.address - }; - - const response = await expect( - createNFTCollection("A", "sdk-e2e-test", "test", true, options) - ).to.be.rejectedWith("Failed to create a SPG NFT collection: Invalid mint token address, mint cost is greater than 0."); - }); + expect(response.spgNftContract).to.be.a("string").and.not.empty; + }); it("Create NFT collection with multi undefined parameters", async function () { let maxSupply: any; - let mintCost: any; + let mintFee: any; let mintToken: any; let owner: any; - const options = { - maxSupply: maxSupply, - mintCost: mintCost, - mintToken: mintToken, - owner: owner - }; - const response = await expect( - createNFTCollection("A", "sdk-e2e-test", "test", true, options) + createNFTCollection("A", "sdk-e2e-test", "test", true, true, accountA.address, "contract-uri", true, "base-uri", maxSupply, mintFee, mintToken, owner) ).to.not.be.rejected; expect(response.txHash).to.be.a("string").and.not.empty; - expect(response.nftContract).to.be.a("string").and.not.empty; + expect(response.spgNftContract).to.be.a("string").and.not.empty; }); it("Create NFT collection with invalid type for maxSupply", async function () { - const options = { - maxSupply: "test" - }; - - const response = await expect( - createNFTCollection("A", "sdk-e2e-test", "test", true, options) - ).to.be.rejectedWith("Failed to create a SPG NFT collection: Cannot convert test to a BigInt"); - }); - - it.skip("Create NFT collection with invalid type for mintCost", async function () { - const options = { - mintCost: "test" - }; - + const maxSupply: any = "test"; const response = await expect( - createNFTCollection("A", "sdk-e2e-test", "test", true, options) + createNFTCollection("A", "sdk-e2e-test", "test", true, true, accountA.address, "contract-uri", true, "base-uri", maxSupply) ).to.be.rejectedWith("Failed to create a SPG NFT collection: Cannot convert test to a BigInt"); - }); - - it.skip("Create NFT collection with invalid type for mintToken", async function () { - const options = { - mintToken: "test" - }; - - const response = await expect( - createNFTCollection("A", "sdk-e2e-test", "test", true, options) - ).to.be.rejectedWith("Failed to create a SPG NFT collection: Address \"test\" is invalid."); - }); - - it.skip("Create NFT collection with mintToken: 0x0000", async function () { - const options = { - mintToken: "0x0000" - }; - - const response = await expect( - createNFTCollection("A", "sdk-e2e-test", "test", true, options) - ).to.be.rejectedWith("Failed to create a SPG NFT collection: Address \"0x0000\" is invalid."); - }); + }); it("Create NFT collection with invalid type for owner", async function () { - const options = { - owner: "test" - }; - + const owner = "0x0000"; const response = await expect( - createNFTCollection("A", "sdk-e2e-test", "test", true, options) - ).to.be.rejectedWith(`Failed to create a SPG NFT collection: request.owner address is invalid: test, Address must be a hex value of 20 bytes (40 hex characters) and match its checksum counterpart.`); + createNFTCollection("A", "sdk-e2e-test", "test", true, true, accountA.address, "contract-uri", true, "", undefined, undefined, undefined, owner) + ).to.be.rejectedWith(`Failed to create a SPG NFT collection: request.owner address is invalid: 0x0000, Address must be a hex value of 20 bytes (40 hex characters) and match its checksum counterpart.`); }); it("Create NFT collection with owner: 0x0000", async function () { - const options = { - owner: "0x0000" - }; - const response = await expect( - createNFTCollection("A", "sdk-e2e-test", "test", true, options) + createNFTCollection("A", "sdk-e2e-test", "test", true, true, accountA.address, "contract-uri", true, "", undefined, undefined, undefined, "0x0000") ).to.be.rejectedWith(`Failed to create a SPG NFT collection: request.owner address is invalid: 0x0000, Address must be a hex value of 20 bytes (40 hex characters) and match its checksum counterpart.`); }); }); diff --git a/test/permission/permission.test.ts b/test/permission/permission.test.ts index 4bd5dec..77a030a 100644 --- a/test/permission/permission.test.ts +++ b/test/permission/permission.test.ts @@ -1,6 +1,6 @@ import { nftContractAddress, privateKeyA, accountB, licensingModuleAddress } from '../../config/config'; import { registerIpAsset, setPermission } from '../../utils/sdkUtils'; -import { checkMintResult, mintNFTWithRetry } from '../../utils/utils'; +import { checkMintResult, mintNFT } from '../../utils/utils'; import { expect } from 'chai'; import { Address } from 'viem'; import chai from 'chai'; @@ -12,9 +12,9 @@ let tokenIdA: string; let ipIdA: Address; describe('SDK Test', function () { - describe('Test ipAsset.register Function', async function () { + describe('Test permission.setPermission Function', async function () { before("Mint NFT and Register IP Asset",async function () { - tokenIdA = await mintNFTWithRetry(privateKeyA); + tokenIdA = await mintNFT(privateKeyA); checkMintResult(tokenIdA); const response = await expect( diff --git a/test/royalty/payRoyaltyOnBehalf.test.ts b/test/royalty/payRoyaltyOnBehalf.test.ts index 66d379a..a07f9a5 100644 --- a/test/royalty/payRoyaltyOnBehalf.test.ts +++ b/test/royalty/payRoyaltyOnBehalf.test.ts @@ -1,5 +1,5 @@ import { privateKeyA, privateKeyB, privateKeyC, nftContractAddress, mintingFeeTokenAddress } from '../../config/config'; -import { mintNFTWithRetry, checkMintResult, sleep } from '../../utils/utils'; +import { mintNFTWithRetry, checkMintResult } from '../../utils/utils'; import { registerIpAsset, payRoyaltyOnBehalf, attachLicenseTerms, registerDerivative } from '../../utils/sdkUtils'; import { Address } from 'viem'; import chai from 'chai'; diff --git a/test/setup.ts b/test/setup.ts index 4e33975..71c4eed 100644 --- a/test/setup.ts +++ b/test/setup.ts @@ -1,6 +1,6 @@ import addContext = require("mochawesome/addContext"); import { captureConsoleLogs } from "../utils/utils"; -import { mintingFeeTokenAddress } from '../config/config'; +import { mockERC20Address } from '../config/config'; import { registerNonComSocialRemixingPIL, registerCommercialUsePIL, registerCommercialRemixPIL } from '../utils/sdkUtils'; import { expect } from 'chai'; @@ -42,14 +42,14 @@ before("Register License Terms", async function () { it("Register Commercial Use License Terms", async function () { const responseComUseLicenseTerms1 = await expect( - registerCommercialUsePIL("A", mintingFee1, mintingFeeTokenAddress, true) + registerCommercialUsePIL("A", mintingFee1, mockERC20Address, true) ).to.not.be.rejected; expect(responseComUseLicenseTerms1.licenseTermsId).to.be.a("bigint").and.to.be.ok; comUseLicenseTermsId1 = responseComUseLicenseTerms1.licenseTermsId; const responseComUseLicenseTerms2 = await expect( - registerCommercialUsePIL("A", mintingFee2, mintingFeeTokenAddress, true) + registerCommercialUsePIL("A", mintingFee2, mockERC20Address, true) ).to.not.be.rejected; expect(responseComUseLicenseTerms1.licenseTermsId).to.be.a("bigint").and.to.be.ok; @@ -58,14 +58,14 @@ before("Register License Terms", async function () { it("Register Commercial Remix License Terms", async function () { const responseComRemixLicenseTerms1 = await expect( - registerCommercialRemixPIL("A", mintingFee1, commercialRevShare1, mintingFeeTokenAddress, true) + registerCommercialRemixPIL("A", mintingFee1, commercialRevShare1, mockERC20Address, true) ).to.not.be.rejected; expect(responseComRemixLicenseTerms1.licenseTermsId).to.be.a("bigint").and.to.be.ok; comRemixLicenseTermsId1 = responseComRemixLicenseTerms1.licenseTermsId; const responseComRemixLicenseTerms2 = await expect( - registerCommercialRemixPIL("A", mintingFee2, commercialRevShare2, mintingFeeTokenAddress, true) + registerCommercialRemixPIL("A", mintingFee2, commercialRevShare2, mockERC20Address, true) ).to.not.be.rejected; expect(responseComRemixLicenseTerms1.licenseTermsId).to.be.a("bigint").and.to.be.ok; diff --git a/test/testUtils.ts b/test/testUtils.ts index c0d3a9c..8ec2460 100644 --- a/test/testUtils.ts +++ b/test/testUtils.ts @@ -1,7 +1,7 @@ -import { nftContractAddress, mintingFeeTokenAddress} from '../config/config' -import { checkMintResult, mintNFTWithRetry } from '../utils/utils' -import { registerIpAsset, attachLicenseTerms, registerDerivative, royaltySnapshot, collectRoyaltyTokens, royaltyClaimableRevenue, royaltyClaimRevenue, getRoyaltyVaultAddress, ipAccountExecute, storyClients, ipAccountExecuteWithSig } from '../utils/sdkUtils' -import { expect } from 'chai' +import { nftContractAddress } from '../config/config'; +import { checkMintResult, mintNFTWithRetry } from '../utils/utils'; +import { registerIpAsset, attachLicenseTerms, registerDerivative, royaltySnapshot, royaltyClaimableRevenue, royaltyClaimRevenue, getRoyaltyVaultAddress, ipAccountExecute, storyClients, ipAccountExecuteWithSig } from '../utils/sdkUtils'; +import { expect } from 'chai'; import chai from 'chai'; import chaiAsPromised from 'chai-as-promised'; @@ -63,19 +63,19 @@ export const mintNFTAndRegisterDerivative = async function( return ipId; }; -export const checkRoyaltyTokensCollected = async function( - caller: keyof typeof storyClients, - parentIpId: Address, - royaltyVaultIpId: Address, - expectedRoyaltyTokensCollected: bigint -){ - const responseAFromB = await expect( - collectRoyaltyTokens(caller, parentIpId, royaltyVaultIpId, waitForTransaction) - ).to.not.be.rejected; +// export const checkRoyaltyTokensCollected = async function( +// caller: keyof typeof storyClients, +// parentIpId: Address, +// royaltyVaultIpId: Address, +// expectedRoyaltyTokensCollected: bigint +// ){ +// const responseAFromB = await expect( +// collectRoyaltyTokens(caller, parentIpId, royaltyVaultIpId, waitForTransaction) +// ).to.not.be.rejected; - expect(responseAFromB.txHash).to.be.a("string").and.not.empty; - expect(responseAFromB.royaltyTokensCollected).to.be.a('bigint').and.to.be.equal(expectedRoyaltyTokensCollected); -}; +// expect(responseAFromB.txHash).to.be.a("string").and.not.empty; +// expect(responseAFromB.royaltyTokensCollected).to.be.a('bigint').and.to.be.equal(expectedRoyaltyTokensCollected); +// }; export const getSnapshotId = async function( caller: keyof typeof storyClients, @@ -92,48 +92,48 @@ export const getSnapshotId = async function( return snapshotId; }; -export const checkClaimableRevenue = async function( - caller: keyof typeof storyClients, - royaltyVaultIpId: Address, - account: Address, - snapshotId: bigint, - expectedClaimableRevenue: bigint -){ - const response = await expect( - royaltyClaimableRevenue(caller, royaltyVaultIpId, account, snapshotId, mintingFeeTokenAddress, waitForTransaction) - ).to.not.be.rejected; +// export const checkClaimableRevenue = async function( +// caller: keyof typeof storyClients, +// royaltyVaultIpId: Address, +// account: Address, +// snapshotId: bigint, +// expectedClaimableRevenue: bigint +// ){ +// const response = await expect( +// royaltyClaimableRevenue(caller, royaltyVaultIpId, account, snapshotId, mintingFeeTokenAddress, waitForTransaction) +// ).to.not.be.rejected; - // expect(response).to.be.a("bigint").and.to.be.equal(expectedClaimableRevenue); -}; - -export const claimRevenueByEOA = async function ( - caller: keyof typeof storyClients, - snapshotIds: bigint[], - royaltyVaultIpId: Address, - expectedClaimableToken: bigint -) { - const response = await expect( - royaltyClaimRevenue(caller, snapshotIds, royaltyVaultIpId, mintingFeeTokenAddress, undefined, waitForTransaction) - ).to.not.be.rejected; - - expect(response.txHash).to.be.a("string").and.not.empty; - // expect(response.claimableToken).to.be.a("bigint").to.be.equal(expectedClaimableToken); -}; - -export const claimRevenueByIPA = async function ( - caller: keyof typeof storyClients, - snapshotIds: bigint[], - royaltyVaultIpId: Address, - ipAccount: Address, - expectedClaimableToken: bigint -) { - const response = await expect( - royaltyClaimRevenue(caller, snapshotIds, royaltyVaultIpId, mintingFeeTokenAddress, ipAccount, waitForTransaction) - ).to.not.be.rejected; - - expect(response.txHash).to.be.a("string").and.not.empty; - // expect(response.claimableToken).to.be.a("bigint").to.be.equal(expectedClaimableToken); -}; +// // expect(response).to.be.a("bigint").and.to.be.equal(expectedClaimableRevenue); +// }; + +// export const claimRevenueByEOA = async function ( +// caller: keyof typeof storyClients, +// snapshotIds: bigint[], +// royaltyVaultIpId: Address, +// expectedClaimableToken: bigint +// ) { +// const response = await expect( +// royaltyClaimRevenue(caller, snapshotIds, royaltyVaultIpId, mintingFeeTokenAddress, undefined, waitForTransaction) +// ).to.not.be.rejected; + +// expect(response.txHash).to.be.a("string").and.not.empty; +// // expect(response.claimableToken).to.be.a("bigint").to.be.equal(expectedClaimableToken); +// }; + +// export const claimRevenueByIPA = async function ( +// caller: keyof typeof storyClients, +// snapshotIds: bigint[], +// royaltyVaultIpId: Address, +// ipAccount: Address, +// expectedClaimableToken: bigint +// ) { +// const response = await expect( +// royaltyClaimRevenue(caller, snapshotIds, royaltyVaultIpId, mintingFeeTokenAddress, ipAccount, waitForTransaction) +// ).to.not.be.rejected; + +// expect(response.txHash).to.be.a("string").and.not.empty; +// // expect(response.claimableToken).to.be.a("bigint").to.be.equal(expectedClaimableToken); +// }; export const transferTokenToEOA = async function( caller: keyof typeof storyClients, diff --git a/utils/cidToHash.ts b/utils/cidToHash.ts new file mode 100644 index 0000000..fd04167 --- /dev/null +++ b/utils/cidToHash.ts @@ -0,0 +1,46 @@ +import { CID } from "multiformats/cid"; +import bs58 from "bs58"; +import { base58btc } from "multiformats/bases/base58"; +import { Hex } from "viem"; + +// Define the prefix for v0 CIDs +const v0Prefix = "1220"; + +// Function to convert CID to IPFS hash +export const convertCIDtoHashIPFS = (cid: string): Hex => { + // Check if the CID is a v0 CID (starts with "Qm") + const isV0 = cid.startsWith("Qm"); + + // Parse the CID + const parsedCID = CID.parse(cid); + + // Convert to base58 CID if it's v0, otherwise convert to v0 + const base58CID = isV0 ? parsedCID.toString() : parsedCID.toV0().toString(); + + // Decode the base58 CID to bytes + const bytes = bs58.decode(base58CID); + + // Convert bytes to a hexadecimal string + const base16CID = Array.from(bytes) + .map((byte) => byte.toString(16).padStart(2, "0")) + .join(""); + + // Return the hash in hexadecimal format, prefixed with "0x" + return ("0x" + base16CID.slice(v0Prefix.length)) as Hex; +}; + +// Main function to demonstrate the conversion +const main = async () => { + // Example CID to convert + const cid = "bafkreid5gk7c75i6u5gtfqfotgbhbu2c2hvvvpj4xv62es4tbbanbutmd4"; // Replace with a valid CID + + try { + const hash = convertCIDtoHashIPFS(cid); + console.log(`Converted IPFS Hash: ${hash}`); + } catch (error) { + console.error("Error converting CID to IPFS hash:", error); + } +}; + +// Execute the main function +main(); \ No newline at end of file diff --git a/utils/constants.ts b/utils/constants.ts new file mode 100644 index 0000000..c1a0322 --- /dev/null +++ b/utils/constants.ts @@ -0,0 +1,23 @@ +import { Hex, zeroAddress } from "viem"; + +export const HashZero = "0x0000000000000000000000000000000000000000000000000000000000000000"; + +export const terms = { + transferable: true, + royaltyPolicy: zeroAddress as Hex, + defaultMintingFee: 0, + expiration: 0, + commercialUse: false, + commercialAttribution: false, + commercializerChecker: zeroAddress as Hex, + commercializerCheckerData: zeroAddress as Hex, + commercialRevShare: 0, + commercialRevCeiling: 0, + derivativesAllowed: true, + derivativesAttribution: true, + derivativesApproval: false, + derivativesReciprocal: true, + derivativeRevCeiling: 0, + currency: zeroAddress as Hex, + uri: "", +}; \ No newline at end of file diff --git a/utils/sdkUtils.ts b/utils/sdkUtils.ts index 6389fec..46b4879 100644 --- a/utils/sdkUtils.ts +++ b/utils/sdkUtils.ts @@ -1,6 +1,5 @@ import { Hex, Address, encodeFunctionData } from "viem"; import { clientA, clientB, clientC, } from '../config/config'; -import { PIL_TYPE } from "@story-protocol/core-sdk"; import { processResponse } from "./utils"; export const storyClients = { @@ -31,6 +30,7 @@ export const registerIpAsset = async function ( waitForTransaction: boolean | undefined, metadataURI?: string | undefined, metadataHash?: `0x${string}` | undefined, + nftMetadataURI?: string | undefined, nftMetadataHash?: `0x${string}` | undefined, deadline?: string | number | bigint | undefined ) { @@ -38,9 +38,10 @@ export const registerIpAsset = async function ( const response = await storyClient.ipAsset.register({ nftContract: nftContractAddress, tokenId: tokenId, - metadata: { - metadataURI: metadataURI, - metadataHash: metadataHash, + ipMetadata: { + ipMetadataURI: metadataURI, + ipMetadataHash: metadataHash, + nftMetadataURI: nftMetadataURI, nftMetadataHash: nftMetadataHash }, deadline: deadline, @@ -48,7 +49,8 @@ export const registerIpAsset = async function ( waitForTransaction: waitForTransaction } }); - console.log(JSON.stringify(response)); + // console.log(JSON.stringify(response)); + console.log(response); return response; }; @@ -80,8 +82,9 @@ export const registerDerivativeIp = async function ( licenseTermsIds: string[] | bigint[] | number[], waitForTransaction?: boolean, licenseTemplate?: `0x${string}` | undefined, - metadataURI?: string | undefined, - metadataHash?: `0x${string}` | undefined, + ipMetadataURI?: string | undefined, + ipMetadataHash?: `0x${string}` | undefined, + nftMetadataURI?: string | undefined, nftMetadataHash?: `0x${string}` | undefined, deadline?: string | number | bigint | undefined ) { @@ -94,9 +97,10 @@ export const registerDerivativeIp = async function ( licenseTermsIds: licenseTermsIds, licenseTemplate: licenseTemplate }, - metadata: { - metadataURI: metadataURI, - metadataHash: metadataHash, + ipMetadata: { + ipMetadataURI: ipMetadataURI, + ipMetadataHash: ipMetadataHash, + nftMetadataURI: nftMetadataURI, nftMetadataHash: nftMetadataHash, }, deadline: deadline, @@ -128,30 +132,26 @@ export const registerDerivativeWithLicenseTokens = async function ( export const mintAndRegisterIpAssetWithPilTerms = async function ( wallet: keyof typeof storyClients, - nftContract: Address, - pilType: PIL_TYPE, + spgNftContract: Address, + terms: any[], waitForTransaction?: boolean, - metadataURI?: string | undefined, - metadataHash?: `0x${string}` | undefined, + ipMetadataURI?: string | undefined, + ipMetadataHash?: `0x${string}` | undefined, + nftMetadataURI?: string | undefined, nftMetadataHash?: `0x${string}` | undefined, - recipient?: `0x${string}` | undefined, - mintingFee?: string | undefined, - commercialRevShare?: number | undefined, - currency?: `0x${string}` | undefined + recipient?: `0x${string}` | undefined ) { const storyClient = getStoryClient(wallet); const response = await storyClient.ipAsset.mintAndRegisterIpAssetWithPilTerms({ - nftContract: nftContract, - pilType: pilType, - metadata: { - metadataURI: metadataURI, - metadataHash: metadataHash, + spgNftContract: spgNftContract, + terms: terms, + ipMetadata: { + ipMetadataURI: ipMetadataURI, + ipMetadataHash: ipMetadataHash, + nftMetadataURI: nftMetadataURI, nftMetadataHash: nftMetadataHash, }, recipient: recipient, - mintingFee: mintingFee, - commercialRevShare: commercialRevShare, - currency: currency, txOptions: { waitForTransaction: waitForTransaction } @@ -166,30 +166,30 @@ export const registerIpAndAttachPilTerms = async function ( wallet: keyof typeof storyClients, nftContract: Address, tokenId: string | number | bigint, - pilType: PIL_TYPE, + terms: any, + mintingFee: string | number | bigint, + currency: `0x${string}`, waitForTransaction?: boolean, - metadataURI?: string | undefined, - metadataHash?: `0x${string}` | undefined, + ipMetadataURI?: string | undefined, + ipMetadataHash?: `0x${string}` | undefined, + nftMetadataURI?: string | undefined, nftMetadataHash?: `0x${string}` | undefined, + royaltyPolicyAddress?: `0x${string}` | undefined, deadline?: string | number | bigint | undefined, - mintingFee?: string | undefined, commercialRevShare?: number | undefined, - currency?: `0x${string}` | undefined ) { const storyClient = getStoryClient(wallet); const response = await storyClient.ipAsset.registerIpAndAttachPilTerms({ nftContract: nftContract, tokenId: tokenId, - pilType: pilType, - metadata: { - metadataURI: metadataURI, - metadataHash: metadataHash, + terms: terms, + ipMetadata: { + ipMetadataURI: ipMetadataURI, + ipMetadataHash: ipMetadataHash, + nftMetadataURI: nftMetadataURI, nftMetadataHash: nftMetadataHash, }, deadline: deadline, - mintingFee: mintingFee, - commercialRevShare: commercialRevShare, - currency: currency, txOptions: { waitForTransaction: waitForTransaction } @@ -218,14 +218,14 @@ export const registerNonComSocialRemixingPIL = async function ( export const registerCommercialRemixPIL = async function ( wallet: keyof typeof storyClients, - mintingFee: string | number | bigint, + defaultMintingFee: string | number | bigint, commercialRevShare: number, currency: Hex, waitForTransaction: boolean ) { const storyClient = getStoryClient(wallet); const response = await storyClient.license.registerCommercialRemixPIL({ - mintingFee: mintingFee, + defaultMintingFee: defaultMintingFee, commercialRevShare: commercialRevShare, currency: currency, txOptions: { @@ -240,13 +240,13 @@ export const registerCommercialRemixPIL = async function ( export const registerCommercialUsePIL = async function ( wallet: keyof typeof storyClients, - mintingFee: string | number | bigint, + defaultMintingFee: string | number | bigint, currency: `0x${string}`, waitForTransaction?: boolean | undefined ) { const storyClient = getStoryClient(wallet); const response = await storyClient.license.registerCommercialUsePIL({ - mintingFee: mintingFee, + defaultMintingFee: defaultMintingFee, currency: currency, txOptions: { waitForTransaction: waitForTransaction, @@ -382,26 +382,6 @@ export const payRoyaltyOnBehalf = async function ( return response; }; -export const collectRoyaltyTokens = async function ( - wallet: keyof typeof storyClients, - parentIpId: Hex, - royaltyVaultIpId: Hex, - waitForTransaction: boolean -) { - const storyClient = getStoryClient(wallet); - const response = await storyClient.royalty.collectRoyaltyTokens({ - parentIpId: parentIpId, - royaltyVaultIpId: royaltyVaultIpId, - txOptions: { - waitForTransaction: waitForTransaction - } - }); - - const responseJson = processResponse(response); - console.log(JSON.stringify(responseJson)); - return response; -}; - export const royaltyClaimableRevenue = async function ( wallet: keyof typeof storyClients, royaltyVaultIpId: Address, @@ -459,18 +439,18 @@ export const getRoyaltyVaultAddress = async function ( export const raiseDispute = async function ( wallet: keyof typeof storyClients, - targetIpId: Hex, - arbitrationPolicy: Hex, - linkToDisputeEvidence: string, - targetTag: string, - waitForTransaction: boolean + targetIpId: Address, + cid: string, + targetTag: string, + data?: Hex, + waitForTransaction?: boolean ) { const storyClient = getStoryClient(wallet); const response = await storyClient.dispute.raiseDispute({ targetIpId: targetIpId, - arbitrationPolicy: arbitrationPolicy, - linkToDisputeEvidence: linkToDisputeEvidence, targetTag: targetTag, + cid: cid, + data: data, txOptions: { waitForTransaction: waitForTransaction } @@ -517,22 +497,39 @@ export const resolveDispute = async function ( export const createNFTCollection = async function ( wallet: keyof typeof storyClients, - name: string, - symbol: string, - waitForTransaction: boolean, - options?: { [key: string]: any } + name: string, + symbol: string, + isPublicMinting: boolean, + mintOpen: boolean, + mintFeeRecipient: Address, + contractURI: string, + waitForTransaction?: boolean, + baseURI?: string, + maxSupply?: number, + mintFee?: bigint, + mintFeeToken?: Hex, + owner?: Hex ) { const storyClient = getStoryClient(wallet); - storyClient.nftClient.spgClient const response = await storyClient.nftClient.createNFTCollection({ name: name, symbol: symbol, + isPublicMinting: isPublicMinting, + mintOpen: mintOpen, + mintFeeRecipient: mintFeeRecipient, + contractURI: contractURI, + baseURI: baseURI, + maxSupply: maxSupply, + mintFee: mintFee, + mintFeeToken: mintFeeToken, + owner: owner, txOptions: { waitForTransaction: waitForTransaction - }, - ...options + } }); - console.log(JSON.stringify(response)); + + // console.log(JSON.stringify(response)); + console.log(response); return response; }; diff --git a/utils/utils.ts b/utils/utils.ts index afbfba9..20281aa 100644 --- a/utils/utils.ts +++ b/utils/utils.ts @@ -1,21 +1,9 @@ -import { Hex, http, Address, createWalletClient, createPublicClient, Chain } from 'viem' +import { Hex, http, Address, createWalletClient, createPublicClient } from 'viem' import { privateKeyToAccount } from 'viem/accounts' -import { sepolia } from 'viem/chains'; import fs from 'fs'; -import { chainStringToViemChain, nftContractAddress, rpcProviderUrl, royaltyPolicyLAPAddress, royaltyApproveAddress, disputeModuleAddress, ipAssetRegistryAddress, licenseTokenAddress } from "../config/config"; +import { nftContractAddress, rpcProviderUrl, royaltyPolicyLAPAddress, royaltyApproveAddress, disputeModuleAddress, ipAssetRegistryAddress, licenseTokenAddress, chainStringToViemChain } from "../config/config"; import { getLicenseTokenOwnerAbi, transferLicenseTokenAbi } from '../config/abi'; -const TEST_ENV = process.env.TEST_ENV as string | undefined; - -let chainId: Chain; -if (TEST_ENV == "sepolia") { - chainId = sepolia; -// } else if (TEST_ENV == "storyTestnet") { -// chainId = chainStringToViemChain("storyTestnet"); -} else { - throw new Error(`Unknown TEST_ENV value: ${TEST_ENV}`); -}; - export function sleep(second: number) { return new Promise((resolve) => setTimeout(resolve, second * 1000)); }; @@ -40,7 +28,7 @@ export function captureConsoleLogs(consoleLogs:string[]){ export function getWalletClient(WALLET_PRIVATE_KEY: Hex){ const account = privateKeyToAccount(WALLET_PRIVATE_KEY as Address); const walletClient = createWalletClient({ - chain: chainId, + chain: chainStringToViemChain("odyssey"), transport: http(rpcProviderUrl), account }); @@ -48,10 +36,58 @@ export function getWalletClient(WALLET_PRIVATE_KEY: Hex){ return walletClient; }; +export async function mintSPGNFT(WALLET_PRIVATE_KEY: Hex, NFT_COLLECTION_ADDRESS?: Address, nftMetadata?: string): Promise { + const account = privateKeyToAccount(WALLET_PRIVATE_KEY as Address); + const baseConfig = { + chain: chainStringToViemChain("odyssey"), + transport: http(rpcProviderUrl) + }; + const walletClient = createWalletClient({ + ...baseConfig, + account + }); + const publicClient = createPublicClient(baseConfig); + const contractAbi = { + inputs: [ + { internalType: 'address', name: 'to', type: 'address' }, + { internalType: "string", name: "nftMetadata", type: "string"}, + ], + name: 'mint', + outputs: [ + { internalType: 'uint256', name: 'tokenId', type: 'uint256' }, + ], + stateMutability: 'nonpayable', + type: 'function' + }; + + const requestArgs = { + address: NFT_COLLECTION_ADDRESS || nftContractAddress, + functionName: 'mint', + args: [account.address, nftMetadata || 'test'], + account: walletClient.account, + abi: [contractAbi] + }; + + // Mint an NFT to your account + await publicClient.simulateContract(requestArgs); + const hash = await walletClient.writeContract(requestArgs); + const { logs } = await publicClient.waitForTransactionReceipt({ + hash: hash + }); + + let tokenId: any; + if (logs[0].topics[3]) { + tokenId = parseInt(logs[0].topics[3], 16); + }; + + console.log(`Minted NFT successful with hash: ` + JSON.stringify(hash) + `\nMinted NFT tokenId: ` + JSON.stringify(tokenId)); + return String(tokenId); +}; + export async function mintNFT(WALLET_PRIVATE_KEY: Hex, NFT_COLLECTION_ADDRESS?: Address): Promise { const account = privateKeyToAccount(WALLET_PRIVATE_KEY as Address); const baseConfig = { - chain: chainId, + chain: chainStringToViemChain("odyssey"), transport: http(rpcProviderUrl) }; const walletClient = createWalletClient({ @@ -60,7 +96,9 @@ export async function mintNFT(WALLET_PRIVATE_KEY: Hex, NFT_COLLECTION_ADDRESS?: }); const publicClient = createPublicClient(baseConfig); const contractAbi = { - inputs: [{ internalType: 'address', name: 'to', type: 'address' }], + inputs: [ + { internalType: 'address', name: 'to', type: 'address' }, + ], name: 'mint', outputs: [ { internalType: 'uint256', name: 'tokenId', type: 'uint256' }, @@ -95,8 +133,8 @@ export async function mintNFT(WALLET_PRIVATE_KEY: Hex, NFT_COLLECTION_ADDRESS?: export async function isRegistered(ipId: Address): Promise { const baseConfig = { - chain: chainId, - transport: http(rpcProviderUrl) + chain: chainStringToViemChain("odyssey"), + transport: http(rpcProviderUrl) }; const publicClient = createPublicClient(baseConfig); @@ -123,10 +161,10 @@ export async function isRegistered(ipId: Address): Promise { return Boolean(result); }; -export async function mintNFTWithTokenID(WALLET_PRIVATE_KEY: Hex, id: number, NFT_COLLECTION_ADDRESS?: Address): Promise { +export async function mintNFTWithTokenID(WALLET_PRIVATE_KEY: Hex, id: number, NFT_COLLECTION_ADDRESS?: Address, nftMetadata?: string): Promise { const account = privateKeyToAccount(WALLET_PRIVATE_KEY as Address); const baseConfig = { - chain: chainId, + chain: chainStringToViemChain("odyssey"), transport: http(rpcProviderUrl) }; const walletClient = createWalletClient({ @@ -137,7 +175,8 @@ export async function mintNFTWithTokenID(WALLET_PRIVATE_KEY: Hex, id: number, NF const contractAbi = { inputs: [ { internalType: 'address', name: 'to', type: 'address' }, - { internalType: "uint256", name: "tokenId",type: "uint256" } + { internalType: "uint256", name: "tokenId",type: "uint256" }, + { internalType: "string", name: "nftMetadata", type: "string"}, ], name: 'mintId', outputs: [ @@ -150,7 +189,7 @@ export async function mintNFTWithTokenID(WALLET_PRIVATE_KEY: Hex, id: number, NF const requestArgs = { address: NFT_COLLECTION_ADDRESS || nftContractAddress, functionName: 'mintId', - args: [account.address, BigInt(id)], + args: [account.address, BigInt(id), nftMetadata], account: walletClient.account, abi: [contractAbi] }; @@ -175,7 +214,7 @@ export async function mintNFTWithTokenID(WALLET_PRIVATE_KEY: Hex, id: number, NF export async function approveSpender(WALLET_PRIVATE_KEY: Hex, value: number) { const account = privateKeyToAccount(WALLET_PRIVATE_KEY as Address); const baseConfig = { - chain: chainId, + chain: chainStringToViemChain("odyssey"), transport: http(rpcProviderUrl) }; const walletClient = createWalletClient({ @@ -214,7 +253,7 @@ export async function approveSpender(WALLET_PRIVATE_KEY: Hex, value: number) { export async function mintAmount(WALLET_PRIVATE_KEY: Hex, amount: number){ const account = privateKeyToAccount(WALLET_PRIVATE_KEY as Address); const baseConfig = { - chain: chainId, + chain: chainStringToViemChain("odyssey"), transport: http(rpcProviderUrl) }; const walletClient = createWalletClient({ @@ -252,7 +291,7 @@ export async function setDisputeJudgement(WALLET_PRIVATE_KEY: Hex, disputeId: bi try { const account = privateKeyToAccount(WALLET_PRIVATE_KEY as Address); const baseConfig = { - chain: chainId, + chain: chainStringToViemChain("odyssey"), transport: http(rpcProviderUrl) }; const walletClient = createWalletClient({ @@ -308,18 +347,18 @@ export async function getLatestTokenId(): Promise { return Number(latestTokenId); }; -export async function mintNFTWithRetry(WALLET_PRIVATE_KEY: Hex, NFT_COLLECTION_ADDRESS?: Address): Promise { +export async function mintNFTWithRetry(WALLET_PRIVATE_KEY: Hex, NFT_COLLECTION_ADDRESS?: Address, nftMetadata?: string): Promise { let tokenId: string = ''; for (let i = 0; i < 3; i++) { try { - tokenId = await mintNFT(WALLET_PRIVATE_KEY, NFT_COLLECTION_ADDRESS); + tokenId = await mintSPGNFT(WALLET_PRIVATE_KEY, NFT_COLLECTION_ADDRESS, nftMetadata); break; } catch (error) { if (i === 1) { try{ const latestTokenId = await getLatestTokenId(); - tokenId = await mintNFTWithTokenID(WALLET_PRIVATE_KEY, Number(latestTokenId) + 1, NFT_COLLECTION_ADDRESS); + tokenId = await mintNFTWithTokenID(WALLET_PRIVATE_KEY, Number(latestTokenId) + 1, NFT_COLLECTION_ADDRESS, nftMetadata); break; } catch (error) { tokenId = ''; @@ -333,7 +372,7 @@ export async function mintNFTWithRetry(WALLET_PRIVATE_KEY: Hex, NFT_COLLECTION_A export async function getTotalRTSupply(): Promise { const baseConfig = { - chain: chainId, + chain: chainStringToViemChain("odyssey"), transport: http(rpcProviderUrl) }; @@ -368,7 +407,7 @@ export async function checkMintResult(tokenIdA: string){ export async function getBlockTimestamp(): Promise { const baseConfig = { - chain: chainId, + chain: chainStringToViemChain("odyssey"), transport: http(rpcProviderUrl) }; const publicClient = createPublicClient(baseConfig); @@ -407,7 +446,7 @@ export const getDeadline = (deadline?: bigint | number | string): bigint => { export async function transferLicenseToken(WALLET_PRIVATE_KEY: Hex, from: Address, to: Address, licenseTokenId: number){ const account = privateKeyToAccount(WALLET_PRIVATE_KEY as Address); const baseConfig = { - chain: chainId, + chain: chainStringToViemChain("odyssey"), transport: http(rpcProviderUrl) }; const walletClient = createWalletClient({ @@ -438,7 +477,7 @@ export async function transferLicenseToken(WALLET_PRIVATE_KEY: Hex, from: Addres export async function getLicenseTokenOwner(tokenId: number): Promise
{ let result: Address | unknown; const baseConfig = { - chain: chainId, + chain: chainStringToViemChain("odyssey"), transport: http(rpcProviderUrl) }; @@ -457,5 +496,3 @@ export async function getLicenseTokenOwner(tokenId: number): Promise