mirror of
https://github.com/oceanprotocol-archive/squid-js.git
synced 2024-02-02 15:31:51 +01:00
166 lines
7.0 KiB
TypeScript
166 lines
7.0 KiB
TypeScript
import {assert} from "chai"
|
|
import ConfigProvider from "../../src/ConfigProvider"
|
|
import DDOCondition from "../../src/ddo/Condition"
|
|
import DDO from "../../src/ddo/DDO"
|
|
import Parameter from "../../src/ddo/Parameter"
|
|
import Service from "../../src/ddo/Service"
|
|
import Account from "../../src/ocean/Account"
|
|
import IdGenerator from "../../src/ocean/IdGenerator"
|
|
import Ocean from "../../src/ocean/Ocean"
|
|
import Condition from "../../src/ocean/ServiceAgreements/Condition"
|
|
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"
|
|
|
|
let ocean: Ocean
|
|
let accounts: Account[]
|
|
let publisherAccount: Account
|
|
let consumerAccount: Account
|
|
|
|
let service: Service
|
|
|
|
describe("ServiceAgreement", () => {
|
|
|
|
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())
|
|
|
|
// get condition keys from template
|
|
const conditions: Condition[] = await serviceAgreementTemplate.getConditions()
|
|
|
|
// create ddo conditions out of the keys
|
|
const ddoConditions: DDOCondition[] = conditions.map((condition): DDOCondition => {
|
|
return {
|
|
contractName: condition.methodReflection.contractName,
|
|
methodName: condition.methodReflection.methodName,
|
|
timeout: condition.timeout,
|
|
conditionKey: condition.condtionKey,
|
|
parameters: condition.methodReflection.inputs.map((input) => {
|
|
return {
|
|
...input,
|
|
value: "xx",
|
|
}as Parameter
|
|
}),
|
|
} as DDOCondition
|
|
})
|
|
|
|
service = {
|
|
type: "Access",
|
|
serviceDefinitionId: IdGenerator.generateId(),
|
|
templateId: serviceAgreementTemplate.getId(),
|
|
conditions: ddoConditions,
|
|
} as Service
|
|
})
|
|
|
|
describe("#signServiceAgreement()", () => {
|
|
it("should sign an service agreement", async () => {
|
|
|
|
const id: string = IdGenerator.generateId()
|
|
const did: string = `did:op:${id}`
|
|
const ddo = new DDO({id: did, service: [service]})
|
|
const assetId: string = IdGenerator.generateId()
|
|
const serviceAgreementId: string = IdGenerator.generateId()
|
|
|
|
// @ts-ignore
|
|
WebServiceConnectorProvider.setConnector(new WebServiceConnectorMock(ddo))
|
|
|
|
const serviceAgreementSignature: string =
|
|
await ServiceAgreement.signServiceAgreement(assetId, ddo, service.serviceDefinitionId,
|
|
serviceAgreementId, consumerAccount)
|
|
|
|
assert(serviceAgreementSignature)
|
|
assert(serviceAgreementSignature.startsWith("0x"))
|
|
})
|
|
})
|
|
|
|
describe("#executeServiceAgreement()", () => {
|
|
it("should execute an service agreement", async () => {
|
|
|
|
const id: string = IdGenerator.generateId()
|
|
const did: string = `did:op:${id}`
|
|
const ddo = new DDO({id: did, service: [service]})
|
|
const assetId: string = IdGenerator.generateId()
|
|
const serviceAgreementId: string = IdGenerator.generateId()
|
|
|
|
// @ts-ignore
|
|
WebServiceConnectorProvider.setConnector(new WebServiceConnectorMock(ddo))
|
|
const serviceAgreementSignature: string =
|
|
await ServiceAgreement.signServiceAgreement(assetId, ddo, service.serviceDefinitionId,
|
|
serviceAgreementId, consumerAccount)
|
|
|
|
const serviceAgreement: ServiceAgreement =
|
|
await ServiceAgreement.executeServiceAgreement(assetId, ddo, service.serviceDefinitionId,
|
|
serviceAgreementId, serviceAgreementSignature, consumerAccount, publisherAccount)
|
|
assert(serviceAgreement)
|
|
|
|
const serviceDefinitionId = serviceAgreement.getId()
|
|
assert(serviceDefinitionId)
|
|
assert(serviceDefinitionId !== did)
|
|
})
|
|
})
|
|
|
|
describe("#getStatus()", () => {
|
|
it("should get the status of a newly created service agreement", async () => {
|
|
|
|
const id: string = IdGenerator.generateId()
|
|
const did: string = `did:op:${id}`
|
|
const ddo = new DDO({id: did, service: [service]})
|
|
const assetId: string = IdGenerator.generateId()
|
|
const serviceAgreementId: string = IdGenerator.generateId()
|
|
|
|
// @ts-ignore
|
|
WebServiceConnectorProvider.setConnector(new WebServiceConnectorMock(ddo))
|
|
const serviceAgreementSignature: string =
|
|
await ServiceAgreement.signServiceAgreement(assetId, ddo, service.serviceDefinitionId,
|
|
serviceAgreementId, consumerAccount)
|
|
assert(serviceAgreementSignature)
|
|
|
|
const serviceAgreement: ServiceAgreement =
|
|
await ServiceAgreement.executeServiceAgreement(assetId, ddo, service.serviceDefinitionId,
|
|
serviceAgreementId, serviceAgreementSignature, consumerAccount, publisherAccount)
|
|
assert(serviceAgreement)
|
|
|
|
const status = await serviceAgreement.getStatus()
|
|
assert(status === false)
|
|
})
|
|
})
|
|
|
|
describe("#grantAccess()", () => {
|
|
it("should grant access in that service agreement", async () => {
|
|
|
|
const id: string = IdGenerator.generateId()
|
|
const did: string = `did:op:${id}`
|
|
const ddo = new DDO({id: did, service: [service]})
|
|
const assetId: string = IdGenerator.generateId()
|
|
const serviceAgreementId: string = IdGenerator.generateId()
|
|
|
|
// @ts-ignore
|
|
WebServiceConnectorProvider.setConnector(new WebServiceConnectorMock(ddo))
|
|
const serviceAgreementSignature: string =
|
|
await ServiceAgreement.signServiceAgreement(assetId, ddo, service.serviceDefinitionId,
|
|
serviceAgreementId, consumerAccount)
|
|
assert(serviceAgreementSignature)
|
|
|
|
const serviceAgreement: ServiceAgreement =
|
|
await ServiceAgreement.executeServiceAgreement(assetId, ddo, service.serviceDefinitionId,
|
|
serviceAgreementId, serviceAgreementSignature, consumerAccount, publisherAccount)
|
|
assert(serviceAgreement)
|
|
|
|
const fulfilled: boolean = await serviceAgreement.grantAccess(assetId, IdGenerator.generateId())
|
|
assert(fulfilled)
|
|
})
|
|
})
|
|
})
|