mirror of
https://github.com/oceanprotocol-archive/squid-js.git
synced 2024-02-02 15:31:51 +01:00
199 lines
8.1 KiB
TypeScript
199 lines
8.1 KiB
TypeScript
import {assert} from "chai"
|
|
import ConfigProvider from "../../src/ConfigProvider"
|
|
import { Condition } from "../../src/ddo/Condition"
|
|
import { DDO } from "../../src/ddo/DDO"
|
|
import { Service } from "../../src/ddo/Service"
|
|
import Account from "../../src/ocean/Account"
|
|
import DID from "../../src/ocean/DID"
|
|
import IdGenerator from "../../src/ocean/IdGenerator"
|
|
import Ocean from "../../src/ocean/Ocean"
|
|
import ServiceAgreement from "../../src/ocean/ServiceAgreements/ServiceAgreement"
|
|
import ServiceAgreementTemplate from "../../src/ocean/ServiceAgreements/ServiceAgreementTemplate"
|
|
import Access from "../../src/ocean/ServiceAgreements/Templates/Access"
|
|
import WebServiceConnectorProvider from "../../src/utils/WebServiceConnectorProvider"
|
|
import config from "../config"
|
|
import TestContractHandler from "../keeper/TestContractHandler"
|
|
import WebServiceConnectorMock from "../mocks/WebServiceConnector.mock"
|
|
import { metadataMock } from "../testdata/MetaData"
|
|
|
|
|
|
let ocean: Ocean
|
|
let accounts: Account[]
|
|
let publisherAccount: Account
|
|
let consumerAccount: Account
|
|
|
|
let accessService: Service
|
|
let metaDataService: Service
|
|
|
|
const did: DID = DID.generate()
|
|
|
|
describe("ServiceAgreement", () => {
|
|
|
|
const metadata = metadataMock
|
|
|
|
before(async () => {
|
|
ConfigProvider.setConfig(config)
|
|
await TestContractHandler.prepareContracts()
|
|
ocean = await Ocean.getInstance(config)
|
|
accounts = await ocean.getAccounts()
|
|
|
|
publisherAccount = accounts[1]
|
|
consumerAccount = accounts[2]
|
|
|
|
const serviceAgreementTemplate: ServiceAgreementTemplate =
|
|
new ServiceAgreementTemplate(new Access())
|
|
|
|
const conditions: Condition[] = await serviceAgreementTemplate.getConditions(metadata, did.getId())
|
|
|
|
accessService = {
|
|
type: "Access",
|
|
serviceDefinitionId: "0",
|
|
templateId: serviceAgreementTemplate.getId(),
|
|
conditions,
|
|
} as Service
|
|
|
|
metaDataService = {
|
|
type: "MetaData",
|
|
metadata,
|
|
} as Service
|
|
})
|
|
|
|
describe("#signServiceAgreement()", () => {
|
|
it("should sign an service agreement", async () => {
|
|
|
|
const ddo = new DDO({id: did.getDid(), service: [accessService]})
|
|
const serviceAgreementId: string = IdGenerator.generateId()
|
|
|
|
// @ts-ignore
|
|
WebServiceConnectorProvider.setConnector(new WebServiceConnectorMock(ddo))
|
|
|
|
const serviceAgreementSignature: string =
|
|
await ServiceAgreement.signServiceAgreement(ddo, accessService.serviceDefinitionId,
|
|
serviceAgreementId, consumerAccount)
|
|
|
|
assert(serviceAgreementSignature)
|
|
assert(serviceAgreementSignature.startsWith("0x"))
|
|
assert(serviceAgreementSignature.length === 132)
|
|
})
|
|
})
|
|
|
|
describe("#executeServiceAgreement()", () => {
|
|
it("should execute a service agreement", async () => {
|
|
|
|
const ddo = new DDO({id: did.getDid(), service: [accessService]})
|
|
const serviceAgreementId: string = IdGenerator.generateId()
|
|
|
|
// @ts-ignore
|
|
WebServiceConnectorProvider.setConnector(new WebServiceConnectorMock(ddo))
|
|
const serviceAgreementSignature: string =
|
|
await ServiceAgreement.signServiceAgreement(ddo, accessService.serviceDefinitionId,
|
|
serviceAgreementId, consumerAccount)
|
|
|
|
const serviceAgreement: ServiceAgreement =
|
|
await ServiceAgreement.executeServiceAgreement(did, ddo, accessService.serviceDefinitionId,
|
|
serviceAgreementId, serviceAgreementSignature, consumerAccount, publisherAccount)
|
|
assert(serviceAgreement)
|
|
|
|
const serviceDefinitionId = serviceAgreement.getId()
|
|
assert(serviceDefinitionId)
|
|
assert(serviceDefinitionId !== did.getId())
|
|
})
|
|
|
|
it("should throw on invalid sig", (done) => {
|
|
|
|
const ddo = new DDO({id: did.getDid(), service: [accessService]})
|
|
const serviceAgreementId: string = IdGenerator.generateId()
|
|
|
|
// @ts-ignore
|
|
WebServiceConnectorProvider.setConnector(new WebServiceConnectorMock(ddo))
|
|
|
|
ServiceAgreement.executeServiceAgreement(did, ddo, accessService.serviceDefinitionId,
|
|
serviceAgreementId, "0x00", consumerAccount, publisherAccount)
|
|
.catch((err) => {
|
|
done()
|
|
})
|
|
})
|
|
})
|
|
|
|
describe("#payAsset()", () => {
|
|
it("should lock the payment in that service agreement", async () => {
|
|
|
|
const ddo = new DDO({id: did.getDid(), service: [accessService, metaDataService]})
|
|
const serviceAgreementId: string = IdGenerator.generateId()
|
|
|
|
// @ts-ignore
|
|
WebServiceConnectorProvider.setConnector(new WebServiceConnectorMock(ddo))
|
|
|
|
const serviceAgreementSignature: string =
|
|
await ServiceAgreement.signServiceAgreement(ddo, accessService.serviceDefinitionId,
|
|
serviceAgreementId, consumerAccount)
|
|
assert(serviceAgreementSignature)
|
|
|
|
const serviceAgreement: ServiceAgreement =
|
|
await ServiceAgreement.executeServiceAgreement(did, ddo, accessService.serviceDefinitionId,
|
|
serviceAgreementId, serviceAgreementSignature, consumerAccount, publisherAccount)
|
|
assert(serviceAgreement)
|
|
|
|
// get funds
|
|
await consumerAccount.requestTokens(metaDataService.metadata.base.price)
|
|
|
|
const paid: boolean = await serviceAgreement.payAsset(did.getId(), metaDataService.metadata.base.price,
|
|
consumerAccount)
|
|
assert(paid)
|
|
})
|
|
})
|
|
|
|
describe("#grantAccess()", () => {
|
|
it("should grant access in that service agreement", async () => {
|
|
|
|
const ddo = new DDO({id: did.getDid(), service: [accessService]})
|
|
const serviceAgreementId: string = IdGenerator.generateId()
|
|
|
|
// @ts-ignore
|
|
WebServiceConnectorProvider.setConnector(new WebServiceConnectorMock(ddo))
|
|
const serviceAgreementSignature: string =
|
|
await ServiceAgreement.signServiceAgreement(ddo, accessService.serviceDefinitionId,
|
|
serviceAgreementId, consumerAccount)
|
|
assert(serviceAgreementSignature)
|
|
|
|
const serviceAgreement: ServiceAgreement =
|
|
await ServiceAgreement.executeServiceAgreement(did, ddo, accessService.serviceDefinitionId,
|
|
serviceAgreementId, serviceAgreementSignature, consumerAccount, publisherAccount)
|
|
assert(serviceAgreement)
|
|
|
|
// get funds
|
|
await consumerAccount.requestTokens(metaDataService.metadata.base.price)
|
|
|
|
const paid: boolean = await serviceAgreement.payAsset(did.getId(), metaDataService.metadata.base.price,
|
|
consumerAccount)
|
|
assert(paid)
|
|
|
|
// todo: use document id
|
|
const accessGranted: boolean = await serviceAgreement.grantAccess(did.getId(), publisherAccount)
|
|
assert(accessGranted)
|
|
})
|
|
|
|
it("should fail to grant grant access if there is no payment", async () => {
|
|
|
|
const ddo = new DDO({id: did.getDid(), service: [accessService]})
|
|
const serviceAgreementId: string = IdGenerator.generateId()
|
|
|
|
// @ts-ignore
|
|
WebServiceConnectorProvider.setConnector(new WebServiceConnectorMock(ddo))
|
|
const serviceAgreementSignature: string =
|
|
await ServiceAgreement.signServiceAgreement(ddo, accessService.serviceDefinitionId,
|
|
serviceAgreementId, consumerAccount)
|
|
assert(serviceAgreementSignature)
|
|
|
|
const serviceAgreement: ServiceAgreement =
|
|
await ServiceAgreement.executeServiceAgreement(did, ddo, accessService.serviceDefinitionId,
|
|
serviceAgreementId, serviceAgreementSignature, consumerAccount, publisherAccount)
|
|
assert(serviceAgreement)
|
|
|
|
// todo: use document id
|
|
const accessGranted: boolean = await serviceAgreement.grantAccess(did.getId(), publisherAccount)
|
|
assert(!accessGranted)
|
|
})
|
|
})
|
|
})
|