mirror of
https://github.com/oceanprotocol-archive/squid-js.git
synced 2024-02-02 15:31:51 +01:00
151 lines
4.2 KiB
TypeScript
151 lines
4.2 KiB
TypeScript
import {assert} from "chai"
|
|
import DDO from "../../src/libDDO/DDO"
|
|
|
|
import * as jsonDDO from "../testdata/ddoSample1.json"
|
|
import * as Web3 from "web3"
|
|
|
|
|
|
describe("libDDO", () => {
|
|
|
|
describe("#constructor()", () => {
|
|
|
|
it("should create an empty ddo", async () => {
|
|
|
|
const ddo = new DDO()
|
|
assert(ddo)
|
|
assert(ddo.did == null)
|
|
|
|
})
|
|
})
|
|
describe('JSON serialization unserialization', () => {
|
|
it("should create ddo with the sample JSON", async () => {
|
|
|
|
assert(jsonDDO)
|
|
var ddo = new DDO(jsonDDO)
|
|
assert(ddo)
|
|
|
|
assert(ddo.validate())
|
|
|
|
var jsonText = ddo.toJSON()
|
|
assert(jsonText)
|
|
})
|
|
|
|
})
|
|
describe('validation', () => {
|
|
it("should test ddo core validation", async () => {
|
|
|
|
// core ddo values
|
|
assert(jsonDDO)
|
|
var ddo = new DDO(jsonDDO)
|
|
assert(ddo)
|
|
|
|
assert(ddo.validate())
|
|
ddo.did = ''
|
|
assert(!ddo.validate())
|
|
})
|
|
it("should test ddo public key validation", async () => {
|
|
|
|
// public key
|
|
var ddo = new DDO(jsonDDO)
|
|
assert(ddo)
|
|
assert(ddo.validate())
|
|
|
|
ddo.publicKeys[0].id = ''
|
|
assert(!ddo.validate())
|
|
|
|
})
|
|
it("should test ddo authentication validation", async () => {
|
|
|
|
// authentication
|
|
var ddo = new DDO(jsonDDO)
|
|
assert(ddo)
|
|
assert(ddo.validate())
|
|
|
|
ddo.authentications[0].type = ''
|
|
assert(!ddo.validate())
|
|
})
|
|
it("should test ddo service validation", async () => {
|
|
// service
|
|
var ddo = new DDO(jsonDDO)
|
|
assert(ddo)
|
|
assert(ddo.validate())
|
|
|
|
ddo.services[0].endpoint = ''
|
|
assert(!ddo.validate())
|
|
})
|
|
it("should test ddo proof validation", async () => {
|
|
// proof
|
|
var ddo = new DDO(jsonDDO)
|
|
assert(ddo)
|
|
assert(ddo.validate())
|
|
|
|
ddo.proof.signatureValue = ''
|
|
assert(!ddo.validate())
|
|
})
|
|
})
|
|
describe('DDO access data', () => {
|
|
it("should find a service in the ddo", async () => {
|
|
var ddo = new DDO(jsonDDO)
|
|
assert(ddo)
|
|
assert(ddo.validate())
|
|
|
|
var service = ddo.getService('Metadata')
|
|
assert(service)
|
|
|
|
var service = ddo.getService('MetadataCannotFind')
|
|
assert(service == null)
|
|
// var item = ddo.findServiceKeyValue('serviceDefinitionId', 'test')
|
|
})
|
|
})
|
|
describe('DDO hashing', () => {
|
|
it("should hash a valid ddo", async () => {
|
|
var ddo = new DDO(jsonDDO)
|
|
assert(ddo)
|
|
assert(ddo.validate())
|
|
|
|
var hash = ddo.calculateHash()
|
|
assert(hash)
|
|
// console.log(hash)
|
|
|
|
})
|
|
})
|
|
|
|
describe('DDO validate proof from JSON', () => {
|
|
it("should have a valid ddo proof", async () => {
|
|
var ddo = new DDO(jsonDDO)
|
|
assert(ddo)
|
|
assert(ddo.validate())
|
|
ddo.validateProof()
|
|
})
|
|
})
|
|
|
|
describe('DDO creation', () => {
|
|
it("should add a signature", async () => {
|
|
var ddo = new DDO()
|
|
assert(ddo)
|
|
const privateKey = ddo.addSignature()
|
|
assert(privateKey.match('-----BEGIN RSA PRIVATE KEY-----'))
|
|
})
|
|
|
|
it("should add a service", async () => {
|
|
const did = 'did:op:' + Web3.utils.randomHex(32).substr(2)
|
|
var ddo = new DDO(did)
|
|
assert(ddo)
|
|
const service = ddo.addService({type: 'metatrippy', serviceEndpoint: 'http://localhost:5000'})
|
|
assert(service)
|
|
assert(service.id === did)
|
|
})
|
|
it("should add a static proof and validate", async () => {
|
|
const did = 'did:op:' + Web3.utils.randomHex(32).substr(2)
|
|
var ddo = new DDO(did)
|
|
assert(ddo)
|
|
const privateKey = ddo.addSignature()
|
|
assert(privateKey.match('-----BEGIN RSA PRIVATE KEY-----'))
|
|
ddo.addProof(0, privateKey)
|
|
console.log(ddo.toJSON())
|
|
assert(ddo.validateProof())
|
|
})
|
|
})
|
|
|
|
})
|