mirror of
https://github.com/oceanprotocol-archive/squid-js.git
synced 2024-02-02 15:31:51 +01:00
added Search asset tests
This commit is contained in:
parent
8bce68a3a5
commit
14f3955ed0
@ -1,6 +1,6 @@
|
||||
{
|
||||
"nodeUri": "http://localhost:8545",
|
||||
"aquariusUri": "https://nginx-aquarius.dev-ocean.com",
|
||||
"aquariusUri": "http://localhost:5000",
|
||||
"brizoUri": "http://localhost:8030",
|
||||
"parityUri": "http://localhost:9545",
|
||||
"secretStoreUri": "http://localhost:12001",
|
||||
|
117
integration/ocean/SearchAsset.test.ts
Normal file
117
integration/ocean/SearchAsset.test.ts
Normal file
@ -0,0 +1,117 @@
|
||||
import { assert } from 'chai'
|
||||
|
||||
import { config } from "../config"
|
||||
|
||||
import { Ocean, MetaData, Account, DDO } from '../../src' // @oceanprotocol/squid
|
||||
|
||||
describe("Search Asset", () => {
|
||||
let ocean: Ocean
|
||||
|
||||
let publisher: Account
|
||||
|
||||
const testHash = Math.random().toString(36).substr(2)
|
||||
let metadata: Partial<MetaData>
|
||||
let metadataGenerator = (name: string) => ({
|
||||
...metadata,
|
||||
base: {
|
||||
...metadata.base,
|
||||
name: `${name}${testHash}`,
|
||||
},
|
||||
})
|
||||
|
||||
let test1length
|
||||
let test2length
|
||||
let test3length
|
||||
|
||||
before(async () => {
|
||||
ocean = await Ocean.getInstance(config)
|
||||
|
||||
// Accounts
|
||||
publisher = (await ocean.accounts.list())[0]
|
||||
publisher.setPassword(process.env.ACCOUNT_PASSWORD)
|
||||
|
||||
// Data
|
||||
metadata = {
|
||||
base: {
|
||||
name: undefined,
|
||||
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: [
|
||||
{
|
||||
url: "https://testocnfiles.blob.core.windows.net/testfiles/testzkp.zip",
|
||||
checksum: "085340abffh21495345af97c6b0e761",
|
||||
contentLength: "12324",
|
||||
},
|
||||
{
|
||||
url: "https://testocnfiles.blob.core.windows.net/testfiles/testzkp2.zip",
|
||||
},
|
||||
],
|
||||
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,
|
||||
},
|
||||
}
|
||||
|
||||
})
|
||||
|
||||
it("should be able to search the assets", async () => {
|
||||
const ddos: DDO[] = await ocean.assets.search(`Test1${testHash}`)
|
||||
|
||||
assert.isArray(ddos, "A search should return an array")
|
||||
|
||||
test1length = ddos.length
|
||||
test2length = (await ocean.assets.search(`Test2${testHash}`)).length
|
||||
test3length = (await ocean.assets.search(`Test3${testHash}`)).length
|
||||
})
|
||||
|
||||
it("should regiester some a asset", async () => {
|
||||
assert.instanceOf(await ocean.assets.create(metadataGenerator("Test1") as any, publisher), DDO)
|
||||
assert.instanceOf(await ocean.assets.create(metadataGenerator("Test2") as any, publisher), DDO)
|
||||
assert.instanceOf(await ocean.assets.create(metadataGenerator("Test2") as any, publisher), DDO)
|
||||
assert.instanceOf(await ocean.assets.create(metadataGenerator("Test3") as any, publisher), DDO)
|
||||
})
|
||||
|
||||
it("should search by text and see the increment of DDOs", async () => {
|
||||
assert.equal((await ocean.assets.search(`Test2${testHash}`)).length - test2length, 2, "Something was wrong searching the assets")
|
||||
assert.equal((await ocean.assets.search(`Test3${testHash}`)).length - test3length, 1, "Something was wrong searching the assets")
|
||||
})
|
||||
|
||||
it("should return a list of DDOs", async () => {
|
||||
const ddos: DDO[] = await ocean.assets.search(`Test1${testHash}`)
|
||||
|
||||
assert.equal(ddos.length - test1length, 1, "Something was wrong searching the assets")
|
||||
ddos.map(ddo => assert.instanceOf(ddo, DDO, "The DDO is not an instance of a DDO"))
|
||||
})
|
||||
|
||||
it("should be able to do a query to get a list of DDOs", async () => {
|
||||
const ddos: DDO[] = await ocean.assets.query({
|
||||
text: `Test2${testHash}`,
|
||||
page: 0,
|
||||
offset: 1,
|
||||
query: {
|
||||
value: 1,
|
||||
},
|
||||
sort: {
|
||||
value: 1,
|
||||
},
|
||||
})
|
||||
|
||||
assert.equal(ddos.length, 1, "Something was wrong searching the assets")
|
||||
ddos.map(ddo => assert.instanceOf(ddo, DDO, "The DDO is not an instance of a DDO"))
|
||||
})
|
||||
})
|
@ -4,7 +4,7 @@ import Config from "../models/Config"
|
||||
import DID from "../ocean/DID"
|
||||
import Logger from "../utils/Logger"
|
||||
import WebServiceConnectorProvider from "../utils/WebServiceConnectorProvider"
|
||||
import SearchQuery from "./query/SearchQuery"
|
||||
import { SearchQuery } from "./query/SearchQuery"
|
||||
|
||||
const apiPath = "/api/v1/aquarius/assets/ddo"
|
||||
|
||||
|
@ -1,3 +0,0 @@
|
||||
export default class Query {
|
||||
public value: number = 1
|
||||
}
|
@ -1,14 +1,7 @@
|
||||
import Query from "./Query"
|
||||
import Sort from "./Sort"
|
||||
|
||||
export default class SearchQuery {
|
||||
public offset: number = 100
|
||||
public page: number = 0
|
||||
public query: Query = {
|
||||
value: 1,
|
||||
} as Query
|
||||
public sort: Sort = {
|
||||
value: 1,
|
||||
} as Sort
|
||||
public text: string = "Office"
|
||||
export interface SearchQuery {
|
||||
text: string
|
||||
offset: number
|
||||
page: number
|
||||
query: {[property: string]: string | number | string[] | number[]}
|
||||
sort: {[jsonPath: string]: number}
|
||||
}
|
||||
|
@ -1,3 +0,0 @@
|
||||
export default class Sort {
|
||||
public value: number = 1
|
||||
}
|
@ -1 +1 @@
|
||||
export * from './squid'
|
||||
export * from "./squid"
|
||||
|
@ -5,7 +5,7 @@ import OceanAgreements from "./OceanAgreements"
|
||||
import OceanAssets from "./OceanAssets"
|
||||
|
||||
import AquariusProvider from "../aquarius/AquariusProvider"
|
||||
import SearchQuery from "../aquarius/query/SearchQuery"
|
||||
import { SearchQuery } from "../aquarius/query/SearchQuery"
|
||||
import BrizoProvider from "../brizo/BrizoProvider"
|
||||
import ConfigProvider from "../ConfigProvider"
|
||||
import { DDO } from "../ddo/DDO"
|
||||
@ -175,7 +175,9 @@ export default class Ocean {
|
||||
|
||||
const accessEvent: ContractEvent = EventListener.subscribe(
|
||||
accessService.conditions[1].contractName,
|
||||
accessService.conditions[1].events[1].name, {})
|
||||
accessService.conditions[1].events[1].name,
|
||||
{},
|
||||
)
|
||||
const filesPromise = new Promise((resolve) => {
|
||||
accessEvent.listenOnce(async () => {
|
||||
Logger.log("Awesome; got a AccessGranted Event. Let's download the asset files.")
|
||||
|
@ -1,5 +1,5 @@
|
||||
import AquariusProvider from "../aquarius/AquariusProvider"
|
||||
import SearchQuery from "../aquarius/query/SearchQuery"
|
||||
import { SearchQuery } from "../aquarius/query/SearchQuery"
|
||||
import BrizoProvider from "../brizo/BrizoProvider"
|
||||
import { Condition } from "../ddo/Condition"
|
||||
import { DDO } from "../ddo/DDO"
|
||||
@ -230,7 +230,7 @@ export default class OceanAssets {
|
||||
* @return {Promise<DDO[]>}
|
||||
*/
|
||||
public async query(query: SearchQuery): Promise<DDO[]> {
|
||||
return AquariusProvider.getAquarius().queryMetadata(query)
|
||||
return AquariusProvider.getAquarius().queryMetadataByText(query)
|
||||
}
|
||||
|
||||
/**
|
||||
|
10
src/squid.ts
10
src/squid.ts
@ -1,14 +1,14 @@
|
||||
import Access from "./ocean/ServiceAgreements/Templates/Access"
|
||||
import Account from "./ocean/Account"
|
||||
import Config from "./models/Config"
|
||||
import Account from "./ocean/Account"
|
||||
import DID from "./ocean/DID"
|
||||
import FitchainCompute from "./ocean/ServiceAgreements/Templates/FitchainCompute"
|
||||
import IdGenerator from "./ocean/IdGenerator"
|
||||
import Logger from "./utils/Logger"
|
||||
import Ocean from "./ocean/Ocean"
|
||||
import SecretStoreProvider from "./secretstore/SecretStoreProvider"
|
||||
import ServiceAgreement from "./ocean/ServiceAgreements/ServiceAgreement"
|
||||
import ServiceAgreementTemplate from "./ocean/ServiceAgreements/ServiceAgreementTemplate"
|
||||
import Access from "./ocean/ServiceAgreements/Templates/Access"
|
||||
import FitchainCompute from "./ocean/ServiceAgreements/Templates/FitchainCompute"
|
||||
import SecretStoreProvider from "./secretstore/SecretStoreProvider"
|
||||
import Logger from "./utils/Logger"
|
||||
import WebServiceConnectorProvider from "./utils/WebServiceConnectorProvider"
|
||||
|
||||
import EventListener from "./keeper/EventListener"
|
||||
|
@ -1,6 +1,6 @@
|
||||
import * as assert from "assert"
|
||||
import Aquarius from "../../src/aquarius/Aquarius"
|
||||
import SearchQuery from "../../src/aquarius/query/SearchQuery"
|
||||
import { SearchQuery } from "../../src/aquarius/query/SearchQuery"
|
||||
import { DDO } from "../../src/ddo/DDO"
|
||||
import DID from "../../src/ocean/DID"
|
||||
import WebServiceConnectorProvider from "../../src/utils/WebServiceConnectorProvider"
|
||||
|
@ -2,7 +2,7 @@ import { assert, spy, use } from "chai"
|
||||
import * as spies from "chai-spies"
|
||||
|
||||
import AquariusProvider from "../../src/aquarius/AquariusProvider"
|
||||
import SearchQuery from "../../src/aquarius/query/SearchQuery"
|
||||
import { SearchQuery } from "../../src/aquarius/query/SearchQuery"
|
||||
import BrizoProvider from "../../src/brizo/BrizoProvider"
|
||||
import ConfigProvider from "../../src/ConfigProvider"
|
||||
import { DDO } from "../../src/ddo/DDO"
|
||||
|
Loading…
Reference in New Issue
Block a user