298 lines
9.3 KiB
TypeScript
298 lines
9.3 KiB
TypeScript
import { assert } from 'chai'
|
|
|
|
import { config } from '../config'
|
|
|
|
import { Ocean, templates, conditions, utils, Account, Keeper } from '../../src' // @oceanprotocol/squid
|
|
|
|
const {
|
|
LockRewardCondition,
|
|
EscrowReward,
|
|
AccessSecretStoreCondition
|
|
} = conditions
|
|
|
|
describe('Register Escrow Access Secret Store Template', () => {
|
|
let ocean: Ocean
|
|
let keeper: Keeper
|
|
|
|
let template: templates.EscrowAccessSecretStoreTemplate
|
|
|
|
const url = 'https://example.com/did/ocean/test-attr-example.txt'
|
|
const checksum = 'b'.repeat(32)
|
|
const escrowAmount = 12
|
|
|
|
let templateManagerOwner: Account
|
|
let publisher: Account
|
|
let consumer: Account
|
|
|
|
let accessSecretStoreCondition: conditions.AccessSecretStoreCondition
|
|
let lockRewardCondition: conditions.LockRewardCondition
|
|
let escrowReward: conditions.EscrowReward
|
|
|
|
before(async () => {
|
|
ocean = await Ocean.getInstance(config)
|
|
keeper = ocean.keeper
|
|
|
|
template = keeper.templates.escrowAccessSecretStoreTemplate
|
|
|
|
// Accounts
|
|
templateManagerOwner = (await ocean.accounts.list())[0]
|
|
publisher = (await ocean.accounts.list())[1]
|
|
consumer = (await ocean.accounts.list())[2]
|
|
|
|
// Conditions
|
|
accessSecretStoreCondition =
|
|
keeper.conditions.accessSecretStoreCondition
|
|
lockRewardCondition = keeper.conditions.lockRewardCondition
|
|
escrowReward = keeper.conditions.escrowReward
|
|
})
|
|
|
|
describe('Propose and approve template', () => {
|
|
it('should propose the template', async () => {
|
|
await keeper.templateStoreManager.proposeTemplate(
|
|
template.getAddress(),
|
|
consumer.getId(),
|
|
true
|
|
)
|
|
// TODO: Use a event to detect template mined
|
|
await new Promise(_ => setTimeout(_, 2 * 1000))
|
|
})
|
|
|
|
it('should approve the template', async () => {
|
|
await keeper.templateStoreManager.approveTemplate(
|
|
template.getAddress(),
|
|
templateManagerOwner.getId(),
|
|
true
|
|
)
|
|
// TODO: Use a event to detect template mined
|
|
await new Promise(_ => setTimeout(_, 2 * 1000))
|
|
})
|
|
})
|
|
|
|
describe('Full flow', () => {
|
|
const agreementId = `0x${utils.generateId()}`
|
|
const did = `0x${utils.generateId()}`
|
|
|
|
let conditionIdAccess: string
|
|
let conditionIdLock: string
|
|
let conditionIdEscrow: string
|
|
|
|
it('should register a DID', async () => {
|
|
await keeper.didRegistry.registerAttribute(
|
|
did,
|
|
checksum,
|
|
[],
|
|
url,
|
|
publisher.getId()
|
|
)
|
|
})
|
|
|
|
it('should generate the condition IDs', async () => {
|
|
conditionIdAccess = await accessSecretStoreCondition.generateIdHash(
|
|
agreementId,
|
|
did,
|
|
consumer.getId()
|
|
)
|
|
conditionIdLock = await lockRewardCondition.generateIdHash(
|
|
agreementId,
|
|
await escrowReward.getAddress(),
|
|
escrowAmount
|
|
)
|
|
conditionIdEscrow = await escrowReward.generateIdHash(
|
|
agreementId,
|
|
escrowAmount,
|
|
publisher.getId(),
|
|
consumer.getId(),
|
|
conditionIdLock,
|
|
conditionIdAccess
|
|
)
|
|
})
|
|
|
|
it('should have conditions types', async () => {
|
|
const conditionTypes = await template.getConditionTypes()
|
|
|
|
assert.equal(conditionTypes.length, 3, 'Expected 3 conditions.')
|
|
assert.deepEqual(
|
|
[...conditionTypes].sort(),
|
|
[
|
|
accessSecretStoreCondition.getAddress(),
|
|
escrowReward.getAddress(),
|
|
lockRewardCondition.getAddress()
|
|
].sort(),
|
|
"The conditions doesn't match"
|
|
)
|
|
})
|
|
|
|
it('should have condition instances asociated', async () => {
|
|
const conditionInstances = await template.getConditions()
|
|
|
|
assert.equal(conditionInstances.length, 3, 'Expected 3 conditions.')
|
|
|
|
const conditionClasses = [
|
|
AccessSecretStoreCondition,
|
|
EscrowReward,
|
|
LockRewardCondition
|
|
]
|
|
conditionClasses.forEach(conditionClass => {
|
|
if (
|
|
!conditionInstances.find(
|
|
condition => condition instanceof conditionClass
|
|
)
|
|
) {
|
|
throw new Error(
|
|
`${conditionClass.name} is not part of the conditions.`
|
|
)
|
|
}
|
|
})
|
|
})
|
|
|
|
it('should create a new agreement', async () => {
|
|
const agreement = await template.createAgreement(
|
|
agreementId,
|
|
did,
|
|
[conditionIdAccess, conditionIdLock, conditionIdEscrow],
|
|
[0, 0, 0],
|
|
[0, 0, 0],
|
|
consumer.getId(),
|
|
publisher.getId()
|
|
)
|
|
|
|
assert.isTrue(agreement.status)
|
|
})
|
|
|
|
it('should not grant the access to the consumer', async () => {
|
|
const accessGranted = await accessSecretStoreCondition.checkPermissions(
|
|
consumer.getId(),
|
|
did
|
|
)
|
|
|
|
assert.isFalse(accessGranted, 'Consumer has been granted.')
|
|
})
|
|
|
|
it('should fulfill LockRewardCondition', async () => {
|
|
await consumer.requestTokens(escrowAmount)
|
|
|
|
await keeper.token.approve(
|
|
lockRewardCondition.getAddress(),
|
|
escrowAmount,
|
|
consumer.getId()
|
|
)
|
|
|
|
const fulfill = await lockRewardCondition.fulfill(
|
|
agreementId,
|
|
escrowReward.getAddress(),
|
|
escrowAmount,
|
|
consumer.getId()
|
|
)
|
|
|
|
assert.isDefined(fulfill.events.Fulfilled, 'Not Fulfilled event.')
|
|
})
|
|
|
|
it('should fulfill AccessSecretStoreCondition', async () => {
|
|
const fulfill = await accessSecretStoreCondition.fulfill(
|
|
agreementId,
|
|
did,
|
|
consumer.getId(),
|
|
publisher.getId()
|
|
)
|
|
|
|
assert.isDefined(fulfill.events.Fulfilled, 'Not Fulfilled event.')
|
|
})
|
|
|
|
it('should fulfill EscrowReward', async () => {
|
|
const fulfill = await escrowReward.fulfill(
|
|
agreementId,
|
|
escrowAmount,
|
|
publisher.getId(),
|
|
consumer.getId(),
|
|
conditionIdLock,
|
|
conditionIdAccess,
|
|
consumer.getId()
|
|
)
|
|
|
|
assert.isDefined(fulfill.events.Fulfilled, 'Not Fulfilled event.')
|
|
})
|
|
|
|
it('should grant the access to the consumer', async () => {
|
|
const accessGranted = await accessSecretStoreCondition.checkPermissions(
|
|
consumer.getId(),
|
|
did
|
|
)
|
|
|
|
assert.isTrue(accessGranted, 'Consumer has not been granted.')
|
|
})
|
|
})
|
|
|
|
describe('Short flow', () => {
|
|
const did = utils.generateId()
|
|
|
|
let agreementId
|
|
|
|
it('should register a DID', async () => {
|
|
// This part is executed inside Ocean.assets.create()
|
|
await keeper.didRegistry.registerAttribute(
|
|
did,
|
|
checksum,
|
|
[],
|
|
url,
|
|
publisher.getId()
|
|
)
|
|
})
|
|
|
|
it('should create a new agreement (short way)', async () => {
|
|
agreementId = await template.createFullAgreement(
|
|
did,
|
|
escrowAmount,
|
|
consumer.getId(),
|
|
publisher.getId()
|
|
)
|
|
|
|
assert.match(agreementId, /^0x[a-f0-9]{64}$/i)
|
|
})
|
|
|
|
it('should not grant the access to the consumer', async () => {
|
|
const accessGranted = await accessSecretStoreCondition.checkPermissions(
|
|
consumer.getId(),
|
|
did
|
|
)
|
|
|
|
assert.isFalse(accessGranted, 'Consumer has been granted.')
|
|
})
|
|
|
|
it('should fulfill the conditions from consumer side', async () => {
|
|
await consumer.requestTokens(escrowAmount)
|
|
|
|
await ocean.agreements.conditions.lockReward(
|
|
agreementId,
|
|
escrowAmount,
|
|
consumer
|
|
)
|
|
})
|
|
|
|
it('should fulfill the conditions from publisher side', async () => {
|
|
await ocean.agreements.conditions.grantAccess(
|
|
agreementId,
|
|
did,
|
|
consumer.getId(),
|
|
publisher
|
|
)
|
|
await ocean.agreements.conditions.releaseReward(
|
|
agreementId,
|
|
escrowAmount,
|
|
did,
|
|
consumer.getId(),
|
|
publisher.getId(),
|
|
publisher
|
|
)
|
|
})
|
|
|
|
it('should grant the access to the consumer', async () => {
|
|
const accessGranted = await accessSecretStoreCondition.checkPermissions(
|
|
consumer.getId(),
|
|
did
|
|
)
|
|
|
|
assert.isTrue(accessGranted, 'Consumer has not been granted.')
|
|
})
|
|
})
|
|
})
|