From 416bd5a678bcf74874fbd7359a6ad89b252514ed Mon Sep 17 00:00:00 2001 From: Simon Date: Fri, 25 Aug 2023 18:36:00 +0200 Subject: [PATCH] Validate index with indexing rev (#4200) * Validate index with indexing rev --------- Co-authored-by: Simon Dumas --- .../contexts/elasticsearch-metadata.json | 3 +-- .../resources/contexts/elasticsearch.json | 3 +-- .../elasticsearch/ElasticSearchViews.scala | 22 +++++++++---------- .../ValidateElasticSearchView.scala | 18 +++++++++------ .../elasticsearch/client/IndexLabel.scala | 5 +++-- .../indexing/IndexingViewDef.scala | 4 ++-- .../model/ElasticSearchView.scala | 10 ++++----- .../model/ElasticSearchViewState.scala | 6 ++--- .../model/ElasticSearchViewValue.scala | 20 +++++++++++------ .../jsonld/indexing-view-compacted-1.json | 1 - .../jsonld/indexing-view-compacted-2.json | 1 - .../jsonld/indexing-view-compacted-3.json | 1 - .../jsonld/indexing-view-expanded.json | 5 ----- .../elasticsearch-view-read-response.json | 1 - .../elasticsearch-view-write-response.json | 1 - .../ElasticSearchIndexingActionSuite.scala | 4 ++-- .../elasticsearch/ElasticSearchViewGen.scala | 5 +++-- .../ElasticSearchViewSTMSpec.scala | 8 +++---- .../ElasticSearchViewValueSuite.scala | 8 ++++--- .../ElasticSearchViewsSpec.scala | 6 ++--- .../ElasticSearchDeletionTaskSuite.scala | 4 ++-- .../ElasticSearchCoordinatorSuite.scala | 4 ++-- .../indexing/IndexingViewDefSuite.scala | 8 +++---- .../ElasticSearchViewSerializationSuite.scala | 4 ++-- .../model/ElasticSearchViewSpec.scala | 3 +-- .../ElasticSearchIndexingRoutesSpec.scala | 4 ++-- .../routes/ElasticSearchViewsRoutesSpec.scala | 22 +++++++------------ .../resources/kg/listings/default-view.json | 1 - .../elasticsearch/indexing-response.json | 1 - .../nexus/tests/kg/SearchConfigSpec.scala | 4 ++-- 30 files changed, 88 insertions(+), 99 deletions(-) diff --git a/delta/plugins/elasticsearch/src/main/resources/contexts/elasticsearch-metadata.json b/delta/plugins/elasticsearch/src/main/resources/contexts/elasticsearch-metadata.json index 7bbc67f7b9..a344a8863a 100644 --- a/delta/plugins/elasticsearch/src/main/resources/contexts/elasticsearch-metadata.json +++ b/delta/plugins/elasticsearch/src/main/resources/contexts/elasticsearch-metadata.json @@ -3,8 +3,7 @@ "View": "https://bluebrain.github.io/nexus/vocabulary/View", "ElasticSearchView": "https://bluebrain.github.io/nexus/vocabulary/ElasticSearchView", "AggregateElasticSearchView": "https://bluebrain.github.io/nexus/vocabulary/AggregateElasticSearchView", - "_uuid": "https://bluebrain.github.io/nexus/vocabulary/uuid", - "_indexingRev": "https://bluebrain.github.io/nexus/vocabulary/indexingRev" + "_uuid": "https://bluebrain.github.io/nexus/vocabulary/uuid" }, "@id": "https://bluebrain.github.io/nexus/contexts/elasticsearch-metadata.json" } diff --git a/delta/plugins/elasticsearch/src/main/resources/contexts/elasticsearch.json b/delta/plugins/elasticsearch/src/main/resources/contexts/elasticsearch.json index 8b377b72e4..8a27561e57 100644 --- a/delta/plugins/elasticsearch/src/main/resources/contexts/elasticsearch.json +++ b/delta/plugins/elasticsearch/src/main/resources/contexts/elasticsearch.json @@ -18,8 +18,7 @@ "viewId": { "@type": "@id" }, - "_uuid": "https://bluebrain.github.io/nexus/vocabulary/uuid", - "_indexingRev": "https://bluebrain.github.io/nexus/vocabulary/indexingRev" + "_uuid": "https://bluebrain.github.io/nexus/vocabulary/uuid" }, "https://bluebrain.github.io/nexus/contexts/pipeline.json" ], diff --git a/delta/plugins/elasticsearch/src/main/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/ElasticSearchViews.scala b/delta/plugins/elasticsearch/src/main/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/ElasticSearchViews.scala index 7254cfb18f..7f5c0ab7c2 100644 --- a/delta/plugins/elasticsearch/src/main/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/ElasticSearchViews.scala +++ b/delta/plugins/elasticsearch/src/main/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/ElasticSearchViews.scala @@ -25,6 +25,7 @@ import ch.epfl.bluebrain.nexus.delta.sdk.model._ import ch.epfl.bluebrain.nexus.delta.sdk.projects.FetchContext import ch.epfl.bluebrain.nexus.delta.sdk.projects.model.ApiMappings import ch.epfl.bluebrain.nexus.delta.sdk.resolvers.ResolverContextResolution +import ch.epfl.bluebrain.nexus.delta.sdk.views.IndexingRev import ch.epfl.bluebrain.nexus.delta.sourcing.ScopedEntityDefinition.Tagger import ch.epfl.bluebrain.nexus.delta.sourcing._ import ch.epfl.bluebrain.nexus.delta.sourcing.config.EventLogConfig @@ -384,12 +385,12 @@ object ElasticSearchViews { def projectionName(state: ElasticSearchViewState): String = projectionName(state.project, state.id, state.indexingRev) - def projectionName(project: ProjectRef, id: Iri, indexingRev: Int): String = { - s"elasticsearch-$project-$id-$indexingRev" + def projectionName(project: ProjectRef, id: Iri, indexingRev: IndexingRev): String = { + s"elasticsearch-$project-$id-${indexingRev.value}" } - def index(uuid: UUID, rev: Int, prefix: String): IndexLabel = - IndexLabel.fromView(prefix, uuid, rev) + def index(uuid: UUID, indexingRev: IndexingRev, prefix: String): IndexLabel = + IndexLabel.fromView(prefix, uuid, indexingRev) def apply( fetchContext: FetchContext[ElasticSearchViewRejection], @@ -424,15 +425,11 @@ object ElasticSearchViews { // format: off def created(e: ElasticSearchViewCreated): Option[ElasticSearchViewState] = Option.when(state.isEmpty) { - ElasticSearchViewState(e.id, e.project, e.uuid, e.value, e.source, Tags.empty, e.rev, e.rev, deprecated = false, e.instant, e.subject, e.instant, e.subject) + ElasticSearchViewState(e.id, e.project, e.uuid, e.value, e.source, Tags.empty, e.rev, IndexingRev.init, deprecated = false, e.instant, e.subject, e.instant, e.subject) } def updated(e: ElasticSearchViewUpdated): Option[ElasticSearchViewState] = state.map { s => - val newIndexingRev = - (e.value.asIndexingValue, s.value.asIndexingValue, Option(s.indexingRev)) - .mapN(nextIndexingRev) - .getOrElse(s.indexingRev) - + val newIndexingRev = nextIndexingRev(s.value, e.value, s.indexingRev, e.rev) s.copy(rev = e.rev, indexingRev = newIndexingRev, value = e.value, source = e.source, updatedAt = e.instant, updatedBy = e.subject) } // format: on @@ -465,7 +462,7 @@ object ElasticSearchViews { for { t <- IOUtils.instant u <- uuidF() - _ <- validate(u, 1, c.value) + _ <- validate(u, IndexingRev.init, c.value) } yield ElasticSearchViewCreated(c.id, c.project, u, c.value, c.source, 1, t, c.subject) case Some(_) => IO.raiseError(ResourceAlreadyExists(c.id, c.project)) } @@ -480,8 +477,9 @@ object ElasticSearchViews { case Some(s) if c.value.tpe != s.value.tpe => IO.raiseError(DifferentElasticSearchViewType(s.id.toString, c.value.tpe, s.value.tpe)) case Some(s) => + val newIndexingRev = nextIndexingRev(s.value, c.value, s.indexingRev, c.rev) for { - _ <- validate(s.uuid, s.rev + 1, c.value) + _ <- validate(s.uuid, newIndexingRev, c.value) t <- IOUtils.instant } yield ElasticSearchViewUpdated(c.id, c.project, s.uuid, c.value, c.source, s.rev + 1, t, c.subject) } diff --git a/delta/plugins/elasticsearch/src/main/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/ValidateElasticSearchView.scala b/delta/plugins/elasticsearch/src/main/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/ValidateElasticSearchView.scala index a4c76028a0..4f6f72f235 100644 --- a/delta/plugins/elasticsearch/src/main/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/ValidateElasticSearchView.scala +++ b/delta/plugins/elasticsearch/src/main/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/ValidateElasticSearchView.scala @@ -9,7 +9,7 @@ import ch.epfl.bluebrain.nexus.delta.sdk.http.HttpClient.HttpResult import ch.epfl.bluebrain.nexus.delta.sdk.http.HttpClientError.HttpClientStatusError import ch.epfl.bluebrain.nexus.delta.sdk.permissions.Permissions import ch.epfl.bluebrain.nexus.delta.sdk.permissions.model.Permission -import ch.epfl.bluebrain.nexus.delta.sdk.views.ValidateAggregate +import ch.epfl.bluebrain.nexus.delta.sdk.views.{IndexingRev, ValidateAggregate} import ch.epfl.bluebrain.nexus.delta.sourcing.Transactors import ch.epfl.bluebrain.nexus.delta.sourcing.stream.{PipeChain, ProjectionErr} import io.circe.JsonObject @@ -22,12 +22,12 @@ import java.util.UUID */ trait ValidateElasticSearchView { - def apply(uuid: UUID, rev: Int, v: ElasticSearchViewValue): IO[ElasticSearchViewRejection, Unit] + def apply(uuid: UUID, indexingRev: IndexingRev, v: ElasticSearchViewValue): IO[ElasticSearchViewRejection, Unit] } object ValidateElasticSearchView { - val always: ValidateElasticSearchView = (_: UUID, _: Int, _: ElasticSearchViewValue) => IO.unit + val always: ValidateElasticSearchView = (_: UUID, _: IndexingRev, _: ElasticSearchViewValue) => IO.unit def apply( validatePipeChain: PipeChain => Either[ProjectionErr, Unit], @@ -63,7 +63,7 @@ object ValidateElasticSearchView { xas ) - private def validateIndexing(uuid: UUID, rev: Int, value: IndexingElasticSearchViewValue) = + private def validateIndexing(uuid: UUID, indexingRev: IndexingRev, value: IndexingElasticSearchViewValue) = for { defaultMapping <- defaultElasticsearchMapping defaultSettings <- defaultElasticsearchSettings @@ -72,7 +72,7 @@ object ValidateElasticSearchView { } _ <- IO.fromEither(value.pipeChain.traverse(validatePipeChain)).mapError(InvalidPipeline) _ <- createIndex( - IndexLabel.fromView(prefix, uuid, rev), + IndexLabel.fromView(prefix, uuid, indexingRev), value.mapping.orElse(Some(defaultMapping)), value.settings.orElse(Some(defaultSettings)) ) @@ -82,12 +82,16 @@ object ValidateElasticSearchView { } } yield () - override def apply(uuid: UUID, rev: Int, value: ElasticSearchViewValue): IO[ElasticSearchViewRejection, Unit] = + override def apply( + uuid: UUID, + indexingRev: IndexingRev, + value: ElasticSearchViewValue + ): IO[ElasticSearchViewRejection, Unit] = value match { case v: AggregateElasticSearchViewValue => validateAggregate(v.views) case v: IndexingElasticSearchViewValue => - validateIndexing(uuid, rev, v) + validateIndexing(uuid, indexingRev, v) } } diff --git a/delta/plugins/elasticsearch/src/main/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/client/IndexLabel.scala b/delta/plugins/elasticsearch/src/main/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/client/IndexLabel.scala index 94a36e3288..1550347f35 100644 --- a/delta/plugins/elasticsearch/src/main/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/client/IndexLabel.scala +++ b/delta/plugins/elasticsearch/src/main/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/client/IndexLabel.scala @@ -5,6 +5,7 @@ import ch.epfl.bluebrain.nexus.delta.kernel.error.FormatError import ch.epfl.bluebrain.nexus.delta.rdf.jsonld.ExpandedJsonLdCursor import ch.epfl.bluebrain.nexus.delta.rdf.jsonld.decoder.JsonLdDecoder import ch.epfl.bluebrain.nexus.delta.rdf.jsonld.decoder.JsonLdDecoderError.ParsingFailure +import ch.epfl.bluebrain.nexus.delta.sdk.views.IndexingRev import io.circe.{Decoder, Encoder} import java.util.UUID @@ -79,8 +80,8 @@ object IndexLabel { * @param indexingRev * the view's indexing revision */ - final def fromView(prefix: String, uuid: UUID, indexingRev: Int): IndexLabel = - new IndexLabel(s"${prefix}_${uuid}_$indexingRev") + final def fromView(prefix: String, uuid: UUID, indexingRev: IndexingRev): IndexLabel = + new IndexLabel(s"${prefix}_${uuid}_${indexingRev.value}") implicit val indexLabelJsonLdDecoder: JsonLdDecoder[IndexLabel] = (cursor: ExpandedJsonLdCursor) => diff --git a/delta/plugins/elasticsearch/src/main/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/indexing/IndexingViewDef.scala b/delta/plugins/elasticsearch/src/main/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/indexing/IndexingViewDef.scala index 6471ace817..f032ebbd65 100644 --- a/delta/plugins/elasticsearch/src/main/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/indexing/IndexingViewDef.scala +++ b/delta/plugins/elasticsearch/src/main/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/indexing/IndexingViewDef.scala @@ -8,7 +8,7 @@ import ch.epfl.bluebrain.nexus.delta.plugins.elasticsearch.model.{contexts, Elas import ch.epfl.bluebrain.nexus.delta.rdf.jsonld.context.ContextValue.ContextObject import ch.epfl.bluebrain.nexus.delta.rdf.jsonld.context.{ContextValue, RemoteContextResolution} import ch.epfl.bluebrain.nexus.delta.sdk.stream.GraphResourceStream -import ch.epfl.bluebrain.nexus.delta.sdk.views.ViewRef +import ch.epfl.bluebrain.nexus.delta.sdk.views.{IndexingRev, ViewRef} import ch.epfl.bluebrain.nexus.delta.sourcing.model.Tag.UserTag import ch.epfl.bluebrain.nexus.delta.sourcing.model.{ElemStream, Tag} import ch.epfl.bluebrain.nexus.delta.sourcing.offset.Offset @@ -48,7 +48,7 @@ object IndexingViewDef { mapping: JsonObject, settings: JsonObject, context: Option[ContextObject], - indexingRev: Int, + indexingRev: IndexingRev, rev: Int ) extends IndexingViewDef { diff --git a/delta/plugins/elasticsearch/src/main/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/model/ElasticSearchView.scala b/delta/plugins/elasticsearch/src/main/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/model/ElasticSearchView.scala index e4b6e7bb0c..fde5b2d5c2 100644 --- a/delta/plugins/elasticsearch/src/main/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/model/ElasticSearchView.scala +++ b/delta/plugins/elasticsearch/src/main/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/model/ElasticSearchView.scala @@ -126,10 +126,9 @@ object ElasticSearchView { context: Option[ContextObject], permission: Permission, tags: Tags, - source: Json, - indexingRev: Int + source: Json ) extends ElasticSearchView { - override def metadata: Metadata = Metadata(Some(uuid), Some(indexingRev)) + override def metadata: Metadata = Metadata(Some(uuid)) override def tpe: ElasticSearchViewType = ElasticSearchViewType.ElasticSearch } @@ -157,7 +156,7 @@ object ElasticSearchView { tags: Tags, source: Json ) extends ElasticSearchView { - override def metadata: Metadata = Metadata(None, None) + override def metadata: Metadata = Metadata(None) override def tpe: ElasticSearchViewType = ElasticSearchViewType.AggregateElasticSearch } @@ -169,7 +168,7 @@ object ElasticSearchView { * @param indexingRev * the optionally available indexing revision */ - final case class Metadata(uuid: Option[UUID], indexingRev: Option[Int]) + final case class Metadata(uuid: Option[UUID]) val context: ContextValue = ContextValue(contexts.elasticsearch) @@ -265,7 +264,6 @@ object ElasticSearchView { Encoder.encodeJsonObject.contramapObject(meta => JsonObject.empty .addIfExists("_uuid", meta.uuid) - .addIfExists("_indexingRev", meta.indexingRev) ) implicit val elasticSearchMetadataJsonLdEncoder: JsonLdEncoder[Metadata] = diff --git a/delta/plugins/elasticsearch/src/main/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/model/ElasticSearchViewState.scala b/delta/plugins/elasticsearch/src/main/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/model/ElasticSearchViewState.scala index d0d4b6e6a7..f86e197059 100644 --- a/delta/plugins/elasticsearch/src/main/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/model/ElasticSearchViewState.scala +++ b/delta/plugins/elasticsearch/src/main/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/model/ElasticSearchViewState.scala @@ -5,6 +5,7 @@ import ch.epfl.bluebrain.nexus.delta.plugins.elasticsearch.model.ElasticSearchVi import ch.epfl.bluebrain.nexus.delta.plugins.elasticsearch.model.ElasticSearchViewValue._ import ch.epfl.bluebrain.nexus.delta.rdf.IriOrBNode.Iri import ch.epfl.bluebrain.nexus.delta.sdk.model.{ResourceF, ResourceUris, Tags} +import ch.epfl.bluebrain.nexus.delta.sdk.views.IndexingRev import ch.epfl.bluebrain.nexus.delta.sourcing.Serializer import ch.epfl.bluebrain.nexus.delta.sourcing.model.Identity.Subject import ch.epfl.bluebrain.nexus.delta.sourcing.model.{ProjectRef, ResourceRef} @@ -55,7 +56,7 @@ final case class ElasticSearchViewState( source: Json, tags: Tags, rev: Int, - indexingRev: Int, + indexingRev: IndexingRev, deprecated: Boolean, createdAt: Instant, createdBy: Subject, @@ -94,8 +95,7 @@ final case class ElasticSearchViewState( context = context, permission = permission, tags = tags, - source = source, - indexingRev = indexingRev + source = source ) case AggregateElasticSearchViewValue(name, description, views) => AggregateElasticSearchView( diff --git a/delta/plugins/elasticsearch/src/main/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/model/ElasticSearchViewValue.scala b/delta/plugins/elasticsearch/src/main/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/model/ElasticSearchViewValue.scala index 17fb483c0e..ce3d2e9361 100644 --- a/delta/plugins/elasticsearch/src/main/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/model/ElasticSearchViewValue.scala +++ b/delta/plugins/elasticsearch/src/main/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/model/ElasticSearchViewValue.scala @@ -1,5 +1,6 @@ package ch.epfl.bluebrain.nexus.delta.plugins.elasticsearch.model +import cats.syntax.all._ import cats.data.{NonEmptyChain, NonEmptySet} import ch.epfl.bluebrain.nexus.delta.plugins.elasticsearch.model.ElasticSearchViewValue.IndexingElasticSearchViewValue import ch.epfl.bluebrain.nexus.delta.plugins.elasticsearch.model.ElasticSearchViewValue.IndexingElasticSearchViewValue.defaultPipeline @@ -8,7 +9,7 @@ import ch.epfl.bluebrain.nexus.delta.rdf.jsonld.ExpandedJsonLd import ch.epfl.bluebrain.nexus.delta.rdf.jsonld.context.ContextValue.ContextObject import ch.epfl.bluebrain.nexus.delta.rdf.jsonld.context.JsonLdContext.keywords import ch.epfl.bluebrain.nexus.delta.sdk.permissions.model.Permission -import ch.epfl.bluebrain.nexus.delta.sdk.views.{PipeStep, ViewRef} +import ch.epfl.bluebrain.nexus.delta.sdk.views.{IndexingRev, PipeStep, ViewRef} import ch.epfl.bluebrain.nexus.delta.sourcing.model.Tag.UserTag import ch.epfl.bluebrain.nexus.delta.sourcing.stream.pipes.{DefaultLabelPredicates, DiscardMetadata, FilterDeprecated} import ch.epfl.bluebrain.nexus.delta.sourcing.stream.{PipeChain, PipeRef} @@ -135,12 +136,17 @@ object ElasticSearchViewValue { * the next indexing revision based on the differences between the given views */ def nextIndexingRev( - view1: IndexingElasticSearchViewValue, - view2: IndexingElasticSearchViewValue, - currentRev: Int - ): Int = - if (!view1.hasSameIndexingFields(view2)) currentRev + 1 - else currentRev + view1: ElasticSearchViewValue, + view2: ElasticSearchViewValue, + currentIndexingRev: IndexingRev, + newEventRev: Int + ): IndexingRev = + (view1.asIndexingValue, view2.asIndexingValue) + .mapN { case (v1, v2) => + if (!v1.hasSameIndexingFields(v2)) IndexingRev(newEventRev) + else currentIndexingRev + } + .getOrElse(currentIndexingRev) } /** diff --git a/delta/plugins/elasticsearch/src/test/resources/jsonld/indexing-view-compacted-1.json b/delta/plugins/elasticsearch/src/test/resources/jsonld/indexing-view-compacted-1.json index 59ddb9851e..00ba2aea7e 100644 --- a/delta/plugins/elasticsearch/src/test/resources/jsonld/indexing-view-compacted-1.json +++ b/delta/plugins/elasticsearch/src/test/resources/jsonld/indexing-view-compacted-1.json @@ -42,7 +42,6 @@ ], "sourceAsText": true, "_uuid": "f85d862a-9ec0-4b9a-8aed-2938d7ca9981", - "_indexingRev": 1, "mapping": { "properties": { "@type": { diff --git a/delta/plugins/elasticsearch/src/test/resources/jsonld/indexing-view-compacted-2.json b/delta/plugins/elasticsearch/src/test/resources/jsonld/indexing-view-compacted-2.json index 08fed4ab10..c05e62bbe9 100644 --- a/delta/plugins/elasticsearch/src/test/resources/jsonld/indexing-view-compacted-2.json +++ b/delta/plugins/elasticsearch/src/test/resources/jsonld/indexing-view-compacted-2.json @@ -24,7 +24,6 @@ "resourceTypes": [], "sourceAsText": false, "_uuid": "f85d862a-9ec0-4b9a-8aed-2938d7ca9981", - "_indexingRev": 1, "mapping": { "properties": { "@type": { diff --git a/delta/plugins/elasticsearch/src/test/resources/jsonld/indexing-view-compacted-3.json b/delta/plugins/elasticsearch/src/test/resources/jsonld/indexing-view-compacted-3.json index 6771e48886..37b31dc494 100644 --- a/delta/plugins/elasticsearch/src/test/resources/jsonld/indexing-view-compacted-3.json +++ b/delta/plugins/elasticsearch/src/test/resources/jsonld/indexing-view-compacted-3.json @@ -17,7 +17,6 @@ "resourceTypes": [], "sourceAsText": false, "_uuid": "f85d862a-9ec0-4b9a-8aed-2938d7ca9981", - "_indexingRev": 1, "mapping": { "properties": { "@type": { diff --git a/delta/plugins/elasticsearch/src/test/resources/jsonld/indexing-view-expanded.json b/delta/plugins/elasticsearch/src/test/resources/jsonld/indexing-view-expanded.json index ddf2ec6495..e547d3fc2a 100644 --- a/delta/plugins/elasticsearch/src/test/resources/jsonld/indexing-view-expanded.json +++ b/delta/plugins/elasticsearch/src/test/resources/jsonld/indexing-view-expanded.json @@ -120,11 +120,6 @@ "@value": "f85d862a-9ec0-4b9a-8aed-2938d7ca9981" } ], - "https://bluebrain.github.io/nexus/vocabulary/indexingRev" : [ - { - "@value" : 1 - } - ], "@id": "https://bluebrain.github.io/nexus/vocabulary/myview" } ] \ No newline at end of file diff --git a/delta/plugins/elasticsearch/src/test/resources/routes/elasticsearch-view-read-response.json b/delta/plugins/elasticsearch/src/test/resources/routes/elasticsearch-view-read-response.json index c05d2b38cd..f4be44f2e7 100644 --- a/delta/plugins/elasticsearch/src/test/resources/routes/elasticsearch-view-read-response.json +++ b/delta/plugins/elasticsearch/src/test/resources/routes/elasticsearch-view-read-response.json @@ -16,7 +16,6 @@ "_outgoing" : "{{self}}/outgoing", "_project" : "http://localhost/v1/projects/{{project}}", "_rev" : {{rev}}, - "_indexingRev": {{indexingRev}}, "_self" : "{{self}}", "_updatedAt" : "1970-01-01T00:00:00Z", "_updatedBy" : "{{updatedBy}}", diff --git a/delta/plugins/elasticsearch/src/test/resources/routes/elasticsearch-view-write-response.json b/delta/plugins/elasticsearch/src/test/resources/routes/elasticsearch-view-write-response.json index 4fd090022b..ee0f3d8d6e 100644 --- a/delta/plugins/elasticsearch/src/test/resources/routes/elasticsearch-view-write-response.json +++ b/delta/plugins/elasticsearch/src/test/resources/routes/elasticsearch-view-write-response.json @@ -14,7 +14,6 @@ "_outgoing" : "{{self}}/outgoing", "_project" : "http://localhost/v1/projects/{{project}}", "_rev" : {{rev}}, - "_indexingRev": {{indexingRev}}, "_self" : "{{self}}", "_updatedAt" : "1970-01-01T00:00:00Z", "_updatedBy" : "{{updatedBy}}" diff --git a/delta/plugins/elasticsearch/src/test/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/ElasticSearchIndexingActionSuite.scala b/delta/plugins/elasticsearch/src/test/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/ElasticSearchIndexingActionSuite.scala index ea54e87aac..3afe870786 100644 --- a/delta/plugins/elasticsearch/src/test/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/ElasticSearchIndexingActionSuite.scala +++ b/delta/plugins/elasticsearch/src/test/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/ElasticSearchIndexingActionSuite.scala @@ -8,7 +8,7 @@ import ch.epfl.bluebrain.nexus.delta.rdf.IriOrBNode.Iri import ch.epfl.bluebrain.nexus.delta.rdf.Vocabulary.nxv import ch.epfl.bluebrain.nexus.delta.rdf.jsonld.ExpandedJsonLd import ch.epfl.bluebrain.nexus.delta.sdk.syntax._ -import ch.epfl.bluebrain.nexus.delta.sdk.views.ViewRef +import ch.epfl.bluebrain.nexus.delta.sdk.views.{IndexingRev, ViewRef} import ch.epfl.bluebrain.nexus.delta.sourcing.PullRequest import ch.epfl.bluebrain.nexus.delta.sourcing.PullRequest.PullRequestState import ch.epfl.bluebrain.nexus.delta.sourcing.PullRequest.PullRequestState.PullRequestActive @@ -33,7 +33,7 @@ class ElasticSearchIndexingActionSuite extends BioSuite with CirceLiteral with F private val instant = Instant.EPOCH - private val indexingRev = 1 + private val indexingRev = IndexingRev.init private val rev = 2 private val project = ProjectRef.unsafe("org", "proj") diff --git a/delta/plugins/elasticsearch/src/test/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/ElasticSearchViewGen.scala b/delta/plugins/elasticsearch/src/test/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/ElasticSearchViewGen.scala index 5d8690ab68..35149c6b38 100644 --- a/delta/plugins/elasticsearch/src/test/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/ElasticSearchViewGen.scala +++ b/delta/plugins/elasticsearch/src/test/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/ElasticSearchViewGen.scala @@ -3,6 +3,7 @@ package ch.epfl.bluebrain.nexus.delta.plugins.elasticsearch import ch.epfl.bluebrain.nexus.delta.plugins.elasticsearch.model.{ElasticSearchViewState, ElasticSearchViewValue, ViewResource} import ch.epfl.bluebrain.nexus.delta.rdf.IriOrBNode.Iri import ch.epfl.bluebrain.nexus.delta.sdk.model.Tags +import ch.epfl.bluebrain.nexus.delta.sdk.views.IndexingRev import ch.epfl.bluebrain.nexus.delta.sourcing.model.Identity.{Anonymous, Subject} import ch.epfl.bluebrain.nexus.delta.sourcing.model.ProjectRef import io.circe.{Json, JsonObject} @@ -19,7 +20,7 @@ object ElasticSearchViewGen { uuid: UUID = UUID.randomUUID(), source: Json = Json.obj(), rev: Int = 1, - indexingRev: Int = 1, + indexingRev: IndexingRev = IndexingRev.init, deprecated: Boolean = false, tags: Tags = Tags.empty, createdBy: Subject = Anonymous, @@ -48,7 +49,7 @@ object ElasticSearchViewGen { uuid: UUID = UUID.randomUUID(), source: Json = Json.obj(), rev: Int = 1, - indexingRev: Int = 1, + indexingRev: IndexingRev = IndexingRev.init, deprecated: Boolean = false, tags: Tags = Tags.empty, createdBy: Subject = Anonymous, diff --git a/delta/plugins/elasticsearch/src/test/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/ElasticSearchViewSTMSpec.scala b/delta/plugins/elasticsearch/src/test/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/ElasticSearchViewSTMSpec.scala index e91eeb45fe..da58b76174 100644 --- a/delta/plugins/elasticsearch/src/test/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/ElasticSearchViewSTMSpec.scala +++ b/delta/plugins/elasticsearch/src/test/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/ElasticSearchViewSTMSpec.scala @@ -13,7 +13,7 @@ import ch.epfl.bluebrain.nexus.delta.rdf.IriOrBNode.Iri import ch.epfl.bluebrain.nexus.delta.rdf.syntax._ import ch.epfl.bluebrain.nexus.delta.sdk.model.Tags import ch.epfl.bluebrain.nexus.delta.sdk.permissions.model.Permission -import ch.epfl.bluebrain.nexus.delta.sdk.views.ViewRef +import ch.epfl.bluebrain.nexus.delta.sdk.views.{IndexingRev, ViewRef} import ch.epfl.bluebrain.nexus.delta.sourcing.model.Identity.{Anonymous, Subject, User} import ch.epfl.bluebrain.nexus.delta.sourcing.model.Tag.UserTag import ch.epfl.bluebrain.nexus.delta.sourcing.model.{Label, ProjectRef} @@ -62,7 +62,7 @@ class ElasticSearchViewSTMSpec // format: on val invalidView: ValidateElasticSearchView = - (_: UUID, _: Int, _: ElasticSearchViewValue) => IO.raiseError(InvalidElasticSearchIndexPayload(None)) + (_: UUID, _: IndexingRev, _: ElasticSearchViewValue) => IO.raiseError(InvalidElasticSearchIndexPayload(None)) def current( id: Iri = id, @@ -72,7 +72,7 @@ class ElasticSearchViewSTMSpec source: Json = source, tags: Tags = Tags.empty, rev: Int = 1, - indexingRev: Int = 1, + indexingRev: IndexingRev = IndexingRev.init, deprecated: Boolean = false, createdAt: Instant = epoch, createdBy: Subject = Anonymous, @@ -248,7 +248,7 @@ class ElasticSearchViewSTMSpec value = indexingValueWithUserTag, source = source2, rev = 2, - indexingRev = 2, + indexingRev = IndexingRev(2), updatedAt = epochPlus10, updatedBy = subject ) diff --git a/delta/plugins/elasticsearch/src/test/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/ElasticSearchViewValueSuite.scala b/delta/plugins/elasticsearch/src/test/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/ElasticSearchViewValueSuite.scala index 440a375b8a..692bd65d1a 100644 --- a/delta/plugins/elasticsearch/src/test/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/ElasticSearchViewValueSuite.scala +++ b/delta/plugins/elasticsearch/src/test/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/ElasticSearchViewValueSuite.scala @@ -4,7 +4,7 @@ import ch.epfl.bluebrain.nexus.delta.plugins.elasticsearch.model.ElasticSearchVi import ch.epfl.bluebrain.nexus.delta.plugins.elasticsearch.model.ElasticSearchViewValue.IndexingElasticSearchViewValue.nextIndexingRev import ch.epfl.bluebrain.nexus.delta.plugins.elasticsearch.model.permissions import ch.epfl.bluebrain.nexus.delta.rdf.jsonld.context.ContextValue.ContextObject -import ch.epfl.bluebrain.nexus.delta.sdk.views.PipeStep +import ch.epfl.bluebrain.nexus.delta.sdk.views.{IndexingRev, PipeStep} import ch.epfl.bluebrain.nexus.delta.sourcing.model.Tag.UserTag import ch.epfl.bluebrain.nexus.delta.sourcing.stream.pipes.FilterDeprecated import io.circe.JsonObject @@ -21,7 +21,8 @@ class ElasticSearchViewValueSuite extends FunSuite { IndexingElasticSearchViewValue(Some("name"), Some("description")), viewValue.copy(permission = permissions.read) ) - viewValues.foreach(v => assertEquals(nextIndexingRev(v, viewValue, 1), 1)) + val expected = IndexingRev.init + viewValues.foreach(v => assertEquals(nextIndexingRev(v, viewValue, IndexingRev.init, 2), expected)) } test("Views with different reindexing fields") { @@ -32,7 +33,8 @@ class ElasticSearchViewValueSuite extends FunSuite { viewValue.copy(settings = Some(JsonObject.empty)), viewValue.copy(context = Some(ContextObject.apply(JsonObject.empty))) ) - viewValues.foreach(v => assertEquals(nextIndexingRev(v, viewValue, 1), 2)) + val expected = IndexingRev(2) + viewValues.foreach(v => assertEquals(nextIndexingRev(v, viewValue, IndexingRev.init, 2), expected)) } } diff --git a/delta/plugins/elasticsearch/src/test/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/ElasticSearchViewsSpec.scala b/delta/plugins/elasticsearch/src/test/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/ElasticSearchViewsSpec.scala index 409d31b355..c82e022787 100644 --- a/delta/plugins/elasticsearch/src/test/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/ElasticSearchViewsSpec.scala +++ b/delta/plugins/elasticsearch/src/test/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/ElasticSearchViewsSpec.scala @@ -16,7 +16,7 @@ import ch.epfl.bluebrain.nexus.delta.sdk.model._ import ch.epfl.bluebrain.nexus.delta.sdk.projects.FetchContextDummy import ch.epfl.bluebrain.nexus.delta.sdk.projects.model.{ApiMappings, Project} import ch.epfl.bluebrain.nexus.delta.sdk.resolvers.ResolverContextResolution -import ch.epfl.bluebrain.nexus.delta.sdk.views.{PipeStep, ViewRef} +import ch.epfl.bluebrain.nexus.delta.sdk.views.{IndexingRev, PipeStep, ViewRef} import ch.epfl.bluebrain.nexus.delta.sourcing.EntityDependencyStore import ch.epfl.bluebrain.nexus.delta.sourcing.model.EntityDependency.DependsOn import ch.epfl.bluebrain.nexus.delta.sourcing.model.Identity.{Group, Subject, User} @@ -74,7 +74,7 @@ class ElasticSearchViewsSpec project: Project, uuid: UUID, rev: Int, - indexingRev: Int, + indexingRev: IndexingRev, deprecated: Boolean, createdAt: Instant, createdBy: Subject, @@ -105,7 +105,7 @@ class ElasticSearchViewsSpec project: Project = project, uuid: UUID = uuid, rev: Int = 1, - indexingRev: Int = 1, + indexingRev: IndexingRev = IndexingRev.init, deprecated: Boolean = false, createdAt: Instant = Instant.EPOCH, createdBy: Subject = alice.subject, diff --git a/delta/plugins/elasticsearch/src/test/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/deletion/ElasticSearchDeletionTaskSuite.scala b/delta/plugins/elasticsearch/src/test/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/deletion/ElasticSearchDeletionTaskSuite.scala index 69e413bffa..0d2048d131 100644 --- a/delta/plugins/elasticsearch/src/test/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/deletion/ElasticSearchDeletionTaskSuite.scala +++ b/delta/plugins/elasticsearch/src/test/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/deletion/ElasticSearchDeletionTaskSuite.scala @@ -5,7 +5,7 @@ import ch.epfl.bluebrain.nexus.delta.plugins.elasticsearch.client.IndexLabel import ch.epfl.bluebrain.nexus.delta.plugins.elasticsearch.indexing.IndexingViewDef import ch.epfl.bluebrain.nexus.delta.plugins.elasticsearch.indexing.IndexingViewDef.{ActiveViewDef, DeprecatedViewDef} import ch.epfl.bluebrain.nexus.delta.rdf.Vocabulary.nxv -import ch.epfl.bluebrain.nexus.delta.sdk.views.ViewRef +import ch.epfl.bluebrain.nexus.delta.sdk.views.{IndexingRev, ViewRef} import ch.epfl.bluebrain.nexus.delta.sourcing.model.Identity.{Anonymous, Subject} import ch.epfl.bluebrain.nexus.delta.sourcing.model.ProjectRef import ch.epfl.bluebrain.nexus.testkit.CirceLiteral @@ -18,7 +18,7 @@ class ElasticSearchDeletionTaskSuite extends BioSuite with CirceLiteral { implicit private val subject: Subject = Anonymous private val project = ProjectRef.unsafe("org", "proj") - private val indexingRev = 1 + private val indexingRev = IndexingRev.init private val rev = 2 private val active1 = ViewRef(project, nxv + "active1") diff --git a/delta/plugins/elasticsearch/src/test/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/indexing/ElasticSearchCoordinatorSuite.scala b/delta/plugins/elasticsearch/src/test/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/indexing/ElasticSearchCoordinatorSuite.scala index e9616792f0..391c8c88be 100644 --- a/delta/plugins/elasticsearch/src/test/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/indexing/ElasticSearchCoordinatorSuite.scala +++ b/delta/plugins/elasticsearch/src/test/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/indexing/ElasticSearchCoordinatorSuite.scala @@ -6,7 +6,7 @@ import ch.epfl.bluebrain.nexus.delta.plugins.elasticsearch.{ElasticSearchViews, import ch.epfl.bluebrain.nexus.delta.rdf.Vocabulary.nxv import ch.epfl.bluebrain.nexus.delta.rdf.jsonld.ExpandedJsonLd import ch.epfl.bluebrain.nexus.delta.sdk.stream.GraphResourceStream -import ch.epfl.bluebrain.nexus.delta.sdk.views.ViewRef +import ch.epfl.bluebrain.nexus.delta.sdk.views.{IndexingRev, ViewRef} import ch.epfl.bluebrain.nexus.delta.sourcing.PullRequest import ch.epfl.bluebrain.nexus.delta.sourcing.model.{ElemStream, ProjectRef} import ch.epfl.bluebrain.nexus.delta.sourcing.offset.Offset @@ -32,7 +32,7 @@ class ElasticSearchCoordinatorSuite extends BioSuite with SupervisorSetup.Fixtur implicit private val patienceConfig: PatienceConfig = PatienceConfig(5.seconds, 10.millis) - private val indexingRev = 1 + private val indexingRev = IndexingRev.init private val rev = 2 private lazy val (sv, projections, projectionErrors) = unapply(supervisor()) diff --git a/delta/plugins/elasticsearch/src/test/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/indexing/IndexingViewDefSuite.scala b/delta/plugins/elasticsearch/src/test/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/indexing/IndexingViewDefSuite.scala index 4516b39748..2bdf6f9c62 100644 --- a/delta/plugins/elasticsearch/src/test/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/indexing/IndexingViewDefSuite.scala +++ b/delta/plugins/elasticsearch/src/test/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/indexing/IndexingViewDefSuite.scala @@ -12,7 +12,7 @@ import ch.epfl.bluebrain.nexus.delta.rdf.jsonld.context.ContextValue.ContextObje import ch.epfl.bluebrain.nexus.delta.sdk.model.Tags import ch.epfl.bluebrain.nexus.delta.sdk.permissions.model.Permission import ch.epfl.bluebrain.nexus.delta.sdk.stream.GraphResourceStream -import ch.epfl.bluebrain.nexus.delta.sdk.views.{PipeStep, ViewRef} +import ch.epfl.bluebrain.nexus.delta.sdk.views.{IndexingRev, PipeStep, ViewRef} import ch.epfl.bluebrain.nexus.delta.sourcing.config.BatchConfig import ch.epfl.bluebrain.nexus.delta.sourcing.model.Identity.{Anonymous, Subject} import ch.epfl.bluebrain.nexus.delta.sourcing.model.ProjectRef @@ -78,7 +78,7 @@ class IndexingViewDefSuite extends BioSuite with CirceLiteral with Fixtures { private val aggregate = AggregateElasticSearchViewValue(NonEmptySet.of(viewRef)) private val sink = CacheSink.states[Json] - private val indexingRev = 1 + private val indexingRev = IndexingRev.init private val rev = 2 private def state(v: ElasticSearchViewValue) = ElasticSearchViewState( @@ -103,7 +103,7 @@ class IndexingViewDefSuite extends BioSuite with CirceLiteral with Fixtures { Some( ActiveViewDef( viewRef, - s"elasticsearch-$projectRef-$id-$indexingRev", + s"elasticsearch-$projectRef-$id-${indexingRev.value}", indexingCustom.resourceTag, indexingCustom.pipeChain, IndexLabel.fromView("prefix", uuid, indexingRev), @@ -123,7 +123,7 @@ class IndexingViewDefSuite extends BioSuite with CirceLiteral with Fixtures { Some( ActiveViewDef( viewRef, - s"elasticsearch-$projectRef-$id-$indexingRev", + s"elasticsearch-$projectRef-$id-${indexingRev.value}", indexingDefault.resourceTag, indexingDefault.pipeChain, IndexLabel.fromView("prefix", uuid, indexingRev), diff --git a/delta/plugins/elasticsearch/src/test/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/model/ElasticSearchViewSerializationSuite.scala b/delta/plugins/elasticsearch/src/test/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/model/ElasticSearchViewSerializationSuite.scala index 804372b35d..4a11454e95 100644 --- a/delta/plugins/elasticsearch/src/test/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/model/ElasticSearchViewSerializationSuite.scala +++ b/delta/plugins/elasticsearch/src/test/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/model/ElasticSearchViewSerializationSuite.scala @@ -12,7 +12,7 @@ import ch.epfl.bluebrain.nexus.delta.sdk.model.Tags import ch.epfl.bluebrain.nexus.delta.sdk.model.metrics.EventMetric._ import ch.epfl.bluebrain.nexus.delta.sdk.permissions.model.Permission import ch.epfl.bluebrain.nexus.delta.sdk.sse.SseEncoder.SseData -import ch.epfl.bluebrain.nexus.delta.sdk.views.{PipeStep, ViewRef} +import ch.epfl.bluebrain.nexus.delta.sdk.views.{IndexingRev, PipeStep, ViewRef} import ch.epfl.bluebrain.nexus.delta.sourcing.model.Identity.{Subject, User} import ch.epfl.bluebrain.nexus.delta.sourcing.model.Tag.UserTag import ch.epfl.bluebrain.nexus.delta.sourcing.model.{Label, ProjectRef} @@ -125,7 +125,7 @@ class ElasticSearchViewSerializationSuite extends SerializationSuite { Json.obj("elastic" -> Json.fromString("value")), Tags(tag -> 3), rev = 1, - indexingRev = 1, + indexingRev = IndexingRev.init, deprecated = false, createdAt = instant, createdBy = subject, diff --git a/delta/plugins/elasticsearch/src/test/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/model/ElasticSearchViewSpec.scala b/delta/plugins/elasticsearch/src/test/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/model/ElasticSearchViewSpec.scala index 0bfe80b987..2992fd1c92 100644 --- a/delta/plugins/elasticsearch/src/test/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/model/ElasticSearchViewSpec.scala +++ b/delta/plugins/elasticsearch/src/test/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/model/ElasticSearchViewSpec.scala @@ -50,8 +50,7 @@ class ElasticSearchViewSpec context = Some(ContextObject(jobj"""{"@vocab": "http://schema.org/"}""")), perm, tagsMap, - source, - 1 + source ) "be converted to compacted Json-LD" in { forAll( diff --git a/delta/plugins/elasticsearch/src/test/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/routes/ElasticSearchIndexingRoutesSpec.scala b/delta/plugins/elasticsearch/src/test/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/routes/ElasticSearchIndexingRoutesSpec.scala index ea23e3df34..7063fe2415 100644 --- a/delta/plugins/elasticsearch/src/test/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/routes/ElasticSearchIndexingRoutesSpec.scala +++ b/delta/plugins/elasticsearch/src/test/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/routes/ElasticSearchIndexingRoutesSpec.scala @@ -18,7 +18,7 @@ import ch.epfl.bluebrain.nexus.delta.sdk.model.IdSegment.{IriSegment, StringSegm import ch.epfl.bluebrain.nexus.delta.sdk.permissions.Permissions.events import ch.epfl.bluebrain.nexus.delta.sdk.projects.{FetchContext, FetchContextDummy} import ch.epfl.bluebrain.nexus.delta.sdk.resolvers.ResolverContextResolution -import ch.epfl.bluebrain.nexus.delta.sdk.views.ViewRef +import ch.epfl.bluebrain.nexus.delta.sdk.views.{IndexingRev, ViewRef} import ch.epfl.bluebrain.nexus.delta.sourcing.model.EntityType import ch.epfl.bluebrain.nexus.delta.sourcing.model.Identity.Anonymous import ch.epfl.bluebrain.nexus.delta.sourcing.offset.Offset @@ -61,7 +61,7 @@ class ElasticSearchIndexingRoutesSpec extends ElasticSearchViewsRoutesFixtures { JsonObject.empty, JsonObject.empty, None, - 1, + IndexingRev.init, 1 ) private val progress = ProjectionProgress(Offset.at(15L), Instant.EPOCH, 9000L, 400L, 30L) diff --git a/delta/plugins/elasticsearch/src/test/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/routes/ElasticSearchViewsRoutesSpec.scala b/delta/plugins/elasticsearch/src/test/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/routes/ElasticSearchViewsRoutesSpec.scala index 06b15e3123..231cb91f6a 100644 --- a/delta/plugins/elasticsearch/src/test/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/routes/ElasticSearchViewsRoutesSpec.scala +++ b/delta/plugins/elasticsearch/src/test/scala/ch/epfl/bluebrain/nexus/delta/plugins/elasticsearch/routes/ElasticSearchViewsRoutesSpec.scala @@ -257,8 +257,6 @@ class ElasticSearchViewsRoutesSpec extends ElasticSearchViewsRoutesFixtures { myId, includeDeprecated = false, rev = 4, - // indexing rev stays one as the update concerned non-indexing fields - indexingRev = 1, deprecated = true ) } @@ -365,29 +363,26 @@ class ElasticSearchViewsRoutesSpec extends ElasticSearchViewsRoutesFixtures { private def elasticSearchViewMetadata( id: Iri, rev: Int = 1, - indexingRev: Int = 1, deprecated: Boolean = false, createdBy: Subject = Anonymous, updatedBy: Subject = Anonymous ): Json = jsonContentOf( "/routes/elasticsearch-view-write-response.json", - "project" -> projectRef, - "id" -> id, - "rev" -> rev, - "indexingRev" -> indexingRev, - "uuid" -> uuid, - "deprecated" -> deprecated, - "createdBy" -> createdBy.asIri, - "updatedBy" -> updatedBy.asIri, - "self" -> ResourceUris("views", projectRef, id).accessUri + "project" -> projectRef, + "id" -> id, + "rev" -> rev, + "uuid" -> uuid, + "deprecated" -> deprecated, + "createdBy" -> createdBy.asIri, + "updatedBy" -> updatedBy.asIri, + "self" -> ResourceUris("views", projectRef, id).accessUri ) private def elasticSearchView( id: Iri, includeDeprecated: Boolean = false, rev: Int = 1, - indexingRev: Int = 1, deprecated: Boolean = false, createdBy: Subject = Anonymous, updatedBy: Subject = Anonymous @@ -398,7 +393,6 @@ class ElasticSearchViewsRoutesSpec extends ElasticSearchViewsRoutesFixtures { "id" -> id, "rev" -> rev, "uuid" -> uuid, - "indexingRev" -> indexingRev, "deprecated" -> deprecated, "createdBy" -> createdBy.asIri, "updatedBy" -> updatedBy.asIri, diff --git a/tests/src/test/resources/kg/listings/default-view.json b/tests/src/test/resources/kg/listings/default-view.json index b5482ce768..09289af78a 100644 --- a/tests/src/test/resources/kg/listings/default-view.json +++ b/tests/src/test/resources/kg/listings/default-view.json @@ -18,7 +18,6 @@ "_constrainedBy": "https://bluebrain.github.io/nexus/schemas/views.json", "_project": "{{project}}", "_rev": 1, - "_indexingRev" : 1, "_deprecated": false, "_createdBy": "{{deltaUri}}/realms/{{realm}}/users/{{user}}", "_updatedBy": "{{deltaUri}}/realms/{{realm}}/users/{{user}}", diff --git a/tests/src/test/resources/kg/views/elasticsearch/indexing-response.json b/tests/src/test/resources/kg/views/elasticsearch/indexing-response.json index b6c0476af4..81ba088a67 100644 --- a/tests/src/test/resources/kg/views/elasticsearch/indexing-response.json +++ b/tests/src/test/resources/kg/views/elasticsearch/indexing-response.json @@ -14,7 +14,6 @@ "_outgoing" : "{{self}}/outgoing", "_project" : "{{deltaUri}}/projects/{{project}}", "_rev" : 1, - "_indexingRev": 1, "_self" : "{{self}}", "_createdBy" : "{{deltaUri}}/realms/{{realm}}/users/{{user}}", "_updatedBy" : "{{deltaUri}}/realms/{{realm}}/users/{{user}}", diff --git a/tests/src/test/scala/ch/epfl/bluebrain/nexus/tests/kg/SearchConfigSpec.scala b/tests/src/test/scala/ch/epfl/bluebrain/nexus/tests/kg/SearchConfigSpec.scala index b209dc2df5..6f2203447e 100644 --- a/tests/src/test/scala/ch/epfl/bluebrain/nexus/tests/kg/SearchConfigSpec.scala +++ b/tests/src/test/scala/ch/epfl/bluebrain/nexus/tests/kg/SearchConfigSpec.scala @@ -345,7 +345,7 @@ class SearchConfigSpec extends BaseSpec { } "have curated field true if curated" in { - val query = queryField(curatedTraceId, "curated") + val query = queryField(curatedTraceId, "curated") assertOneSource(query) { json => json shouldBe json"""{ "curated": true }""" @@ -353,7 +353,7 @@ class SearchConfigSpec extends BaseSpec { } "have curated field false if unassessed" in { - val query = queryField(unassessedTraceId, "curated") + val query = queryField(unassessedTraceId, "curated") assertOneSource(query) { json => json shouldBe json"""{ "curated": false }"""