From 7e409932a859100db8935c2602febd7cec99fea2 Mon Sep 17 00:00:00 2001 From: dantb Date: Wed, 11 Oct 2023 16:39:17 +0200 Subject: [PATCH] Add Sparql test to query default view by tag --- .../views/sparql-search-response-tagged.json | 41 +++++++++++++++++++ .../nexus/tests/kg/SparqlViewsSpec.scala | 22 +++++++++- 2 files changed, 61 insertions(+), 2 deletions(-) create mode 100644 tests/src/test/resources/kg/views/sparql-search-response-tagged.json diff --git a/tests/src/test/resources/kg/views/sparql-search-response-tagged.json b/tests/src/test/resources/kg/views/sparql-search-response-tagged.json new file mode 100644 index 0000000000..e3d5b81677 --- /dev/null +++ b/tests/src/test/resources/kg/views/sparql-search-response-tagged.json @@ -0,0 +1,41 @@ +{ + "head": { + "vars": [ + "s" + ] + }, + "results": { + "bindings": [ + { + "s": { + "type": "uri", + "value": "https://bbp.epfl.ch/nexus/v0/data/bbp/experiment/patchedcell/v0.1.0/010b8ecb-21ac-4987-8faa-91f1274e656d" + } + }, + { + "s": { + "type": "uri", + "value": "https://bbp.epfl.ch/nexus/v0/data/bbp/experiment/patchedcell/v0.1.0/03e9025f-35ab-42ca-ac4a-5da2701b93f3" + } + }, + { + "s": { + "type": "uri", + "value": "https://bbp.epfl.ch/nexus/v0/data/bbp/experiment/patchedcell/v0.1.0/048bf2a9-c3e4-4401-bb1e-61f5fcacb85b" + } + }, + { + "s": { + "type": "uri", + "value": "https://bbp.epfl.ch/nexus/v0/data/bbp/experiment/patchedcell/v0.1.0/04e5f081-26fb-49ea-9d38-da7ef49d9e9f" + } + }, + { + "s": { + "type": "uri", + "value": "https://bbp.epfl.ch/nexus/v0/data/bbp/experiment/patchedcell/v0.1.0/08825325-0a84-4924-839b-baabcd9bdbb8" + } + } + ] + } +} \ No newline at end of file diff --git a/tests/src/test/scala/ch/epfl/bluebrain/nexus/tests/kg/SparqlViewsSpec.scala b/tests/src/test/scala/ch/epfl/bluebrain/nexus/tests/kg/SparqlViewsSpec.scala index 7136cc572b..9e19cbd406 100644 --- a/tests/src/test/scala/ch/epfl/bluebrain/nexus/tests/kg/SparqlViewsSpec.scala +++ b/tests/src/test/scala/ch/epfl/bluebrain/nexus/tests/kg/SparqlViewsSpec.scala @@ -52,7 +52,7 @@ class SparqlViewsSpec extends BaseSpec with EitherValuable with CirceEq { "create a context" in { val payload = jsonContentOf("/kg/views/context.json") - projects.parTraverse { project => + projects.traverse { project => deltaClient.put[Json](s"/resources/$project/resource/test-resource:context", payload, ScoobyDoo) { (_, response) => response.status shouldEqual StatusCodes.Created @@ -230,7 +230,7 @@ class SparqlViewsSpec extends BaseSpec with EitherValuable with CirceEq { } "tag resources" in { - (1 to 5).toList.parTraverse { i => + (1 to 5).toList.traverse { i => val payload = jsonContentOf(s"/kg/views/instances/instance$i.json") val id = `@id`.getOption(payload).value val unprefixedId = id.stripPrefix("https://bbp.epfl.ch/nexus/v0/data/bbp/experiment/patchedcell/v0.1.0/") @@ -259,6 +259,24 @@ class SparqlViewsSpec extends BaseSpec with EitherValuable with CirceEq { } } + val byTagQuery = + """ + |prefix nxv: + | + |select ?s where { + | ?s nxv:tags "one" + |} + |order by ?s + """.stripMargin + + "search by tag in SPARQL endpoint in project 1 with default view" in eventually { + deltaClient.sparqlQuery[Json](s"/views/$fullId/nxv:defaultSparqlIndex/sparql", byTagQuery, ScoobyDoo) { + (json, response) => + response.status shouldEqual StatusCodes.OK + json shouldEqual jsonContentOf("/kg/views/sparql-search-response-tagged.json") + } + } + "search instances in SPARQL endpoint in project 1 with custom SparqlView after tags added" in { eventually { deltaClient.sparqlQuery[Json](s"/views/$fullId/test-resource:cell-view/sparql", query, ScoobyDoo) {