1
0
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:
Pedro Gutiérrez 2019-02-12 15:07:10 +01:00 committed by Pedro Gutiérrez
parent 8bce68a3a5
commit 14f3955ed0
12 changed files with 139 additions and 33 deletions

View File

@ -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",

View 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"))
})
})

View File

@ -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"

View File

@ -1,3 +0,0 @@
export default class Query {
public value: number = 1
}

View File

@ -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}
}

View File

@ -1,3 +0,0 @@
export default class Sort {
public value: number = 1
}

View File

@ -1 +1 @@
export * from './squid'
export * from "./squid"

View File

@ -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.")

View File

@ -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)
}
/**

View File

@ -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"

View File

@ -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"

View File

@ -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"