1
0
mirror of https://github.com/oceanprotocol/ocean.js.git synced 2024-11-26 20:39:05 +01:00
ocean.js/test/integration/PublishEditConsume.test.ts
2024-07-01 14:06:13 +01:00

558 lines
16 KiB
TypeScript

import { assert } from 'chai'
import { ethers, Signer } from 'ethers'
import { getTestConfig, getAddresses, provider } from '../config'
import {
Config,
ProviderInstance,
Aquarius,
Datatoken,
downloadFile,
sendTx,
transfer,
amountToUnits
} from '../../src'
import { Files, Smartcontract } from '../../src/@types'
import { createAsset, orderAsset, updateAssetMetadata } from './helpers'
let config: Config
let aquarius: Aquarius
let datatoken: Datatoken
let providerUrl: string
let consumerAccount: Signer
let publisherAccount: Signer
let addresses: any
let urlAssetId
let resolvedUrlAssetDdo
let resolvedUrlAssetDdoAfterUpdate
let arweaveAssetId
let resolvedArweaveAssetDdo
let resolvedArweaveAssetDdoAfterUpdate
let ipfsAssetId
let resolvedIpfsAssetDdo
let resolvedIpfsAssetDdoAfterUpdate
let onchainAssetId
let resolvedOnchainAssetDdo
let resolvedOnchainAssetDdoAfterUpdate
let grapqlAssetId
let resolvedGraphqlAssetDdo
let resolvedGraphqlAssetDdoAfterUpdate
let urlOrderTx
let arwaveOrderTx
let ipfsOrderTx
let onchainOrderTx
let grapqlOrderTx
const urlFile: Files = {
datatokenAddress: '0x0',
nftAddress: '0x0',
files: [
{
type: 'url',
url: 'https://raw.githubusercontent.com/oceanprotocol/testdatasets/main/shs_dataset_test.txt',
method: 'GET'
}
]
}
const arweaveFile: Files = {
datatokenAddress: '0x0',
nftAddress: '0x0',
files: [
{
type: 'arweave',
transactionId: 'USuWnUl3gLPhm4TPbmL6E2a2e2SWMCVo9yWCaapD-98'
}
]
}
const ifpsFile: Files = {
datatokenAddress: '0x0',
nftAddress: '0x0',
files: [
{
type: 'ipfs',
hash: 'QmRhsp7eghZtW4PktPC2wAHdKoy2LiF1n6UXMKmAhqQJUA'
}
]
}
const onchainFile: Files = {
datatokenAddress: '0x0',
nftAddress: '0x0',
files: []
}
const grapqlFile: Files = {
datatokenAddress: '0x0',
nftAddress: '0x0',
files: [
{
type: 'graphql',
url: 'https://v4.subgraph.sepolia.oceanprotocol.com/subgraphs/name/oceanprotocol/ocean-subgraph',
query: `"
query{
nfts(orderBy: createdTimestamp,orderDirection:desc){
id
symbol
createdTimestamp
}
}
"`
}
]
}
const assetDdo = {
'@context': ['https://w3id.org/did/v1'],
id: 'did:op:efba17455c127a885ec7830d687a8f6e64f5ba559f8506f8723c1f10f05c049c',
version: '4.1.0',
chainId: 4,
nftAddress: '0x0',
metadata: {
created: '2021-12-20T14:35:20Z',
updated: '2021-12-20T14:35:20Z',
type: 'dataset',
name: 'Test asset',
description: 'desc for the storage type assets',
tags: [''],
author: 'ocean-protocol',
license: 'https://market.oceanprotocol.com/terms',
additionalInformation: {
termsAndConditions: true
}
},
services: [
{
id: 'testFakeId',
type: 'access',
files: '',
datatokenAddress: '0x0',
serviceEndpoint: 'http://172.15.0.4:8030',
timeout: 0
}
]
}
function delay(interval: number) {
return it('should delay', (done) => {
setTimeout(() => done(), interval)
}).timeout(interval + 100)
}
describe('Publish consume test', async () => {
before(async () => {
publisherAccount = (await provider.getSigner(0)) as Signer
consumerAccount = (await provider.getSigner(1)) as Signer
config = await getTestConfig(publisherAccount)
aquarius = new Aquarius(config?.metadataCacheUri)
providerUrl = config?.providerUri
addresses = getAddresses()
})
it('Mint OCEAN to publisher account', async () => {
const minAbi = [
{
constant: false,
inputs: [
{ name: 'to', type: 'address' },
{ name: 'value', type: 'uint256' }
],
name: 'mint',
outputs: [{ name: '', type: 'bool' }],
payable: false,
stateMutability: 'nonpayable',
type: 'function'
}
]
const tokenContract = new ethers.Contract(addresses.Ocean, minAbi, publisherAccount)
const estGas = await tokenContract.estimateGas.mint(
await publisherAccount.getAddress(),
amountToUnits(null, null, '1000', 18)
)
await sendTx(
estGas,
publisherAccount,
1,
tokenContract.mint,
await publisherAccount.getAddress(),
amountToUnits(null, null, '1000', 18)
)
})
it('Send some OCEAN to consumer account', async () => {
transfer(
publisherAccount,
config,
addresses.Ocean,
await consumerAccount.getAddress(),
'100'
)
})
it('Should publish url asset', async () => {
urlAssetId = await createAsset(
'UrlDatatoken',
'URLDT',
publisherAccount,
urlFile,
assetDdo,
providerUrl,
addresses.ERC721Factory,
aquarius
)
assert(urlAssetId, 'Failed to publish url DDO')
})
it('Should publish ipfs asset', async () => {
ipfsAssetId = await createAsset(
'IpfsDatatoken',
'IPFSDT',
publisherAccount,
ifpsFile,
assetDdo,
providerUrl,
addresses.ERC721Factory,
aquarius
)
assert(ipfsAssetId, 'Failed to publish ipfs DDO')
})
it('Should publish arwave asset', async () => {
arweaveAssetId = await createAsset(
'ArweaveDatatoken',
'ARWEAVEDT',
publisherAccount,
arweaveFile,
assetDdo,
providerUrl,
addresses.ERC721Factory,
aquarius
)
assert(arweaveAssetId, 'Failed to publish ipfs DDO')
})
it('Should publish onchain asset', async () => {
const chainFile: Smartcontract = {
type: 'smartcontract',
address: addresses.Router,
abi: {
inputs: [],
name: 'swapOceanFee',
outputs: [{ internalType: 'uint256', name: '', type: 'uint256' }],
stateMutability: 'view',
type: 'function'
},
chainId: 8996
}
onchainFile.files[0] = chainFile
onchainAssetId = await createAsset(
'ChainDatatoken',
'CHAINDT',
publisherAccount,
onchainFile,
assetDdo,
providerUrl,
addresses.ERC721Factory,
aquarius
)
assert(onchainAssetId, 'Failed to publish onchain DDO')
})
it('Should publish graphql asset', async () => {
grapqlAssetId = await createAsset(
'GraphDatatoken',
'GRAPHDT',
publisherAccount,
grapqlFile,
assetDdo,
providerUrl,
addresses.ERC721Factory,
aquarius
)
assert(grapqlAssetId, 'Failed to publish graphql DDO')
})
delay(10000) // let's wait for aquarius to index the assets
it('Resolve published assets', async () => {
resolvedUrlAssetDdo = await aquarius.waitForAqua(urlAssetId)
assert(resolvedUrlAssetDdo, 'Cannot fetch url DDO from Aquarius')
resolvedArweaveAssetDdo = await aquarius.waitForAqua(arweaveAssetId)
assert(resolvedArweaveAssetDdo, 'Cannot fetch arwave DDO from Aquarius')
resolvedIpfsAssetDdo = await aquarius.waitForAqua(ipfsAssetId)
assert(resolvedIpfsAssetDdo, 'Cannot fetch ipfs DDO from Aquarius')
resolvedOnchainAssetDdo = await aquarius.waitForAqua(onchainAssetId)
assert(resolvedOnchainAssetDdo, 'Cannot fetch onchain DDO from Aquarius')
resolvedGraphqlAssetDdo = await aquarius.waitForAqua(grapqlAssetId)
assert(resolvedGraphqlAssetDdo, 'Cannot fetch graphql DDO from Aquarius')
})
it('Mint datasets datatokens to publisher', async () => {
datatoken = new Datatoken(publisherAccount, config.chainId)
const urlMintTx = await datatoken.mint(
resolvedUrlAssetDdo.services[0].datatokenAddress,
await publisherAccount.getAddress(),
'10',
await consumerAccount.getAddress()
)
assert(urlMintTx, 'Failed minting url datatoken to consumer.')
const arwaveMintTx = await datatoken.mint(
resolvedArweaveAssetDdo.services[0].datatokenAddress,
await publisherAccount.getAddress(),
'10',
await consumerAccount.getAddress()
)
assert(arwaveMintTx, 'Failed minting arwave datatoken to consumer.')
const ipfsMintTx = await datatoken.mint(
resolvedIpfsAssetDdo.services[0].datatokenAddress,
await publisherAccount.getAddress(),
'10',
await consumerAccount.getAddress()
)
assert(ipfsMintTx, 'Failed minting ipfs datatoken to consumer.')
const onchainMintTx = await datatoken.mint(
resolvedOnchainAssetDdo.services[0].datatokenAddress,
await publisherAccount.getAddress(),
'10',
await consumerAccount.getAddress()
)
assert(onchainMintTx, 'Failed minting onchain datatoken to consumer.')
const graphqlMintTx = await datatoken.mint(
resolvedGraphqlAssetDdo.services[0].datatokenAddress,
await publisherAccount.getAddress(),
'10',
await consumerAccount.getAddress()
)
assert(graphqlMintTx, 'Failed minting graphql datatoken to consumer.')
})
it('Should order url dataset', async () => {
datatoken = new Datatoken(consumerAccount, config.chainId)
urlOrderTx = await orderAsset(
resolvedUrlAssetDdo.id,
resolvedUrlAssetDdo.services[0].datatokenAddress,
await consumerAccount.getAddress(),
resolvedUrlAssetDdo.services[0].id,
0,
datatoken,
providerUrl
)
assert(urlOrderTx, 'Ordering url dataset failed.')
}).timeout(40000)
it('Should order arweave dataset', async () => {
arwaveOrderTx = await orderAsset(
resolvedArweaveAssetDdo.id,
resolvedArweaveAssetDdo.services[0].datatokenAddress,
await consumerAccount.getAddress(),
resolvedArweaveAssetDdo.services[0].id,
0,
datatoken,
providerUrl
)
assert(arwaveOrderTx, 'Ordering arwave dataset failed.')
}).timeout(40000)
it('Should order ipfs dataset', async () => {
ipfsOrderTx = await orderAsset(
resolvedIpfsAssetDdo.id,
resolvedIpfsAssetDdo.services[0].datatokenAddress,
await consumerAccount.getAddress(),
resolvedIpfsAssetDdo.services[0].id,
0,
datatoken,
providerUrl
)
assert(ipfsOrderTx, 'Ordering ipfs dataset failed.')
}).timeout(40000)
it('Should order onchain dataset', async () => {
onchainOrderTx = await orderAsset(
resolvedOnchainAssetDdo.id,
resolvedOnchainAssetDdo.services[0].datatokenAddress,
await consumerAccount.getAddress(),
resolvedOnchainAssetDdo.services[0].id,
0,
datatoken,
providerUrl
)
assert(onchainOrderTx, 'Ordering onchain dataset failed.')
}).timeout(40000)
it('Should order graphQl dataset', async () => {
grapqlOrderTx = await orderAsset(
resolvedGraphqlAssetDdo.id,
resolvedGraphqlAssetDdo.services[0].datatokenAddress,
await consumerAccount.getAddress(),
resolvedGraphqlAssetDdo.services[0].id,
0,
datatoken,
providerUrl
)
assert(grapqlOrderTx, 'Ordering graphql dataset failed.')
})
it('Should download the datasets files', async () => {
const urlDownloadUrl = await ProviderInstance.getDownloadUrl(
resolvedUrlAssetDdo.id,
resolvedUrlAssetDdo.services[0].id,
0,
urlOrderTx.transactionHash,
providerUrl,
consumerAccount
)
assert(urlDownloadUrl, 'Provider getDownloadUrl failed for url dataset')
try {
await downloadFile(urlDownloadUrl)
} catch (e) {
assert.fail(`Download url dataset failed: ${e}`)
}
const arwaveDownloadURL = await ProviderInstance.getDownloadUrl(
resolvedArweaveAssetDdo.id,
resolvedArweaveAssetDdo.services[0].id,
0,
arwaveOrderTx.transactionHash,
providerUrl,
consumerAccount
)
assert(arwaveDownloadURL, 'Provider getDownloadUrl failed for arwave dataset')
try {
await downloadFile(arwaveDownloadURL)
} catch (e) {
assert.fail(`Download arwave dataset failed: ${e}`)
}
const ipfsDownloadURL = await ProviderInstance.getDownloadUrl(
resolvedIpfsAssetDdo.id,
resolvedIpfsAssetDdo.services[0].id,
0,
ipfsOrderTx.transactionHash,
providerUrl,
consumerAccount
)
assert(ipfsDownloadURL, 'Provider getDownloadUrl failed for ipfs dataset')
try {
await downloadFile(ipfsDownloadURL)
} catch (e) {
assert.fail(`Download ipfs dataset failed ${e}`)
}
const onchainDownloadURL = await ProviderInstance.getDownloadUrl(
resolvedOnchainAssetDdo.id,
resolvedOnchainAssetDdo.services[0].id,
0,
onchainOrderTx.transactionHash,
providerUrl,
consumerAccount
)
assert(onchainDownloadURL, 'Provider getDownloadUrl failed for onchain dataset')
try {
await downloadFile(onchainDownloadURL)
} catch (e) {
assert.fail(`Download onchain dataset failed ${e}`)
}
const graphqlDownloadURL = await ProviderInstance.getDownloadUrl(
resolvedGraphqlAssetDdo.id,
resolvedGraphqlAssetDdo.services[0].id,
0,
grapqlOrderTx.transactionHash,
providerUrl,
consumerAccount
)
assert(graphqlDownloadURL, 'Provider getDownloadUrl failed for graphql dataset')
try {
await downloadFile(graphqlDownloadURL)
} catch (e) {
assert.fail(`Download graphql dataset failed ${e}`)
}
})
it('Should update url dataset', async () => {
resolvedUrlAssetDdo.metadata.name = 'updated url asset name'
const updateUrlTx = await updateAssetMetadata(
publisherAccount,
resolvedUrlAssetDdo,
providerUrl,
aquarius
)
assert(updateUrlTx, 'Failed to update url asset metadata')
})
it('Should update arweave dataset', async () => {
resolvedArweaveAssetDdo.metadata.name = 'updated arwave asset name'
const updateArwaveTx = await updateAssetMetadata(
publisherAccount,
resolvedArweaveAssetDdo,
providerUrl,
aquarius
)
assert(updateArwaveTx, 'Failed to update arwave asset metadata')
})
it('Should update ipfs dataset', async () => {
resolvedIpfsAssetDdo.metadata.name = 'updated ipfs asset name'
const updateIpfsTx = await updateAssetMetadata(
publisherAccount,
resolvedIpfsAssetDdo,
providerUrl,
aquarius
)
assert(updateIpfsTx, 'Failed to update ipfs asset metadata')
})
it('Should update onchain dataset', async () => {
resolvedOnchainAssetDdo.metadata.name = 'updated onchain asset name'
const updateOnchainTx = await updateAssetMetadata(
publisherAccount,
resolvedOnchainAssetDdo,
providerUrl,
aquarius
)
assert(updateOnchainTx, 'Failed to update ipfs asset metadata')
})
it('Should update graphql dataset', async () => {
resolvedGraphqlAssetDdo.metadata.name = 'updated graphql asset name'
const updateGraphqlTx = await updateAssetMetadata(
publisherAccount,
resolvedGraphqlAssetDdo,
providerUrl,
aquarius
)
assert(updateGraphqlTx, 'Failed to update graphql asset metadata')
})
delay(10000) // let's wait for aquarius to index the updated ddo's
it('Should resolve updated datasets', async () => {
resolvedUrlAssetDdoAfterUpdate = await aquarius.waitForAqua(urlAssetId)
assert(resolvedUrlAssetDdoAfterUpdate, 'Cannot fetch url DDO from Aquarius')
resolvedArweaveAssetDdoAfterUpdate = await aquarius.waitForAqua(arweaveAssetId)
assert(resolvedArweaveAssetDdoAfterUpdate, 'Cannot fetch arwave DDO from Aquarius')
resolvedIpfsAssetDdoAfterUpdate = await aquarius.waitForAqua(ipfsAssetId)
assert(resolvedIpfsAssetDdoAfterUpdate, 'Cannot fetch ipfs DDO from Aquarius')
resolvedOnchainAssetDdoAfterUpdate = await aquarius.waitForAqua(onchainAssetId)
assert(resolvedOnchainAssetDdoAfterUpdate, 'Cannot fetch onchain DDO from Aquarius')
resolvedGraphqlAssetDdoAfterUpdate = await aquarius.waitForAqua(grapqlAssetId)
assert(resolvedGraphqlAssetDdoAfterUpdate, 'Cannot fetch onchain DDO from Aquarius')
})
})