Skip to content

Commit

Permalink
Addressing comments
Browse files Browse the repository at this point in the history
Signed-off-by: Arpit Bandejiya <abandeji@amazon.com>
  • Loading branch information
Arpit-Bandejiya committed Jan 5, 2023
1 parent 099a7d1 commit aa541ad
Show file tree
Hide file tree
Showing 9 changed files with 22 additions and 97 deletions.
2 changes: 1 addition & 1 deletion CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/),

## [Unreleased 3.0]
### Added
- Add support of default replica count change using total awareness attribute([#5610](https://github.com/opensearch-project/OpenSearch/pull/5610))
- Add support of default replica count cluster setting ([#5610](https://github.com/opensearch-project/OpenSearch/pull/5610))
- Hardened token permissions in GitHub workflows ([#4587](https://github.com/opensearch-project/OpenSearch/pull/4587))
- Support for HTTP/2 (server-side) ([#3847](https://github.com/opensearch-project/OpenSearch/pull/3847))
- Add getter for path field in NestedQueryBuilder ([#4636](https://github.com/opensearch-project/OpenSearch/pull/4636))
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -310,7 +310,7 @@ public void testRolloverWithIndexSettingsBalancedWithUseZoneForReplicaDefaultCou
testAlias.writeIndex(true);
}
assertAcked(prepareCreate("test_index-2").addAlias(testAlias).get());
manageUseZoneForReplicaSetting(true);
manageReplicaBalanceSettingWithDefaultReplica(true);
index("test_index-2", "type1", "1", "field", "value");
flush("test_index-2");

Expand All @@ -321,7 +321,7 @@ public void testRolloverWithIndexSettingsBalancedWithUseZoneForReplicaDefaultCou
final IndexMetadata newIndex = state.metadata().index("test_index-000003");
assertThat(newIndex.getNumberOfShards(), equalTo(3));
assertThat(newIndex.getNumberOfReplicas(), equalTo(2));
manageUseZoneForReplicaSetting(false);
manageReplicaBalanceSettingWithDefaultReplica(false);
randomIndexTemplate();
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -670,7 +670,7 @@ public void testAwarenessReplicaBalanceWithUseZoneForDefaultReplicaCount() {
createIndex(".system-index", Settings.builder().put("index.number_of_replicas", 0).build());
DeleteIndexTemplateRequestBuilder deleteTemplate = client().admin().indices().prepareDeleteTemplate("random_index_template");
assertAcked(deleteTemplate.execute().actionGet());
manageUseZoneForReplicaSetting(true);
manageReplicaBalanceSettingWithDefaultReplica(true);
int updated = 0;

try {
Expand Down Expand Up @@ -734,7 +734,7 @@ public void testAwarenessReplicaBalanceWithUseZoneForDefaultReplicaCount() {
);
assertEquals(4, updated);
} finally {
manageUseZoneForReplicaSetting(false);
manageReplicaBalanceSettingWithDefaultReplica(false);
randomIndexTemplate();
}
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -1031,7 +1031,7 @@ public void testPartitionedTemplate() throws Exception {
}

public void testAwarenessReplicaBalance() throws IOException {
manageUseZoneForReplicaSetting(true);
manageReplicaBalanceSettingWithDefaultReplica(true);
int updated = 0;
try {
client().admin()
Expand Down Expand Up @@ -1073,7 +1073,7 @@ public void testAwarenessReplicaBalance() throws IOException {
);
assertEquals(3, updated);
} finally {
manageUseZoneForReplicaSetting(false);
manageReplicaBalanceSettingWithDefaultReplica(false);
}
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -988,7 +988,7 @@ public void testRestoreBalancedReplica() {
.setIndices("test-index", ".system-index")
.setWaitForCompletion(true)
.get();
manageUseZoneForReplicaSetting(true);
manageReplicaBalanceSettingWithDefaultReplica(true);

final IllegalArgumentException restoreError = expectThrows(
IllegalArgumentException.class,
Expand Down Expand Up @@ -1051,7 +1051,7 @@ public void testRestoreBalancedReplica() {

assertThat(restoreSnapshotResponse.getRestoreInfo().totalShards(), greaterThan(0));
} finally {
manageUseZoneForReplicaSetting(false);
manageReplicaBalanceSettingWithDefaultReplica(false);
randomIndexTemplate();
}
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -162,7 +162,7 @@ public interface Custom extends NamedDiffable<Custom>, ToXContentFragment, Clust
}

public static final Setting<Integer> DEFAULT_REPLICA_COUNT_SETTING = Setting.intSetting(
"cluster.default_replica_count",
"cluster.default_number_of_replicas",
1,
Property.Dynamic,
Property.NodeScope
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -1072,6 +1072,13 @@ public void testParseMappingsWithTypelessTemplate() throws Exception {

public void testvalidateIndexSettings() {
ClusterService clusterService = mock(ClusterService.class);
Metadata metadata = Metadata.builder()
.transientSettings(Settings.builder().put(Metadata.DEFAULT_REPLICA_COUNT_SETTING.getKey(), 1).build())
.build();
ClusterState clusterState = ClusterState.builder(org.opensearch.cluster.ClusterName.CLUSTER_NAME_SETTING.getDefault(Settings.EMPTY))
.metadata(metadata)
.build();

ThreadPool threadPool = new TestThreadPool(getTestName());
Settings settings = Settings.builder()
.put(AwarenessAllocationDecider.CLUSTER_ROUTING_ALLOCATION_AWARENESS_ATTRIBUTE_SETTING.getKey(), "zone, rack")
Expand All @@ -1082,6 +1089,8 @@ public void testvalidateIndexSettings() {
ClusterSettings clusterSettings = new ClusterSettings(settings, ClusterSettings.BUILT_IN_CLUSTER_SETTINGS);
when(clusterService.getSettings()).thenReturn(settings);
when(clusterService.getClusterSettings()).thenReturn(clusterSettings);
when(clusterService.state()).thenReturn(clusterState);

MetadataCreateIndexService checkerService = new MetadataCreateIndexService(
settings,
clusterService,
Expand Down Expand Up @@ -1113,37 +1122,6 @@ public void testvalidateIndexSettings() {
validationErrors = checkerService.getIndexSettingsValidationErrors(settings, false, Optional.empty());
assertThat(validationErrors.size(), is(0));

settings = Settings.builder()
.put(AwarenessAllocationDecider.CLUSTER_ROUTING_ALLOCATION_AWARENESS_ATTRIBUTE_SETTING.getKey(), "zone, rack")
.put(AwarenessAllocationDecider.CLUSTER_ROUTING_ALLOCATION_AWARENESS_FORCE_GROUP_SETTING.getKey() + "zone.values", "a, b")
.put(AwarenessAllocationDecider.CLUSTER_ROUTING_ALLOCATION_AWARENESS_FORCE_GROUP_SETTING.getKey() + "rack.values", "c, d, e")
.put(AwarenessReplicaBalance.CLUSTER_ROUTING_ALLOCATION_AWARENESS_BALANCE_SETTING.getKey(), true)
.put(AwarenessReplicaBalance.FORCE_AWARENESS_REPLICA_SETTING.getKey(), true)
.build();

clusterSettings = new ClusterSettings(settings, ClusterSettings.BUILT_IN_CLUSTER_SETTINGS);
when(clusterService.getSettings()).thenReturn(settings);
when(clusterService.getClusterSettings()).thenReturn(clusterSettings);

checkerService = new MetadataCreateIndexService(
settings,
clusterService,
null,
null,
null,
createTestShardLimitService(randomIntBetween(1, 1000), false, clusterService),
new Environment(Settings.builder().put("path.home", "dummy").build(), null),
IndexScopedSettings.DEFAULT_SCOPED_SETTINGS,
threadPool,
null,
new SystemIndices(Collections.emptyMap()),
true,
new AwarenessReplicaBalance(settings, clusterService.getClusterSettings())
);

validationErrors = checkerService.getIndexSettingsValidationErrors(settings, false, Optional.empty());
assertThat(validationErrors.size(), is(0));

threadPool.shutdown();
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -39,30 +39,6 @@ public void testNoForcedAwarenessAttribute() {
assertEquals(awarenessReplicaBalance.validate(1, autoExpandReplica), Optional.empty());
}

public void testStaticMaxAwarenessAttributes() {
Settings settings = Settings.builder()
.put("cluster.routing.allocation.awareness.attributes", "rack_id")
.put(SETTING_AUTO_EXPAND_REPLICAS, "0-1")
.build();
assertThat(AwarenessReplicaBalance.maxAwarenessAttributes(settings), equalTo(1));

settings = Settings.builder()
.put(AwarenessAllocationDecider.CLUSTER_ROUTING_ALLOCATION_AWARENESS_ATTRIBUTE_SETTING.getKey(), "zone, rack")
.put(AwarenessAllocationDecider.CLUSTER_ROUTING_ALLOCATION_AWARENESS_FORCE_GROUP_SETTING.getKey() + "zone.values", "a, b")
.put(AwarenessAllocationDecider.CLUSTER_ROUTING_ALLOCATION_AWARENESS_FORCE_GROUP_SETTING.getKey() + "rack.values", "c, d, e")
.put(AwarenessReplicaBalance.CLUSTER_ROUTING_ALLOCATION_AWARENESS_BALANCE_SETTING.getKey(), true)
.put(SETTING_AUTO_EXPAND_REPLICAS, "0-2")
.build();
assertThat(AwarenessReplicaBalance.maxAwarenessAttributes(settings), equalTo(3));

settings = Settings.builder()
.put(AwarenessAllocationDecider.CLUSTER_ROUTING_ALLOCATION_AWARENESS_ATTRIBUTE_SETTING.getKey(), "zone, rack")
.put(AwarenessReplicaBalance.CLUSTER_ROUTING_ALLOCATION_AWARENESS_BALANCE_SETTING.getKey(), true)
.put(SETTING_AUTO_EXPAND_REPLICAS, "0-1")
.build();
assertThat(AwarenessReplicaBalance.maxAwarenessAttributes(settings), equalTo(1));
}

public void testForcedAwarenessAttribute() {
// When auto expand replica settings is as per zone awareness
Settings settings = Settings.builder()
Expand Down Expand Up @@ -155,33 +131,4 @@ public void testForcedAwarenessAttributeDisabled() {
assertEquals(awarenessReplicaBalance.validate(1, autoExpandReplica), Optional.empty());
}

public void testSetUseForceZoneForReplicaWhenAllocationAwarenessIsDefault() {
Settings settings = Settings.builder().put(AwarenessReplicaBalance.FORCE_AWARENESS_REPLICA_SETTING.getKey(), true).build();

IllegalArgumentException iae = expectThrows(
IllegalArgumentException.class,
() -> new AwarenessReplicaBalance(settings, EMPTY_CLUSTER_SETTINGS)
);
assertEquals(
"To enable cluster.routing.allocation.awareness.force_replica, cluster.routing.allocation.awareness.balance should be enabled",
iae.getMessage()
);
}

public void testSetUseForceZoneForReplicaWhenAllocationAwarenessIsFalse() {
Settings settings = Settings.builder()
.put(AwarenessReplicaBalance.CLUSTER_ROUTING_ALLOCATION_AWARENESS_BALANCE_SETTING.getKey(), false)
.put(AwarenessReplicaBalance.FORCE_AWARENESS_REPLICA_SETTING.getKey(), true)
.build();

IllegalArgumentException iae = expectThrows(
IllegalArgumentException.class,
() -> new AwarenessReplicaBalance(settings, EMPTY_CLUSTER_SETTINGS)
);
assertEquals(
"To enable cluster.routing.allocation.awareness.force_replica, cluster.routing.allocation.awareness.balance should be enabled",
iae.getMessage()
);
}

}
Original file line number Diff line number Diff line change
Expand Up @@ -2403,7 +2403,7 @@ public void manageReplicaBalanceSetting(boolean apply) {
assertAcked(client().admin().cluster().updateSettings(updateSettingsRequest).actionGet());
}

public void manageUseZoneForReplicaSetting(boolean apply) {
public void manageReplicaBalanceSettingWithDefaultReplica(boolean apply) {
Settings settings;
if (apply) {
settings = Settings.builder()
Expand All @@ -2413,14 +2413,14 @@ public void manageUseZoneForReplicaSetting(boolean apply) {
"a, b, c"
)
.put(AwarenessReplicaBalance.CLUSTER_ROUTING_ALLOCATION_AWARENESS_BALANCE_SETTING.getKey(), true)
.put(AwarenessReplicaBalance.FORCE_AWARENESS_REPLICA_SETTING.getKey(), true)
.put(Metadata.DEFAULT_REPLICA_COUNT_SETTING.getKey(), 2)
.build();
} else {
settings = Settings.builder()
.putNull(AwarenessAllocationDecider.CLUSTER_ROUTING_ALLOCATION_AWARENESS_ATTRIBUTE_SETTING.getKey())
.putNull(AwarenessAllocationDecider.CLUSTER_ROUTING_ALLOCATION_AWARENESS_FORCE_GROUP_SETTING.getKey() + "zone.values")
.putNull(AwarenessReplicaBalance.CLUSTER_ROUTING_ALLOCATION_AWARENESS_BALANCE_SETTING.getKey())
.putNull(AwarenessReplicaBalance.FORCE_AWARENESS_REPLICA_SETTING.getKey())
.putNull(Metadata.DEFAULT_REPLICA_COUNT_SETTING.getKey())
.build();
}
ClusterUpdateSettingsRequest updateSettingsRequest = new ClusterUpdateSettingsRequest();
Expand Down

0 comments on commit aa541ad

Please sign in to comment.