Search in sources :

Example 6 with TestNewIndex

use of org.sonar.server.es.newindex.TestNewIndex in project sonarqube by SonarSource.

the class IndexDefinitionHashTest method hash_changes_if_clustering_is_enabled_or_not.

@Test
public void hash_changes_if_clustering_is_enabled_or_not() {
    Index index = Index.simple("foo");
    IndexMainType mainType = IndexMainType.main(index, "bar");
    MapSettings empty = new MapSettings();
    MapSettings clusterDisabled = new MapSettings().setProperty(CLUSTER_ENABLED.getKey(), false);
    MapSettings clusterEnabled = new MapSettings().setProperty(CLUSTER_ENABLED.getKey(), true);
    assertThat(hashOf(new TestNewIndex(mainType, settingsConfigurationOf(empty)))).isEqualTo(hashOf(new TestNewIndex(mainType, settingsConfigurationOf(empty)))).isEqualTo(hashOf(new TestNewIndex(mainType, settingsConfigurationOf(clusterDisabled)))).isNotEqualTo(hashOf(new TestNewIndex(mainType, settingsConfigurationOf(clusterEnabled))));
}
Also used : MapSettings(org.sonar.api.config.internal.MapSettings) TestNewIndex(org.sonar.server.es.newindex.TestNewIndex) IndexMainType(org.sonar.server.es.IndexType.IndexMainType) TestNewIndex(org.sonar.server.es.newindex.TestNewIndex) Test(org.junit.Test)

Example 7 with TestNewIndex

use of org.sonar.server.es.newindex.TestNewIndex in project sonarqube by SonarSource.

the class IndexDefinitionHashTest method computeAndVerifyAllSameHashesOnMapping.

@SafeVarargs
private final void computeAndVerifyAllSameHashesOnMapping(IndexMainType mainType, Consumer<TypeMapping>... fieldTypes) {
    List<Consumer<TypeMapping>> fieldTypes1 = Arrays.asList(fieldTypes);
    List<TestNewIndex> mainIndices = fieldTypes1.stream().map(consumer -> {
        TestNewIndex mainTypeMapping = new TestNewIndex(mainType, settingsConfiguration);
        consumer.accept(mainTypeMapping.getMainTypeMapping());
        return mainTypeMapping;
    }).collect(toList());
    List<TestNewIndex> relationIndices = fieldTypes1.stream().map(consumer -> {
        TestNewIndex relationTypeMapping = new TestNewIndex(mainType, settingsConfiguration);
        consumer.accept(relationTypeMapping.createRelationMapping("donut"));
        return relationTypeMapping;
    }).collect(toList());
    Set<String> mainHashes = mainIndices.stream().map(IndexDefinitionHashTest::hashOf).collect(toSet());
    Set<String> relationHashes = relationIndices.stream().map(IndexDefinitionHashTest::hashOf).collect(toSet());
    assertThat(mainHashes).isEqualTo(mainIndices.stream().map(IndexDefinitionHashTest::hashOf).collect(toSet())).doesNotContainAnyElementsOf(relationHashes).hasSize(1);
    assertThat(relationHashes).isEqualTo(relationIndices.stream().map(IndexDefinitionHashTest::hashOf).collect(toSet())).doesNotContainAnyElementsOf(mainHashes).hasSize(1);
}
Also used : Arrays(java.util.Arrays) CLUSTER_ENABLED(org.sonar.process.ProcessProperties.Property.CLUSTER_ENABLED) Assertions.assertThat(org.assertj.core.api.Assertions.assertThat) Set(java.util.Set) Test(org.junit.Test) MapSettings(org.sonar.api.config.internal.MapSettings) TestNewIndex(org.sonar.server.es.newindex.TestNewIndex) Consumer(java.util.function.Consumer) SettingsConfiguration(org.sonar.server.es.newindex.SettingsConfiguration) List(java.util.List) Collectors.toList(java.util.stream.Collectors.toList) IndexMainType(org.sonar.server.es.IndexType.IndexMainType) Configuration(org.sonar.api.config.Configuration) TypeMapping(org.sonar.server.es.newindex.TypeMapping) Collectors.toSet(java.util.stream.Collectors.toSet) Consumer(java.util.function.Consumer) TestNewIndex(org.sonar.server.es.newindex.TestNewIndex)

Example 8 with TestNewIndex

use of org.sonar.server.es.newindex.TestNewIndex in project sonarqube by SonarSource.

the class IndexDefinitionHashTest method hash_changes_if_relations_are_different.

@Test
public void hash_changes_if_relations_are_different() {
    Index index = Index.withRelations("foo");
    IndexMainType mainType = IndexMainType.main(index, "bar");
    TestNewIndex indexNoRelation = new TestNewIndex(mainType, settingsConfiguration);
    TestNewIndex indexOneRelation = new TestNewIndex(mainType, settingsConfiguration).addRelation("donut1");
    TestNewIndex indexOneOtherRelation = new TestNewIndex(mainType, settingsConfiguration).addRelation("donut2");
    TestNewIndex indexTwoRelations = new TestNewIndex(mainType, settingsConfiguration).addRelation("donut1").addRelation("donut2");
    TestNewIndex indexTwoOtherRelations = new TestNewIndex(mainType, settingsConfiguration).addRelation("donut1").addRelation("donut3");
    assertThat(hashOf(indexNoRelation)).isEqualTo(hashOf(new TestNewIndex(mainType, settingsConfiguration))).isNotEqualTo(hashOf(indexOneRelation)).isNotEqualTo(hashOf(indexOneOtherRelation)).isNotEqualTo(hashOf(indexTwoRelations)).isNotEqualTo(hashOf(indexTwoOtherRelations));
    assertThat(hashOf(indexOneRelation)).isEqualTo(hashOf(new TestNewIndex(mainType, settingsConfiguration).addRelation("donut1"))).isNotEqualTo(hashOf(indexOneOtherRelation)).isNotEqualTo(hashOf(indexTwoRelations)).isNotEqualTo(hashOf(indexTwoOtherRelations));
    assertThat(hashOf(indexTwoRelations)).isEqualTo(hashOf(new TestNewIndex(mainType, settingsConfiguration).addRelation("donut1").addRelation("donut2"))).isNotEqualTo(hashOf(indexOneRelation)).isNotEqualTo(hashOf(indexOneOtherRelation)).isNotEqualTo(hashOf(indexTwoOtherRelations));
}
Also used : TestNewIndex(org.sonar.server.es.newindex.TestNewIndex) IndexMainType(org.sonar.server.es.IndexType.IndexMainType) TestNewIndex(org.sonar.server.es.newindex.TestNewIndex) Test(org.junit.Test)

Example 9 with TestNewIndex

use of org.sonar.server.es.newindex.TestNewIndex in project sonarqube by SonarSource.

the class IndexDefinitionHashTest method hash_changes_if_number_of_shards_changes.

@Test
public void hash_changes_if_number_of_shards_changes() {
    Index index = Index.simple("foo");
    IndexMainType mainType = IndexMainType.main(index, "bar");
    Configuration emptySettings = new MapSettings().asConfig();
    SettingsConfiguration defaultNbOfShards = SettingsConfiguration.newBuilder(emptySettings).build();
    SettingsConfiguration specifiedDefaultNbOfShards = SettingsConfiguration.newBuilder(emptySettings).setDefaultNbOfShards(5).build();
    SettingsConfiguration specifyDefaultNbOfShards = SettingsConfiguration.newBuilder(new MapSettings().setProperty("sonar.search." + index.getName() + ".shards", 1).asConfig()).setDefaultNbOfShards(1).build();
    SettingsConfiguration specifiedNbOfShards = SettingsConfiguration.newBuilder(new MapSettings().setProperty("sonar.search." + index.getName() + ".shards", 10).asConfig()).setDefaultNbOfShards(5).build();
    assertThat(hashOf(new TestNewIndex(mainType, defaultNbOfShards))).isEqualTo(hashOf(new TestNewIndex(mainType, defaultNbOfShards))).isEqualTo(hashOf(new TestNewIndex(mainType, specifyDefaultNbOfShards))).isNotEqualTo(hashOf(new TestNewIndex(mainType, specifiedDefaultNbOfShards))).isNotEqualTo(hashOf(new TestNewIndex(mainType, specifiedNbOfShards)));
    assertThat(hashOf(new TestNewIndex(mainType, specifiedDefaultNbOfShards))).isEqualTo(hashOf(new TestNewIndex(mainType, specifiedDefaultNbOfShards))).isNotEqualTo(hashOf(new TestNewIndex(mainType, specifyDefaultNbOfShards)));
}
Also used : SettingsConfiguration(org.sonar.server.es.newindex.SettingsConfiguration) Configuration(org.sonar.api.config.Configuration) MapSettings(org.sonar.api.config.internal.MapSettings) SettingsConfiguration(org.sonar.server.es.newindex.SettingsConfiguration) TestNewIndex(org.sonar.server.es.newindex.TestNewIndex) IndexMainType(org.sonar.server.es.IndexType.IndexMainType) TestNewIndex(org.sonar.server.es.newindex.TestNewIndex) Test(org.junit.Test)

Example 10 with TestNewIndex

use of org.sonar.server.es.newindex.TestNewIndex in project sonarqube by SonarSource.

the class IndexDefinitionHashTest method hash_changes_if_fields_on_main_type_mapping_are_different.

@Test
public void hash_changes_if_fields_on_main_type_mapping_are_different() {
    Index index = Index.withRelations("foo");
    IndexMainType mainType = IndexMainType.main(index, "bar");
    TestNewIndex indexNoField = new TestNewIndex(mainType, settingsConfiguration);
    TestNewIndex indexOneField = new TestNewIndex(mainType, settingsConfiguration);
    indexOneField.getMainTypeMapping().createIntegerField("field1");
    TestNewIndex indexOneFieldAgain = new TestNewIndex(mainType, settingsConfiguration);
    indexOneFieldAgain.getMainTypeMapping().createIntegerField("field1");
    TestNewIndex indexOneOtherField = new TestNewIndex(mainType, settingsConfiguration);
    indexOneOtherField.getMainTypeMapping().createIntegerField("field2");
    TestNewIndex indexTwoFields = new TestNewIndex(mainType, settingsConfiguration);
    indexTwoFields.getMainTypeMapping().createIntegerField("field1").createIntegerField("field2");
    TestNewIndex indexTwoFieldsAgain = new TestNewIndex(mainType, settingsConfiguration);
    indexTwoFieldsAgain.getMainTypeMapping().createIntegerField("field1").createIntegerField("field2");
    TestNewIndex indexTwoOtherFields = new TestNewIndex(mainType, settingsConfiguration);
    indexTwoOtherFields.getMainTypeMapping().createIntegerField("field1").createIntegerField("field3");
    assertThat(hashOf(indexNoField)).isEqualTo(hashOf(new TestNewIndex(mainType, settingsConfiguration))).isNotEqualTo(hashOf(indexOneField)).isNotEqualTo(hashOf(indexOneOtherField)).isNotEqualTo(hashOf(indexTwoFields)).isNotEqualTo(hashOf(indexTwoOtherFields));
    assertThat(hashOf(indexOneField)).isEqualTo(hashOf(indexOneFieldAgain)).isNotEqualTo(hashOf(indexOneOtherField)).isNotEqualTo(hashOf(indexTwoFields)).isNotEqualTo(hashOf(indexTwoOtherFields));
    assertThat(hashOf(indexTwoFields)).isEqualTo(hashOf(indexTwoFieldsAgain)).isNotEqualTo(hashOf(indexOneField)).isNotEqualTo(hashOf(indexOneOtherField)).isNotEqualTo(hashOf(indexTwoOtherFields));
}
Also used : TestNewIndex(org.sonar.server.es.newindex.TestNewIndex) IndexMainType(org.sonar.server.es.IndexType.IndexMainType) TestNewIndex(org.sonar.server.es.newindex.TestNewIndex) Test(org.junit.Test)

Aggregations

Test (org.junit.Test)10 IndexMainType (org.sonar.server.es.IndexType.IndexMainType)10 TestNewIndex (org.sonar.server.es.newindex.TestNewIndex)10 MapSettings (org.sonar.api.config.internal.MapSettings)5 Configuration (org.sonar.api.config.Configuration)4 SettingsConfiguration (org.sonar.server.es.newindex.SettingsConfiguration)4 Arrays (java.util.Arrays)2 List (java.util.List)2 Set (java.util.Set)2 Consumer (java.util.function.Consumer)2 Collectors.toList (java.util.stream.Collectors.toList)2 Collectors.toSet (java.util.stream.Collectors.toSet)2 Assertions.assertThat (org.assertj.core.api.Assertions.assertThat)2 CLUSTER_ENABLED (org.sonar.process.ProcessProperties.Property.CLUSTER_ENABLED)2 TypeMapping (org.sonar.server.es.newindex.TypeMapping)2