From 9c52a1991f2732fdb763407390213312115867a4 Mon Sep 17 00:00:00 2001 From: Andrzej Liszka Date: Thu, 4 Jul 2024 15:24:10 +0200 Subject: [PATCH] adds support for indexRangeFilters property setting --- .../client/v1/schema/model/Property.java | 2 + .../client/WeaviateDockerImage.java | 2 +- .../integration/client/WeaviateVersion.java | 6 +- .../ClientSchemaDefaultsAndMigrationTest.java | 863 +++++++++++++++--- .../client/schema/ClientSchemaTest.java | 2 +- 5 files changed, 757 insertions(+), 118 deletions(-) diff --git a/src/main/java/io/weaviate/client/v1/schema/model/Property.java b/src/main/java/io/weaviate/client/v1/schema/model/Property.java index f287613b..0e38d6c6 100644 --- a/src/main/java/io/weaviate/client/v1/schema/model/Property.java +++ b/src/main/java/io/weaviate/client/v1/schema/model/Property.java @@ -27,6 +27,7 @@ public class Property { Boolean indexInverted; Boolean indexFilterable; Boolean indexSearchable; + Boolean indexRangeFilters; Object moduleConfig; List nestedProperties; @@ -43,6 +44,7 @@ public static class NestedProperty { String tokenization; Boolean indexFilterable; Boolean indexSearchable; + Boolean indexRangeFilters; List nestedProperties; } } diff --git a/src/test/java/io/weaviate/integration/client/WeaviateDockerImage.java b/src/test/java/io/weaviate/integration/client/WeaviateDockerImage.java index 6a6193ae..f7b65399 100644 --- a/src/test/java/io/weaviate/integration/client/WeaviateDockerImage.java +++ b/src/test/java/io/weaviate/integration/client/WeaviateDockerImage.java @@ -2,6 +2,6 @@ public class WeaviateDockerImage { - public static final String WEAVIATE_DOCKER_IMAGE = String.format("semitechnologies/weaviate:%s", WeaviateVersion.EXPECTED_WEAVIATE_VERSION); + public static final String WEAVIATE_DOCKER_IMAGE = String.format("semitechnologies/weaviate:%s", WeaviateVersion.WEAVIATE_IMAGE); } diff --git a/src/test/java/io/weaviate/integration/client/WeaviateVersion.java b/src/test/java/io/weaviate/integration/client/WeaviateVersion.java index 3165af57..57b44da6 100644 --- a/src/test/java/io/weaviate/integration/client/WeaviateVersion.java +++ b/src/test/java/io/weaviate/integration/client/WeaviateVersion.java @@ -2,10 +2,12 @@ public class WeaviateVersion { + public static final String WEAVIATE_IMAGE = "preview-range-roaring-set-index-rename-indexrangeble-to-indexrangefilters-1083432"; + // to be set according to weaviate docker image - public static final String EXPECTED_WEAVIATE_VERSION = "1.25.1"; + public static final String EXPECTED_WEAVIATE_VERSION = "1.26.0-rc.0"; // to be set according to weaviate docker image - public static final String EXPECTED_WEAVIATE_GIT_HASH = "2fc82d0"; + public static final String EXPECTED_WEAVIATE_GIT_HASH = "1083432"; private WeaviateVersion() {} } diff --git a/src/test/java/io/weaviate/integration/client/schema/ClientSchemaDefaultsAndMigrationTest.java b/src/test/java/io/weaviate/integration/client/schema/ClientSchemaDefaultsAndMigrationTest.java index 54242bb1..302017f6 100644 --- a/src/test/java/io/weaviate/integration/client/schema/ClientSchemaDefaultsAndMigrationTest.java +++ b/src/test/java/io/weaviate/integration/client/schema/ClientSchemaDefaultsAndMigrationTest.java @@ -12,8 +12,11 @@ import io.weaviate.client.v1.schema.model.Tokenization; import io.weaviate.client.v1.schema.model.WeaviateClass; import io.weaviate.integration.client.WeaviateDockerCompose; + import java.util.Collections; + import static org.assertj.core.api.Assertions.assertThat; + import org.junit.After; import org.junit.Before; import org.junit.ClassRule; @@ -262,9 +265,11 @@ public static Object[][] provideInvalidForDataTypeAndTokenization() { @DataMethod(source = ClientSchemaDefaultsAndMigrationTest.class, method = "provideForDataTypeAndIndexing") @Test - public void shouldCreatePropertyWithDataTypeAndIndexing(String dataType, Boolean inverted, Boolean filterable, - Boolean searchable, Boolean expectedInverted, - Boolean expectedFilterable, Boolean expectedSearchable) { + public void shouldCreatePropertyWithDataTypeAndIndexing(String dataType, + Boolean inverted, Boolean expectedInverted, + Boolean filterable, Boolean expectedFilterable, + Boolean searchable, Boolean expectedSearchable, + Boolean rangeFilters, Boolean expectedRangeFilters) { WeaviateClass clazz = WeaviateClass.builder() .className("SomeClass") .description("some class description") @@ -275,6 +280,7 @@ public void shouldCreatePropertyWithDataTypeAndIndexing(String dataType, Boolean .indexInverted(inverted) .indexFilterable(filterable) .indexSearchable(searchable) + .indexRangeFilters(rangeFilters) .build() )) .build(); @@ -299,106 +305,292 @@ public void shouldCreatePropertyWithDataTypeAndIndexing(String dataType, Boolean .first().extracting(prop -> (Property) prop) .returns(expectedInverted, Property::getIndexInverted) .returns(expectedFilterable, Property::getIndexFilterable) - .returns(expectedSearchable, Property::getIndexSearchable); + .returns(expectedSearchable, Property::getIndexSearchable) + .returns(expectedRangeFilters, Property::getIndexRangeFilters); } public static Object[][] provideForDataTypeAndIndexing() { return new Object[][]{ new Object[]{ DataType.TEXT, - null, null, null, - null, Boolean.TRUE, Boolean.TRUE, + null, null, + null, Boolean.TRUE, + null, Boolean.TRUE, + null, Boolean.FALSE, + }, + new Object[]{ + DataType.TEXT, + null, null, + null, Boolean.TRUE, + null, Boolean.TRUE, + Boolean.FALSE, Boolean.FALSE, + }, + new Object[]{ + DataType.TEXT, + null, null, + null, Boolean.TRUE, + Boolean.FALSE, Boolean.FALSE, + null, Boolean.FALSE, + }, + new Object[]{ + DataType.TEXT, + null, null, + null, Boolean.TRUE, + Boolean.FALSE, Boolean.FALSE, + Boolean.FALSE, Boolean.FALSE, + }, + new Object[]{ + DataType.TEXT, + null, null, + null, Boolean.TRUE, + Boolean.TRUE, Boolean.TRUE, + null, Boolean.FALSE, + }, + new Object[]{ + DataType.TEXT, + null, null, + null, Boolean.TRUE, + Boolean.TRUE, Boolean.TRUE, + Boolean.FALSE, Boolean.FALSE, + }, + new Object[]{ + DataType.TEXT, + null, null, + Boolean.FALSE, Boolean.FALSE, + null, Boolean.TRUE, + null, Boolean.FALSE, }, new Object[]{ DataType.TEXT, - null, null, Boolean.FALSE, - null, Boolean.TRUE, Boolean.FALSE, + null, null, + Boolean.FALSE, Boolean.FALSE, + null, Boolean.TRUE, + Boolean.FALSE, Boolean.FALSE, }, new Object[]{ DataType.TEXT, - null, null, Boolean.TRUE, - null, Boolean.TRUE, Boolean.TRUE, + null, null, + Boolean.FALSE, Boolean.FALSE, + Boolean.FALSE, Boolean.FALSE, + null, Boolean.FALSE, }, new Object[]{ DataType.TEXT, - null, Boolean.FALSE, null, - null, Boolean.FALSE, Boolean.TRUE, + null, null, + Boolean.FALSE, Boolean.FALSE, + Boolean.FALSE, Boolean.FALSE, + Boolean.FALSE, Boolean.FALSE, }, new Object[]{ DataType.TEXT, - null, Boolean.FALSE, Boolean.FALSE, - null, Boolean.FALSE, Boolean.FALSE, + null, null, + Boolean.FALSE, Boolean.FALSE, + Boolean.TRUE, Boolean.TRUE, + null, Boolean.FALSE, }, new Object[]{ DataType.TEXT, - null, Boolean.FALSE, Boolean.TRUE, - null, Boolean.FALSE, Boolean.TRUE, + null, null, + Boolean.FALSE, Boolean.FALSE, + Boolean.TRUE, Boolean.TRUE, + Boolean.FALSE, Boolean.FALSE, }, new Object[]{ DataType.TEXT, - null, Boolean.TRUE, null, - null, Boolean.TRUE, Boolean.TRUE, + null, null, + Boolean.TRUE, Boolean.TRUE, + null, Boolean.TRUE, + null, Boolean.FALSE, }, new Object[]{ DataType.TEXT, - null, Boolean.TRUE, Boolean.FALSE, - null, Boolean.TRUE, Boolean.FALSE, + null, null, + Boolean.TRUE, Boolean.TRUE, + null, Boolean.TRUE, + Boolean.FALSE, Boolean.FALSE, }, new Object[]{ DataType.TEXT, - null, Boolean.TRUE, Boolean.TRUE, - null, Boolean.TRUE, Boolean.TRUE, + null, null, + Boolean.TRUE, Boolean.TRUE, + Boolean.FALSE, Boolean.FALSE, + null, Boolean.FALSE, }, new Object[]{ DataType.TEXT, - Boolean.FALSE, null, null, - null, Boolean.FALSE, Boolean.FALSE, + null, null, + Boolean.TRUE, Boolean.TRUE, + Boolean.FALSE, Boolean.FALSE, + Boolean.FALSE, Boolean.FALSE, }, new Object[]{ DataType.TEXT, - Boolean.TRUE, null, null, - null, Boolean.TRUE, Boolean.TRUE, + null, null, + Boolean.TRUE, Boolean.TRUE, + Boolean.TRUE, Boolean.TRUE, + null, Boolean.FALSE, + }, + new Object[]{ + DataType.TEXT, + null, null, + Boolean.TRUE, Boolean.TRUE, + Boolean.TRUE, Boolean.TRUE, + Boolean.FALSE, Boolean.FALSE, + }, + new Object[]{ + DataType.TEXT, + Boolean.FALSE, null, + null, Boolean.FALSE, + null, Boolean.FALSE, + null, Boolean.FALSE, + }, + new Object[]{ + DataType.TEXT, + Boolean.TRUE, null, + null, Boolean.TRUE, + null, Boolean.TRUE, + null, Boolean.FALSE, }, new Object[]{ DataType.INT, - null, null, null, - null, Boolean.TRUE, Boolean.FALSE, + null, null, + null, Boolean.TRUE, + null, Boolean.FALSE, + null, Boolean.FALSE, + }, + new Object[]{ + DataType.INT, + null, null, + null, Boolean.TRUE, + null, Boolean.FALSE, + Boolean.FALSE, Boolean.FALSE, + }, + new Object[]{ + DataType.INT, + null, null, + null, Boolean.TRUE, + null, Boolean.FALSE, + Boolean.TRUE, Boolean.TRUE, + }, + new Object[]{ + DataType.INT, + null, null, + null, Boolean.TRUE, + Boolean.FALSE, Boolean.FALSE, + null, Boolean.FALSE, + }, + new Object[]{ + DataType.INT, + null, null, + null, Boolean.TRUE, + Boolean.FALSE, Boolean.FALSE, + Boolean.FALSE, Boolean.FALSE, }, new Object[]{ DataType.INT, - null, null, Boolean.FALSE, - null, Boolean.TRUE, Boolean.FALSE, + null, null, + null, Boolean.TRUE, + Boolean.FALSE, Boolean.FALSE, + Boolean.TRUE, Boolean.TRUE, }, new Object[]{ DataType.INT, - null, Boolean.FALSE, null, - null, Boolean.FALSE, Boolean.FALSE, + null, null, + Boolean.FALSE, Boolean.FALSE, + null, Boolean.FALSE, + null, Boolean.FALSE, }, new Object[]{ DataType.INT, - null, Boolean.FALSE, Boolean.FALSE, - null, Boolean.FALSE, Boolean.FALSE, + null, null, + Boolean.FALSE, Boolean.FALSE, + null, Boolean.FALSE, + Boolean.FALSE, Boolean.FALSE, }, new Object[]{ DataType.INT, - null, Boolean.TRUE, null, - null, Boolean.TRUE, Boolean.FALSE, + null, null, + Boolean.FALSE, Boolean.FALSE, + null, Boolean.FALSE, + Boolean.TRUE, Boolean.TRUE, }, new Object[]{ DataType.INT, - null, Boolean.TRUE, Boolean.FALSE, - null, Boolean.TRUE, Boolean.FALSE, + null, null, + Boolean.FALSE, Boolean.FALSE, + Boolean.FALSE, Boolean.FALSE, + null, Boolean.FALSE, }, new Object[]{ DataType.INT, - Boolean.FALSE, null, null, - null, Boolean.FALSE, Boolean.FALSE, + null, null, + Boolean.FALSE, Boolean.FALSE, + Boolean.FALSE, Boolean.FALSE, + Boolean.FALSE, Boolean.FALSE, }, new Object[]{ DataType.INT, - Boolean.TRUE, null, null, - null, Boolean.TRUE, Boolean.FALSE, + null, null, + Boolean.FALSE, Boolean.FALSE, + Boolean.FALSE, Boolean.FALSE, + Boolean.TRUE, Boolean.TRUE, + }, + new Object[]{ + DataType.INT, + null, null, + Boolean.TRUE, Boolean.TRUE, + null, Boolean.FALSE, + null, Boolean.FALSE, + }, + new Object[]{ + DataType.INT, + null, null, + Boolean.TRUE, Boolean.TRUE, + null, Boolean.FALSE, + Boolean.FALSE, Boolean.FALSE, + }, + new Object[]{ + DataType.INT, + null, null, + Boolean.TRUE, Boolean.TRUE, + null, Boolean.FALSE, + Boolean.TRUE, Boolean.TRUE, + }, + new Object[]{ + DataType.INT, + null, null, + Boolean.TRUE, Boolean.TRUE, + Boolean.FALSE, Boolean.FALSE, + null, Boolean.FALSE, + }, + new Object[]{ + DataType.INT, + null, null, + Boolean.TRUE, Boolean.TRUE, + Boolean.FALSE, Boolean.FALSE, + Boolean.FALSE, Boolean.FALSE, + }, + new Object[]{ + DataType.INT, + null, null, + Boolean.TRUE, Boolean.TRUE, + Boolean.FALSE, Boolean.FALSE, + Boolean.TRUE, Boolean.TRUE, + }, + new Object[]{ + DataType.INT, + Boolean.FALSE, null, + null, Boolean.FALSE, + null, Boolean.FALSE, + null, Boolean.FALSE, + }, + new Object[]{ + DataType.INT, + Boolean.TRUE, null, + null, Boolean.TRUE, + null, Boolean.FALSE, + null, Boolean.FALSE, }, }; } @@ -406,8 +598,10 @@ public static Object[][] provideForDataTypeAndIndexing() { @DataMethod(source = ClientSchemaDefaultsAndMigrationTest.class, method = "provideInvalidForDataTypeAndIndexing") @Test - public void shouldNotCreatePropertyWithDataTypeAndIndexing(String dataType, Boolean inverted, Boolean filterable, - Boolean searchable, String expectedErrMsg) { + public void shouldNotCreatePropertyWithDataTypeAndIndexing(String dataType, + Boolean inverted, Boolean filterable, + Boolean searchable, Boolean rangeFilters, + String expectedErrMsg) { WeaviateClass clazz = WeaviateClass.builder() .className("SomeClass") .description("some class description") @@ -418,6 +612,7 @@ public void shouldNotCreatePropertyWithDataTypeAndIndexing(String dataType, Bool .indexInverted(inverted) .indexFilterable(filterable) .indexSearchable(searchable) + .indexRangeFilters(rangeFilters) .build() )) .build(); @@ -437,183 +632,623 @@ public void shouldNotCreatePropertyWithDataTypeAndIndexing(String dataType, Bool } public static Object[][] provideInvalidForDataTypeAndIndexing() { + String errInverted = "`indexInverted` is deprecated and can not be set together with `indexFilterable`, `indexSearchable` or `indexRangeFilters`"; + String errSearchable = "`indexSearchable` is allowed only for text/text[] data types. For other data types set false or leave empty"; + String errRangeFilters = "`indexRangeFilters` is allowed only for number/int/date data types. For other data types set false or leave empty"; + return new Object[][]{ new Object[]{ DataType.TEXT, - Boolean.FALSE, null, Boolean.FALSE, - "`indexInverted` is deprecated and can not be set together with `indexFilterable` or `indexSearchable`", + Boolean.FALSE, null, Boolean.FALSE, null, + errInverted, + }, + new Object[]{ + DataType.TEXT, + Boolean.FALSE, null, Boolean.FALSE, Boolean.FALSE, + errInverted, + }, + new Object[]{ + DataType.TEXT, + Boolean.FALSE, null, Boolean.FALSE, Boolean.TRUE, + errInverted, }, new Object[]{ DataType.TEXT, - Boolean.FALSE, null, Boolean.TRUE, - "`indexInverted` is deprecated and can not be set together with `indexFilterable` or `indexSearchable`", + Boolean.FALSE, null, Boolean.TRUE, null, + errInverted, }, new Object[]{ DataType.TEXT, - Boolean.FALSE, Boolean.FALSE, null, - "`indexInverted` is deprecated and can not be set together with `indexFilterable` or `indexSearchable`", + Boolean.FALSE, null, Boolean.TRUE, Boolean.FALSE, + errInverted, }, new Object[]{ DataType.TEXT, - Boolean.FALSE, Boolean.FALSE, Boolean.FALSE, - "`indexInverted` is deprecated and can not be set together with `indexFilterable` or `indexSearchable`", + Boolean.FALSE, null, Boolean.TRUE, Boolean.TRUE, + errInverted, }, new Object[]{ DataType.TEXT, - Boolean.FALSE, Boolean.FALSE, Boolean.TRUE, - "`indexInverted` is deprecated and can not be set together with `indexFilterable` or `indexSearchable`", + Boolean.FALSE, Boolean.FALSE, null, null, + errInverted, }, new Object[]{ DataType.TEXT, - Boolean.FALSE, Boolean.TRUE, null, - "`indexInverted` is deprecated and can not be set together with `indexFilterable` or `indexSearchable`", + Boolean.FALSE, Boolean.FALSE, null, Boolean.FALSE, + errInverted, }, new Object[]{ DataType.TEXT, - Boolean.FALSE, Boolean.TRUE, Boolean.FALSE, - "`indexInverted` is deprecated and can not be set together with `indexFilterable` or `indexSearchable`", + Boolean.FALSE, Boolean.FALSE, null, Boolean.TRUE, + errInverted, }, new Object[]{ DataType.TEXT, - Boolean.FALSE, Boolean.TRUE, Boolean.TRUE, - "`indexInverted` is deprecated and can not be set together with `indexFilterable` or `indexSearchable`", + Boolean.FALSE, Boolean.FALSE, Boolean.FALSE, null, + errInverted, }, new Object[]{ DataType.TEXT, - Boolean.TRUE, null, Boolean.FALSE, - "`indexInverted` is deprecated and can not be set together with `indexFilterable` or `indexSearchable`", + Boolean.FALSE, Boolean.FALSE, Boolean.FALSE, Boolean.FALSE, + errInverted, }, new Object[]{ DataType.TEXT, - Boolean.TRUE, null, Boolean.TRUE, - "`indexInverted` is deprecated and can not be set together with `indexFilterable` or `indexSearchable`", + Boolean.FALSE, Boolean.FALSE, Boolean.FALSE, Boolean.TRUE, + errInverted, }, new Object[]{ DataType.TEXT, - Boolean.TRUE, Boolean.FALSE, null, - "`indexInverted` is deprecated and can not be set together with `indexFilterable` or `indexSearchable`", + Boolean.FALSE, Boolean.FALSE, Boolean.TRUE, null, + errInverted, }, new Object[]{ DataType.TEXT, - Boolean.TRUE, Boolean.FALSE, Boolean.FALSE, - "`indexInverted` is deprecated and can not be set together with `indexFilterable` or `indexSearchable`", + Boolean.FALSE, Boolean.FALSE, Boolean.TRUE, Boolean.FALSE, + errInverted, }, new Object[]{ DataType.TEXT, - Boolean.TRUE, Boolean.FALSE, Boolean.TRUE, - "`indexInverted` is deprecated and can not be set together with `indexFilterable` or `indexSearchable`", + Boolean.FALSE, Boolean.FALSE, Boolean.TRUE, Boolean.TRUE, + errInverted, }, new Object[]{ DataType.TEXT, - Boolean.TRUE, Boolean.TRUE, null, - "`indexInverted` is deprecated and can not be set together with `indexFilterable` or `indexSearchable`", + Boolean.FALSE, Boolean.TRUE, null, null, + errInverted, }, new Object[]{ DataType.TEXT, - Boolean.TRUE, Boolean.TRUE, Boolean.FALSE, - "`indexInverted` is deprecated and can not be set together with `indexFilterable` or `indexSearchable`", + Boolean.FALSE, Boolean.TRUE, null, Boolean.FALSE, + errInverted, }, new Object[]{ DataType.TEXT, - Boolean.TRUE, Boolean.TRUE, Boolean.TRUE, - "`indexInverted` is deprecated and can not be set together with `indexFilterable` or `indexSearchable`", + Boolean.FALSE, Boolean.TRUE, null, Boolean.TRUE, + errInverted, + }, + new Object[]{ + DataType.TEXT, + Boolean.FALSE, Boolean.TRUE, Boolean.FALSE, null, + errInverted, + }, + new Object[]{ + DataType.TEXT, + Boolean.FALSE, Boolean.TRUE, Boolean.FALSE, Boolean.FALSE, + errInverted, + }, + new Object[]{ + DataType.TEXT, + Boolean.FALSE, Boolean.TRUE, Boolean.FALSE, Boolean.TRUE, + errInverted, + }, + new Object[]{ + DataType.TEXT, + Boolean.FALSE, Boolean.TRUE, Boolean.TRUE, null, + errInverted, + }, + new Object[]{ + DataType.TEXT, + Boolean.FALSE, Boolean.TRUE, Boolean.TRUE, Boolean.FALSE, + errInverted, + }, + new Object[]{ + DataType.TEXT, + Boolean.FALSE, Boolean.TRUE, Boolean.TRUE, Boolean.TRUE, + errInverted, + }, + new Object[]{ + DataType.TEXT, + Boolean.TRUE, null, Boolean.FALSE, null, + errInverted, + }, + new Object[]{ + DataType.TEXT, + Boolean.TRUE, null, Boolean.FALSE, Boolean.FALSE, + errInverted, + }, + new Object[]{ + DataType.TEXT, + Boolean.TRUE, null, Boolean.FALSE, Boolean.TRUE, + errInverted, + }, + new Object[]{ + DataType.TEXT, + Boolean.TRUE, null, Boolean.TRUE, null, + errInverted, + }, + new Object[]{ + DataType.TEXT, + Boolean.TRUE, null, Boolean.TRUE, Boolean.FALSE, + errInverted, + }, + new Object[]{ + DataType.TEXT, + Boolean.TRUE, null, Boolean.TRUE, Boolean.TRUE, + errInverted, + }, + new Object[]{ + DataType.TEXT, + Boolean.TRUE, Boolean.FALSE, null, null, + errInverted, + }, + new Object[]{ + DataType.TEXT, + Boolean.TRUE, Boolean.FALSE, null, Boolean.FALSE, + errInverted, + }, + new Object[]{ + DataType.TEXT, + Boolean.TRUE, Boolean.FALSE, null, Boolean.TRUE, + errInverted, + }, + new Object[]{ + DataType.TEXT, + Boolean.TRUE, Boolean.FALSE, Boolean.FALSE, null, + errInverted, + }, + new Object[]{ + DataType.TEXT, + Boolean.TRUE, Boolean.FALSE, Boolean.FALSE, Boolean.FALSE, + errInverted, + }, + new Object[]{ + DataType.TEXT, + Boolean.TRUE, Boolean.FALSE, Boolean.FALSE, Boolean.TRUE, + errInverted, + }, + new Object[]{ + DataType.TEXT, + Boolean.TRUE, Boolean.FALSE, Boolean.TRUE, null, + errInverted, + }, + new Object[]{ + DataType.TEXT, + Boolean.TRUE, Boolean.FALSE, Boolean.TRUE, Boolean.FALSE, + errInverted, + }, + new Object[]{ + DataType.TEXT, + Boolean.TRUE, Boolean.FALSE, Boolean.TRUE, Boolean.TRUE, + errInverted, + }, + new Object[]{ + DataType.TEXT, + Boolean.TRUE, Boolean.TRUE, null, null, + errInverted, + }, + new Object[]{ + DataType.TEXT, + Boolean.TRUE, Boolean.TRUE, null, Boolean.FALSE, + errInverted, + }, + new Object[]{ + DataType.TEXT, + Boolean.TRUE, Boolean.TRUE, null, Boolean.TRUE, + errInverted, + }, + new Object[]{ + DataType.TEXT, + Boolean.TRUE, Boolean.TRUE, Boolean.FALSE, null, + errInverted, + }, + new Object[]{ + DataType.TEXT, + Boolean.TRUE, Boolean.TRUE, Boolean.FALSE, Boolean.FALSE, + errInverted, + }, + new Object[]{ + DataType.TEXT, + Boolean.TRUE, Boolean.TRUE, Boolean.FALSE, Boolean.TRUE, + errInverted, + }, + new Object[]{ + DataType.TEXT, + Boolean.TRUE, Boolean.TRUE, Boolean.TRUE, null, + errInverted, + }, + new Object[]{ + DataType.TEXT, + Boolean.TRUE, Boolean.TRUE, Boolean.TRUE, Boolean.FALSE, + errInverted, + }, + new Object[]{ + DataType.TEXT, + Boolean.TRUE, Boolean.TRUE, Boolean.TRUE, Boolean.TRUE, + errInverted, + }, + new Object[]{ + DataType.TEXT, + Boolean.FALSE, null, null, Boolean.FALSE, + errInverted, + }, + new Object[]{ + DataType.TEXT, + Boolean.FALSE, null, null, Boolean.TRUE, + errInverted, + }, + new Object[]{ + DataType.TEXT, + Boolean.TRUE, null, null, Boolean.FALSE, + errInverted, + }, + new Object[]{ + DataType.TEXT, + Boolean.TRUE, null, null, Boolean.TRUE, + errInverted, }, new Object[]{ DataType.INT, - Boolean.FALSE, null, Boolean.FALSE, - "`indexInverted` is deprecated and can not be set together with `indexFilterable` or `indexSearchable`", + Boolean.FALSE, null, Boolean.FALSE, null, + errInverted, + }, + new Object[]{ + DataType.INT, + Boolean.FALSE, null, Boolean.FALSE, Boolean.FALSE, + errInverted, + }, + new Object[]{ + DataType.INT, + Boolean.FALSE, null, Boolean.FALSE, Boolean.TRUE, + errInverted, + }, + new Object[]{ + DataType.INT, + Boolean.FALSE, null, Boolean.TRUE, null, + errInverted, + }, + new Object[]{ + DataType.INT, + Boolean.FALSE, null, Boolean.TRUE, Boolean.FALSE, + errInverted, + }, + new Object[]{ + DataType.INT, + Boolean.FALSE, null, Boolean.TRUE, Boolean.TRUE, + errInverted, + }, + new Object[]{ + DataType.INT, + Boolean.FALSE, Boolean.FALSE, null, null, + errInverted, + }, + new Object[]{ + DataType.INT, + Boolean.FALSE, Boolean.FALSE, null, Boolean.FALSE, + errInverted, + }, + new Object[]{ + DataType.INT, + Boolean.FALSE, Boolean.FALSE, null, Boolean.TRUE, + errInverted, + }, + new Object[]{ + DataType.INT, + Boolean.FALSE, Boolean.FALSE, Boolean.FALSE, null, + errInverted, + }, + new Object[]{ + DataType.INT, + Boolean.FALSE, Boolean.FALSE, Boolean.FALSE, Boolean.FALSE, + errInverted, + }, + new Object[]{ + DataType.INT, + Boolean.FALSE, Boolean.FALSE, Boolean.FALSE, Boolean.TRUE, + errInverted, + }, + new Object[]{ + DataType.INT, + Boolean.FALSE, Boolean.FALSE, Boolean.TRUE, null, + errInverted, + }, + new Object[]{ + DataType.INT, + Boolean.FALSE, Boolean.FALSE, Boolean.TRUE, Boolean.FALSE, + errInverted, + }, + new Object[]{ + DataType.INT, + Boolean.FALSE, Boolean.FALSE, Boolean.TRUE, Boolean.TRUE, + errInverted, + }, + new Object[]{ + DataType.INT, + Boolean.FALSE, Boolean.TRUE, null, null, + errInverted, + }, + new Object[]{ + DataType.INT, + Boolean.FALSE, Boolean.TRUE, null, Boolean.FALSE, + errInverted, + }, + new Object[]{ + DataType.INT, + Boolean.FALSE, Boolean.TRUE, null, Boolean.TRUE, + errInverted, + }, + new Object[]{ + DataType.INT, + Boolean.FALSE, Boolean.TRUE, Boolean.FALSE, null, + errInverted, + }, + new Object[]{ + DataType.INT, + Boolean.FALSE, Boolean.TRUE, Boolean.FALSE, Boolean.FALSE, + errInverted, + }, + new Object[]{ + DataType.INT, + Boolean.FALSE, Boolean.TRUE, Boolean.FALSE, Boolean.TRUE, + errInverted, + }, + new Object[]{ + DataType.INT, + Boolean.FALSE, Boolean.TRUE, Boolean.TRUE, null, + errInverted, + }, + new Object[]{ + DataType.INT, + Boolean.FALSE, Boolean.TRUE, Boolean.TRUE, Boolean.FALSE, + errInverted, + }, + new Object[]{ + DataType.INT, + Boolean.FALSE, Boolean.TRUE, Boolean.TRUE, Boolean.TRUE, + errInverted, + }, + new Object[]{ + DataType.INT, + Boolean.TRUE, null, Boolean.FALSE, null, + errInverted, }, new Object[]{ DataType.INT, - Boolean.FALSE, null, Boolean.TRUE, - "`indexInverted` is deprecated and can not be set together with `indexFilterable` or `indexSearchable`", + Boolean.TRUE, null, Boolean.FALSE, Boolean.FALSE, + errInverted, }, new Object[]{ DataType.INT, - Boolean.FALSE, Boolean.FALSE, null, - "`indexInverted` is deprecated and can not be set together with `indexFilterable` or `indexSearchable`", + Boolean.TRUE, null, Boolean.FALSE, Boolean.TRUE, + errInverted, }, new Object[]{ DataType.INT, - Boolean.FALSE, Boolean.FALSE, Boolean.FALSE, - "`indexInverted` is deprecated and can not be set together with `indexFilterable` or `indexSearchable`", + Boolean.TRUE, null, Boolean.TRUE, null, + errInverted, }, new Object[]{ DataType.INT, - Boolean.FALSE, Boolean.FALSE, Boolean.TRUE, - "`indexInverted` is deprecated and can not be set together with `indexFilterable` or `indexSearchable`", + Boolean.TRUE, null, Boolean.TRUE, Boolean.FALSE, + errInverted, }, new Object[]{ DataType.INT, - Boolean.FALSE, Boolean.TRUE, null, - "`indexInverted` is deprecated and can not be set together with `indexFilterable` or `indexSearchable`", + Boolean.TRUE, null, Boolean.TRUE, Boolean.TRUE, + errInverted, }, new Object[]{ DataType.INT, - Boolean.FALSE, Boolean.TRUE, Boolean.FALSE, - "`indexInverted` is deprecated and can not be set together with `indexFilterable` or `indexSearchable`", + Boolean.TRUE, Boolean.FALSE, null, null, + errInverted, }, new Object[]{ DataType.INT, - Boolean.FALSE, Boolean.TRUE, Boolean.TRUE, - "`indexInverted` is deprecated and can not be set together with `indexFilterable` or `indexSearchable`", + Boolean.TRUE, Boolean.FALSE, null, Boolean.FALSE, + errInverted, }, new Object[]{ DataType.INT, - Boolean.TRUE, null, Boolean.FALSE, - "`indexInverted` is deprecated and can not be set together with `indexFilterable` or `indexSearchable`", + Boolean.TRUE, Boolean.FALSE, null, Boolean.TRUE, + errInverted, }, new Object[]{ DataType.INT, - Boolean.TRUE, null, Boolean.TRUE, - "`indexInverted` is deprecated and can not be set together with `indexFilterable` or `indexSearchable`", + Boolean.TRUE, Boolean.FALSE, Boolean.FALSE, null, + errInverted, }, new Object[]{ DataType.INT, - Boolean.TRUE, Boolean.FALSE, null, - "`indexInverted` is deprecated and can not be set together with `indexFilterable` or `indexSearchable`", + Boolean.TRUE, Boolean.FALSE, Boolean.FALSE, Boolean.FALSE, + errInverted, }, new Object[]{ DataType.INT, - Boolean.TRUE, Boolean.FALSE, Boolean.FALSE, - "`indexInverted` is deprecated and can not be set together with `indexFilterable` or `indexSearchable`", + Boolean.TRUE, Boolean.FALSE, Boolean.FALSE, Boolean.TRUE, + errInverted, }, new Object[]{ DataType.INT, - Boolean.TRUE, Boolean.FALSE, Boolean.TRUE, - "`indexInverted` is deprecated and can not be set together with `indexFilterable` or `indexSearchable`", + Boolean.TRUE, Boolean.FALSE, Boolean.TRUE, null, + errInverted, }, new Object[]{ DataType.INT, - Boolean.TRUE, Boolean.TRUE, null, - "`indexInverted` is deprecated and can not be set together with `indexFilterable` or `indexSearchable`", + Boolean.TRUE, Boolean.FALSE, Boolean.TRUE, Boolean.FALSE, + errInverted, }, new Object[]{ DataType.INT, - Boolean.TRUE, Boolean.TRUE, Boolean.FALSE, - "`indexInverted` is deprecated and can not be set together with `indexFilterable` or `indexSearchable`", + Boolean.TRUE, Boolean.FALSE, Boolean.TRUE, Boolean.TRUE, + errInverted, }, new Object[]{ DataType.INT, - Boolean.TRUE, Boolean.TRUE, Boolean.TRUE, - "`indexInverted` is deprecated and can not be set together with `indexFilterable` or `indexSearchable`", + Boolean.TRUE, Boolean.TRUE, null, null, + errInverted, + }, + new Object[]{ + DataType.INT, + Boolean.TRUE, Boolean.TRUE, null, Boolean.FALSE, + errInverted, + }, + new Object[]{ + DataType.INT, + Boolean.TRUE, Boolean.TRUE, null, Boolean.TRUE, + errInverted, + }, + new Object[]{ + DataType.INT, + Boolean.TRUE, Boolean.TRUE, Boolean.FALSE, null, + errInverted, + }, + new Object[]{ + DataType.INT, + Boolean.TRUE, Boolean.TRUE, Boolean.FALSE, Boolean.FALSE, + errInverted, + }, + new Object[]{ + DataType.INT, + Boolean.TRUE, Boolean.TRUE, Boolean.FALSE, Boolean.TRUE, + errInverted, + }, + new Object[]{ + DataType.INT, + Boolean.TRUE, Boolean.TRUE, Boolean.TRUE, null, + errInverted, + }, + new Object[]{ + DataType.INT, + Boolean.TRUE, Boolean.TRUE, Boolean.TRUE, Boolean.FALSE, + errInverted, + }, + new Object[]{ + DataType.INT, + Boolean.TRUE, Boolean.TRUE, Boolean.TRUE, Boolean.TRUE, + errInverted, + }, + new Object[]{ + DataType.INT, + Boolean.FALSE, null, null, Boolean.FALSE, + errInverted, + }, + new Object[]{ + DataType.INT, + Boolean.FALSE, null, null, Boolean.TRUE, + errInverted, + }, + new Object[]{ + DataType.INT, + Boolean.TRUE, null, null, Boolean.FALSE, + errInverted, + }, + new Object[]{ + DataType.INT, + Boolean.TRUE, null, null, Boolean.TRUE, + errInverted, }, new Object[]{ DataType.INT, - null, null, Boolean.TRUE, - "`indexSearchable` is allowed only for text/text[] data types. For other data types set false or leave empty", + null, null, Boolean.TRUE, null, + errSearchable, + }, + new Object[]{ + DataType.INT, + null, null, Boolean.TRUE, Boolean.FALSE, + errSearchable, + }, + new Object[]{ + DataType.INT, + null, null, Boolean.TRUE, Boolean.TRUE, + errSearchable, + }, + new Object[]{ + DataType.INT, + null, Boolean.FALSE, Boolean.TRUE, null, + errSearchable, }, new Object[]{ DataType.INT, - null, Boolean.FALSE, Boolean.TRUE, - "`indexSearchable` is allowed only for text/text[] data types. For other data types set false or leave empty", + null, Boolean.FALSE, Boolean.TRUE, Boolean.FALSE, + errSearchable, }, new Object[]{ DataType.INT, - null, Boolean.TRUE, Boolean.TRUE, - "`indexSearchable` is allowed only for text/text[] data types. For other data types set false or leave empty", + null, Boolean.FALSE, Boolean.TRUE, Boolean.TRUE, + errSearchable, + }, + new Object[]{ + DataType.INT, + null, Boolean.TRUE, Boolean.TRUE, null, + errSearchable, + }, + new Object[]{ + DataType.INT, + null, Boolean.TRUE, Boolean.TRUE, Boolean.FALSE, + errSearchable, + }, + new Object[]{ + DataType.INT, + null, Boolean.TRUE, Boolean.TRUE, Boolean.TRUE, + errSearchable, + }, + + new Object[]{ + DataType.TEXT, + null, null, null, Boolean.TRUE, + errRangeFilters, + }, + new Object[]{ + DataType.TEXT, + null, Boolean.FALSE, null, Boolean.TRUE, + errRangeFilters, + }, + new Object[]{ + DataType.TEXT, + null, Boolean.TRUE, null, Boolean.TRUE, + errRangeFilters, + }, + new Object[]{ + DataType.TEXT, + null, null, Boolean.FALSE, Boolean.TRUE, + errRangeFilters, + }, + new Object[]{ + DataType.TEXT, + null, null, Boolean.TRUE, Boolean.TRUE, + errRangeFilters, + }, + new Object[]{ + DataType.TEXT, + null, Boolean.FALSE, Boolean.FALSE, Boolean.TRUE, + errRangeFilters, + }, + new Object[]{ + DataType.TEXT, + null, Boolean.FALSE, Boolean.TRUE, Boolean.TRUE, + errRangeFilters, + }, + new Object[]{ + DataType.TEXT, + null, Boolean.TRUE, Boolean.FALSE, Boolean.TRUE, + errRangeFilters, + }, + new Object[]{ + DataType.TEXT, + null, Boolean.TRUE, Boolean.TRUE, Boolean.TRUE, + errRangeFilters, }, }; } diff --git a/src/test/java/io/weaviate/integration/client/schema/ClientSchemaTest.java b/src/test/java/io/weaviate/integration/client/schema/ClientSchemaTest.java index 6905799d..6a1f63c5 100644 --- a/src/test/java/io/weaviate/integration/client/schema/ClientSchemaTest.java +++ b/src/test/java/io/weaviate/integration/client/schema/ClientSchemaTest.java @@ -444,7 +444,7 @@ public void testSchemaCreateClassWithInvalidTokenizationProperty() { //then assertResultTrue(createStatus); - assertResultError("tokenization in body should be one of [word lowercase whitespace field trigram gse]", notExistingTokenizationCreateStatus); + assertResultError("tokenization in body should be one of [word lowercase whitespace field trigram gse kagome_kr]", notExistingTokenizationCreateStatus); assertResultError("Tokenization is not allowed for data type 'int'", notSupportedTokenizationForIntCreateStatus); }