1
0
mirror of https://github.com/oceanprotocol-archive/squid-js.git synced 2024-02-02 15:31:51 +01:00
squid-js/integration/ocean/ConsumeAsset.test.ts

129 lines
5.0 KiB
TypeScript
Raw Normal View History

2019-03-14 21:28:51 +01:00
import { assert } from "chai"
2019-02-21 18:07:02 +01:00
import { config } from "../config"
2019-03-14 21:28:51 +01:00
import { Ocean, MetaData, DDO, DID, Account/*, ServiceAgreement*/ } from "../../src" // @oceanprotocol/squid
2019-02-21 18:07:02 +01:00
2019-03-14 16:58:07 +01:00
describe("Consume Asset", () => {
2019-02-21 18:07:02 +01:00
let ocean: Ocean
let publisher: Account
let consumer: Account
let metadata: Partial<MetaData>
2019-03-14 16:58:07 +01:00
let ddo: DDO
let serviceAgreementSignatureResult: {agreementId: string, signature: string}
2019-02-21 18:07:02 +01:00
before(async () => {
2019-03-14 16:58:07 +01:00
ocean = await Ocean.getInstance(config)
2019-02-21 18:07:02 +01:00
// Accounts
2019-03-14 16:58:07 +01:00
publisher = (await ocean.accounts.list())[0]
publisher.setPassword(process.env.ACCOUNT_PASSWORD)
consumer = (await ocean.accounts.list())[1]
2019-02-21 18:07:02 +01:00
// Data
metadata = {
base: {
2019-03-14 16:58:07 +01:00
name: "Office Humidity",
2019-02-21 18:07:02 +01:00
type: "dataset",
description: "Weather information of UK including temperature and humidity",
size: "3.1gb",
dateCreated: "2012-02-01T10:55:11+00:00",
author: "Met Office",
license: "CC-BY",
copyrightHolder: "Met Office",
encoding: "UTF-8",
compression: "zip",
contentType: "text/csv",
// tslint:disable-next-line
workExample: "stationId,latitude,longitude,datetime,temperature,humidity423432fsd,51.509865,-0.118092,2011-01-01T10:55:11+00:00,7.2,68",
files: [
{
2019-03-14 16:58:07 +01:00
url: "https://testocnfiles.blob.core.windows.net/testfiles/testzkp.zip",
2019-02-21 18:07:02 +01:00
checksum: "085340abffh21495345af97c6b0e761",
contentLength: "12324",
},
{
2019-03-14 16:58:07 +01:00
url: "https://testocnfiles.blob.core.windows.net/testfiles/testzkp2.zip",
2019-02-21 18:07:02 +01:00
},
],
links: [
{sample1: "http://data.ceda.ac.uk/badc/ukcp09/data/gridded-land-obs/gridded-land-obs-daily/"},
{sample2: "http://data.ceda.ac.uk/badc/ukcp09/data/gridded-land-obs/gridded-land-obs-averages-25km/"},
{fieldsDescription: "http://data.ceda.ac.uk/badc/ukcp09/"},
],
inLanguage: "en",
tags: "weather, uk, 2011, temperature, humidity",
price: 10,
},
}
2019-03-14 16:58:07 +01:00
})
2019-02-21 18:07:02 +01:00
2019-03-14 16:58:07 +01:00
it("should regiester a asset", async () => {
ddo = await ocean.assets.create(metadata as any, publisher)
assert.isDefined(ddo, "Register has not returned a DDO")
assert.match(ddo.id, /^did:op:[a-f0-9]{64}$/, "DDO id is not valid")
assert.isAtLeast(ddo.authentication.length, 1, "Default authentication not added")
assert.isDefined(ddo.findServiceByType("Access"), "DDO Access service doesn't exist")
2019-02-21 18:07:02 +01:00
})
2019-03-14 16:58:07 +01:00
it("should be able to request tokens for consumer", async () => {
2019-03-14 21:28:51 +01:00
const initialBalance = (await consumer.getBalance()).ocn
2019-03-14 16:58:07 +01:00
await consumer.requestTokens(metadata.base.price)
2019-02-21 18:07:02 +01:00
2019-03-14 16:58:07 +01:00
assert.equal((await consumer.getBalance()).ocn, initialBalance + metadata.base.price, "OCN Tokens not delivered")
2019-02-21 18:07:02 +01:00
})
2019-03-14 16:58:07 +01:00
it("should sign the service agreement", async () => {
2019-02-21 18:07:02 +01:00
const accessService = ddo.findServiceByType("Access")
2019-03-14 16:58:07 +01:00
serviceAgreementSignatureResult = await ocean.agreements.prepare(ddo.id, accessService.serviceDefinitionId, consumer)
2019-02-25 14:06:48 +01:00
2019-03-14 16:58:07 +01:00
const {agreementId, signature} = serviceAgreementSignatureResult
assert.match(agreementId, /^[a-f0-9]{64}$/, "Service agreement ID seems not valid")
assert.match(signature, /^0x[a-f0-9]{130}$/, "Service agreement signature seems not valid")
2019-02-21 18:07:02 +01:00
})
2019-03-14 16:58:07 +01:00
it("should execute the service agreement", async () => {
2019-02-21 18:07:02 +01:00
const accessService = ddo.findServiceByType("Access")
2019-03-14 16:58:07 +01:00
const success = await ocean.agreements.create(
ddo.id,
serviceAgreementSignatureResult.agreementId,
accessService.serviceDefinitionId,
serviceAgreementSignatureResult.signature,
consumer,
publisher,
)
2019-02-21 18:07:02 +01:00
2019-03-14 16:58:07 +01:00
assert.isTrue(success)
})
xit("should lock the payment", async () => {
const paid = await ocean.agreements.conditions
.lockReward(
serviceAgreementSignatureResult.agreementId,
ddo.findServiceByType("Metadata").metadata.base.price,
publisher,
)
assert.isTrue(paid, "The asset has not been paid correctly")
})
2019-02-21 18:07:02 +01:00
2019-03-14 19:02:41 +01:00
xit("should grant the access", async () => {
2019-03-14 16:58:07 +01:00
const granted = await ocean.agreements.conditions
.grantAccess(serviceAgreementSignatureResult.agreementId, ddo.id, consumer.getId(), publisher)
assert.isTrue(granted, "The asset has not been granted correctly")
})
xit("should consume the assets", async () => {
const accessService = ddo.findServiceByType("Access")
2019-02-21 18:07:02 +01:00
2019-03-14 16:58:07 +01:00
await ocean.assets.consume(serviceAgreementSignatureResult.agreementId, ddo.id, accessService.serviceDefinitionId, consumer)
2019-02-21 18:07:02 +01:00
})
})