Encapsulate Client as class variable for PolicyStepsRegistry (#33529)
Rather than pass in the client on the `update` step, this makes it passed in to the constructor so it's not required on every update.
This commit is contained in:
parent
e0b99d7ab3
commit
8fa8dea138
|
@ -66,7 +66,7 @@ public class IndexLifecycleService extends AbstractComponent
|
||||||
this.clock = clock;
|
this.clock = clock;
|
||||||
this.nowSupplier = nowSupplier;
|
this.nowSupplier = nowSupplier;
|
||||||
this.scheduledJob = null;
|
this.scheduledJob = null;
|
||||||
this.policyRegistry = new PolicyStepsRegistry(xContentRegistry);
|
this.policyRegistry = new PolicyStepsRegistry(xContentRegistry, client);
|
||||||
this.lifecycleRunner = new IndexLifecycleRunner(policyRegistry, clusterService, nowSupplier);
|
this.lifecycleRunner = new IndexLifecycleRunner(policyRegistry, clusterService, nowSupplier);
|
||||||
this.pollInterval = LifecycleSettings.LIFECYCLE_POLL_INTERVAL_SETTING.get(settings);
|
this.pollInterval = LifecycleSettings.LIFECYCLE_POLL_INTERVAL_SETTING.get(settings);
|
||||||
clusterService.addStateApplier(this);
|
clusterService.addStateApplier(this);
|
||||||
|
@ -146,7 +146,7 @@ public class IndexLifecycleService extends AbstractComponent
|
||||||
policyRegistry.removeIndices(event.indicesDeleted());
|
policyRegistry.removeIndices(event.indicesDeleted());
|
||||||
}
|
}
|
||||||
if (event.state().metaData().custom(IndexLifecycleMetadata.TYPE) != null) {
|
if (event.state().metaData().custom(IndexLifecycleMetadata.TYPE) != null) {
|
||||||
policyRegistry.update(event.state(), client);
|
policyRegistry.update(event.state());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -45,6 +45,7 @@ import java.util.stream.Collectors;
|
||||||
public class PolicyStepsRegistry {
|
public class PolicyStepsRegistry {
|
||||||
private static final Logger logger = LogManager.getLogger(PolicyStepsRegistry.class);
|
private static final Logger logger = LogManager.getLogger(PolicyStepsRegistry.class);
|
||||||
|
|
||||||
|
private final Client client;
|
||||||
// keeps track of existing policies in the cluster state
|
// keeps track of existing policies in the cluster state
|
||||||
private final SortedMap<String, LifecyclePolicyMetadata> lifecyclePolicyMap;
|
private final SortedMap<String, LifecyclePolicyMetadata> lifecyclePolicyMap;
|
||||||
// keeps track of what the first step in a policy is, the key is policy name
|
// keeps track of what the first step in a policy is, the key is policy name
|
||||||
|
@ -55,22 +56,24 @@ public class PolicyStepsRegistry {
|
||||||
private final Map<Index, List<Step>> indexPhaseSteps;
|
private final Map<Index, List<Step>> indexPhaseSteps;
|
||||||
private final NamedXContentRegistry xContentRegistry;
|
private final NamedXContentRegistry xContentRegistry;
|
||||||
|
|
||||||
public PolicyStepsRegistry(NamedXContentRegistry xContentRegistry) {
|
public PolicyStepsRegistry(NamedXContentRegistry xContentRegistry, Client client) {
|
||||||
this.lifecyclePolicyMap = new TreeMap<>();
|
this.lifecyclePolicyMap = new TreeMap<>();
|
||||||
this.firstStepMap = new HashMap<>();
|
this.firstStepMap = new HashMap<>();
|
||||||
this.stepMap = new HashMap<>();
|
this.stepMap = new HashMap<>();
|
||||||
this.indexPhaseSteps = new HashMap<>();
|
this.indexPhaseSteps = new HashMap<>();
|
||||||
this.xContentRegistry = xContentRegistry;
|
this.xContentRegistry = xContentRegistry;
|
||||||
|
this.client = client;
|
||||||
}
|
}
|
||||||
|
|
||||||
PolicyStepsRegistry(SortedMap<String, LifecyclePolicyMetadata> lifecyclePolicyMap,
|
PolicyStepsRegistry(SortedMap<String, LifecyclePolicyMetadata> lifecyclePolicyMap,
|
||||||
Map<String, Step> firstStepMap, Map<String, Map<Step.StepKey, Step>> stepMap,
|
Map<String, Step> firstStepMap, Map<String, Map<Step.StepKey, Step>> stepMap,
|
||||||
Map<Index, List<Step>> indexPhaseSteps, NamedXContentRegistry xContentRegistry) {
|
Map<Index, List<Step>> indexPhaseSteps, NamedXContentRegistry xContentRegistry, Client client) {
|
||||||
this.lifecyclePolicyMap = lifecyclePolicyMap;
|
this.lifecyclePolicyMap = lifecyclePolicyMap;
|
||||||
this.firstStepMap = firstStepMap;
|
this.firstStepMap = firstStepMap;
|
||||||
this.stepMap = stepMap;
|
this.stepMap = stepMap;
|
||||||
this.indexPhaseSteps = indexPhaseSteps;
|
this.indexPhaseSteps = indexPhaseSteps;
|
||||||
this.xContentRegistry = xContentRegistry;
|
this.xContentRegistry = xContentRegistry;
|
||||||
|
this.client = client;
|
||||||
}
|
}
|
||||||
|
|
||||||
SortedMap<String, LifecyclePolicyMetadata> getLifecyclePolicyMap() {
|
SortedMap<String, LifecyclePolicyMetadata> getLifecyclePolicyMap() {
|
||||||
|
@ -97,7 +100,7 @@ public class PolicyStepsRegistry {
|
||||||
}
|
}
|
||||||
|
|
||||||
@SuppressWarnings({ "unchecked", "rawtypes" })
|
@SuppressWarnings({ "unchecked", "rawtypes" })
|
||||||
public void update(ClusterState clusterState, Client client) {
|
public void update(ClusterState clusterState) {
|
||||||
final IndexLifecycleMetadata meta = clusterState.metaData().custom(IndexLifecycleMetadata.TYPE);
|
final IndexLifecycleMetadata meta = clusterState.metaData().custom(IndexLifecycleMetadata.TYPE);
|
||||||
|
|
||||||
assert meta != null : "IndexLifecycleMetadata cannot be null when updating the policy steps registry";
|
assert meta != null : "IndexLifecycleMetadata cannot be null when updating the policy steps registry";
|
||||||
|
|
|
@ -100,7 +100,7 @@ public class ExecuteStepsUpdateTaskTests extends ESTestCase {
|
||||||
randomNonNegativeLong(), randomNonNegativeLong()));
|
randomNonNegativeLong(), randomNonNegativeLong()));
|
||||||
policyMap.put(invalidPolicyName, new LifecyclePolicyMetadata(invalidPolicy, Collections.emptyMap(),
|
policyMap.put(invalidPolicyName, new LifecyclePolicyMetadata(invalidPolicy, Collections.emptyMap(),
|
||||||
randomNonNegativeLong(), randomNonNegativeLong()));
|
randomNonNegativeLong(), randomNonNegativeLong()));
|
||||||
policyStepsRegistry = new PolicyStepsRegistry(NamedXContentRegistry.EMPTY);
|
policyStepsRegistry = new PolicyStepsRegistry(NamedXContentRegistry.EMPTY, client);
|
||||||
|
|
||||||
indexName = randomAlphaOfLength(5);
|
indexName = randomAlphaOfLength(5);
|
||||||
lifecycleMetadata = new IndexLifecycleMetadata(policyMap, OperationMode.RUNNING);
|
lifecycleMetadata = new IndexLifecycleMetadata(policyMap, OperationMode.RUNNING);
|
||||||
|
@ -130,7 +130,7 @@ public class ExecuteStepsUpdateTaskTests extends ESTestCase {
|
||||||
.metaData(metaData)
|
.metaData(metaData)
|
||||||
.nodes(DiscoveryNodes.builder().localNodeId(nodeId).masterNodeId(nodeId).add(masterNode).build())
|
.nodes(DiscoveryNodes.builder().localNodeId(nodeId).masterNodeId(nodeId).add(masterNode).build())
|
||||||
.build();
|
.build();
|
||||||
policyStepsRegistry.update(clusterState, client);
|
policyStepsRegistry.update(clusterState);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testNeverExecuteNonClusterStateStep() throws IOException {
|
public void testNeverExecuteNonClusterStateStep() throws IOException {
|
||||||
|
@ -165,7 +165,7 @@ public class ExecuteStepsUpdateTaskTests extends ESTestCase {
|
||||||
.put(LifecycleSettings.LIFECYCLE_PHASE, (String) null)
|
.put(LifecycleSettings.LIFECYCLE_PHASE, (String) null)
|
||||||
.put(LifecycleSettings.LIFECYCLE_ACTION, (String) null)
|
.put(LifecycleSettings.LIFECYCLE_ACTION, (String) null)
|
||||||
.put(LifecycleSettings.LIFECYCLE_STEP, (String) null).build()))).build();
|
.put(LifecycleSettings.LIFECYCLE_STEP, (String) null).build()))).build();
|
||||||
policyStepsRegistry.update(clusterState, client);
|
policyStepsRegistry.update(clusterState);
|
||||||
|
|
||||||
Step invalidStep = new MockClusterStateActionStep(firstStepKey, secondStepKey);
|
Step invalidStep = new MockClusterStateActionStep(firstStepKey, secondStepKey);
|
||||||
long now = randomNonNegativeLong();
|
long now = randomNonNegativeLong();
|
||||||
|
@ -230,6 +230,6 @@ public class ExecuteStepsUpdateTaskTests extends ESTestCase {
|
||||||
.put(LifecycleSettings.LIFECYCLE_PHASE, stepKey.getPhase())
|
.put(LifecycleSettings.LIFECYCLE_PHASE, stepKey.getPhase())
|
||||||
.put(LifecycleSettings.LIFECYCLE_ACTION, stepKey.getAction())
|
.put(LifecycleSettings.LIFECYCLE_ACTION, stepKey.getAction())
|
||||||
.put(LifecycleSettings.LIFECYCLE_STEP, stepKey.getName()).build()))).build();
|
.put(LifecycleSettings.LIFECYCLE_STEP, stepKey.getName()).build()))).build();
|
||||||
policyStepsRegistry.update(clusterState, client);
|
policyStepsRegistry.update(clusterState);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -82,7 +82,7 @@ public class IndexLifecycleRunnerTests extends ESTestCase {
|
||||||
steps.add(step);
|
steps.add(step);
|
||||||
Index index = new Index(indexName, indexName + "uuid");
|
Index index = new Index(indexName, indexName + "uuid");
|
||||||
indexSteps.put(index, steps);
|
indexSteps.put(index, steps);
|
||||||
return new PolicyStepsRegistry(lifecyclePolicyMap, firstStepMap, stepMap, indexSteps, NamedXContentRegistry.EMPTY);
|
return new PolicyStepsRegistry(lifecyclePolicyMap, firstStepMap, stepMap, indexSteps, NamedXContentRegistry.EMPTY, null);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testRunPolicyTerminalPolicyStep() {
|
public void testRunPolicyTerminalPolicyStep() {
|
||||||
|
@ -344,7 +344,7 @@ public class IndexLifecycleRunnerTests extends ESTestCase {
|
||||||
public void testRunPolicyWithNoStepsInRegistry() {
|
public void testRunPolicyWithNoStepsInRegistry() {
|
||||||
String policyName = "cluster_state_action_policy";
|
String policyName = "cluster_state_action_policy";
|
||||||
ClusterService clusterService = mock(ClusterService.class);
|
ClusterService clusterService = mock(ClusterService.class);
|
||||||
IndexLifecycleRunner runner = new IndexLifecycleRunner(new PolicyStepsRegistry(NamedXContentRegistry.EMPTY),
|
IndexLifecycleRunner runner = new IndexLifecycleRunner(new PolicyStepsRegistry(NamedXContentRegistry.EMPTY, null),
|
||||||
clusterService, () -> 0L);
|
clusterService, () -> 0L);
|
||||||
IndexMetaData indexMetaData = IndexMetaData.builder("my_index").settings(settings(Version.CURRENT))
|
IndexMetaData indexMetaData = IndexMetaData.builder("my_index").settings(settings(Version.CURRENT))
|
||||||
.numberOfShards(randomIntBetween(1, 5)).numberOfReplicas(randomIntBetween(0, 5)).build();
|
.numberOfShards(randomIntBetween(1, 5)).numberOfReplicas(randomIntBetween(0, 5)).build();
|
||||||
|
@ -472,7 +472,7 @@ public class IndexLifecycleRunnerTests extends ESTestCase {
|
||||||
Index index = new Index("test", "uuid");
|
Index index = new Index("test", "uuid");
|
||||||
indexSteps.put(index, phase1Steps);
|
indexSteps.put(index, phase1Steps);
|
||||||
PolicyStepsRegistry registry = new PolicyStepsRegistry(lifecyclePolicyMap, firstStepMap, stepMap, indexSteps,
|
PolicyStepsRegistry registry = new PolicyStepsRegistry(lifecyclePolicyMap, firstStepMap, stepMap, indexSteps,
|
||||||
NamedXContentRegistry.EMPTY);
|
NamedXContentRegistry.EMPTY, null);
|
||||||
|
|
||||||
Settings indexSettings = Settings.EMPTY;
|
Settings indexSettings = Settings.EMPTY;
|
||||||
Step actualStep = IndexLifecycleRunner.getCurrentStep(registry, policyName, index, indexSettings);
|
Step actualStep = IndexLifecycleRunner.getCurrentStep(registry, policyName, index, indexSettings);
|
||||||
|
@ -506,7 +506,7 @@ public class IndexLifecycleRunnerTests extends ESTestCase {
|
||||||
// TODO: it'd be nice if we used the actual registry.update method for this
|
// TODO: it'd be nice if we used the actual registry.update method for this
|
||||||
indexSteps.clear();
|
indexSteps.clear();
|
||||||
indexSteps.put(index, Collections.singletonList(fourthStep));
|
indexSteps.put(index, Collections.singletonList(fourthStep));
|
||||||
registry = new PolicyStepsRegistry(lifecyclePolicyMap, firstStepMap, stepMap, indexSteps, NamedXContentRegistry.EMPTY);
|
registry = new PolicyStepsRegistry(lifecyclePolicyMap, firstStepMap, stepMap, indexSteps, NamedXContentRegistry.EMPTY, null);
|
||||||
|
|
||||||
indexSettings = Settings.builder()
|
indexSettings = Settings.builder()
|
||||||
.put(LifecycleSettings.LIFECYCLE_PHASE, "phase_2")
|
.put(LifecycleSettings.LIFECYCLE_PHASE, "phase_2")
|
||||||
|
@ -527,7 +527,7 @@ public class IndexLifecycleRunnerTests extends ESTestCase {
|
||||||
// Back to phase_1
|
// Back to phase_1
|
||||||
indexSteps.clear();
|
indexSteps.clear();
|
||||||
indexSteps.put(index, phase1Steps);
|
indexSteps.put(index, phase1Steps);
|
||||||
registry = new PolicyStepsRegistry(lifecyclePolicyMap, firstStepMap, stepMap, indexSteps, NamedXContentRegistry.EMPTY);
|
registry = new PolicyStepsRegistry(lifecyclePolicyMap, firstStepMap, stepMap, indexSteps, NamedXContentRegistry.EMPTY, null);
|
||||||
|
|
||||||
indexSettings = Settings.builder()
|
indexSettings = Settings.builder()
|
||||||
.put(LifecycleSettings.LIFECYCLE_PHASE, "phase_1")
|
.put(LifecycleSettings.LIFECYCLE_PHASE, "phase_1")
|
||||||
|
@ -1080,7 +1080,7 @@ public class IndexLifecycleRunnerTests extends ESTestCase {
|
||||||
Map<String, Map<StepKey, Step>> stepMap = Collections.singletonMap(policyName, policySteps);
|
Map<String, Map<StepKey, Step>> stepMap = Collections.singletonMap(policyName, policySteps);
|
||||||
Map<Index, List<Step>> indexSteps = Collections.singletonMap(index, Collections.singletonList(step));
|
Map<Index, List<Step>> indexSteps = Collections.singletonMap(index, Collections.singletonList(step));
|
||||||
PolicyStepsRegistry policyStepsRegistry = new PolicyStepsRegistry(lifecyclePolicyMap, firstStepMap,
|
PolicyStepsRegistry policyStepsRegistry = new PolicyStepsRegistry(lifecyclePolicyMap, firstStepMap,
|
||||||
stepMap, indexSteps, NamedXContentRegistry.EMPTY);
|
stepMap, indexSteps, NamedXContentRegistry.EMPTY, null);
|
||||||
ClusterService clusterService = mock(ClusterService.class);
|
ClusterService clusterService = mock(ClusterService.class);
|
||||||
final AtomicLong now = new AtomicLong(5);
|
final AtomicLong now = new AtomicLong(5);
|
||||||
IndexLifecycleRunner runner = new IndexLifecycleRunner(policyStepsRegistry, clusterService, now::get);
|
IndexLifecycleRunner runner = new IndexLifecycleRunner(policyStepsRegistry, clusterService, now::get);
|
||||||
|
|
|
@ -54,7 +54,7 @@ public class PolicyStepsRegistryTests extends ESTestCase {
|
||||||
String policyName = randomAlphaOfLengthBetween(2, 10);
|
String policyName = randomAlphaOfLengthBetween(2, 10);
|
||||||
Step expectedFirstStep = new MockStep(MOCK_STEP_KEY, null);
|
Step expectedFirstStep = new MockStep(MOCK_STEP_KEY, null);
|
||||||
Map<String, Step> firstStepMap = Collections.singletonMap(policyName, expectedFirstStep);
|
Map<String, Step> firstStepMap = Collections.singletonMap(policyName, expectedFirstStep);
|
||||||
PolicyStepsRegistry registry = new PolicyStepsRegistry(null, firstStepMap, null, null, NamedXContentRegistry.EMPTY);
|
PolicyStepsRegistry registry = new PolicyStepsRegistry(null, firstStepMap, null, null, NamedXContentRegistry.EMPTY, null);
|
||||||
Step actualFirstStep = registry.getFirstStep(policyName);
|
Step actualFirstStep = registry.getFirstStep(policyName);
|
||||||
assertThat(actualFirstStep, sameInstance(expectedFirstStep));
|
assertThat(actualFirstStep, sameInstance(expectedFirstStep));
|
||||||
}
|
}
|
||||||
|
@ -63,7 +63,7 @@ public class PolicyStepsRegistryTests extends ESTestCase {
|
||||||
String policyName = randomAlphaOfLengthBetween(2, 10);
|
String policyName = randomAlphaOfLengthBetween(2, 10);
|
||||||
Step expectedFirstStep = new MockStep(MOCK_STEP_KEY, null);
|
Step expectedFirstStep = new MockStep(MOCK_STEP_KEY, null);
|
||||||
Map<String, Step> firstStepMap = Collections.singletonMap(policyName, expectedFirstStep);
|
Map<String, Step> firstStepMap = Collections.singletonMap(policyName, expectedFirstStep);
|
||||||
PolicyStepsRegistry registry = new PolicyStepsRegistry(null, firstStepMap, null, null, NamedXContentRegistry.EMPTY);
|
PolicyStepsRegistry registry = new PolicyStepsRegistry(null, firstStepMap, null, null, NamedXContentRegistry.EMPTY, null);
|
||||||
Step actualFirstStep = registry.getFirstStep(policyName + "unknown");
|
Step actualFirstStep = registry.getFirstStep(policyName + "unknown");
|
||||||
assertNull(actualFirstStep);
|
assertNull(actualFirstStep);
|
||||||
}
|
}
|
||||||
|
@ -72,7 +72,7 @@ public class PolicyStepsRegistryTests extends ESTestCase {
|
||||||
Step expectedStep = new MockStep(MOCK_STEP_KEY, null);
|
Step expectedStep = new MockStep(MOCK_STEP_KEY, null);
|
||||||
Index index = new Index("test", "uuid");
|
Index index = new Index("test", "uuid");
|
||||||
Map<Index, List<Step>> indexSteps = Collections.singletonMap(index, Collections.singletonList(expectedStep));
|
Map<Index, List<Step>> indexSteps = Collections.singletonMap(index, Collections.singletonList(expectedStep));
|
||||||
PolicyStepsRegistry registry = new PolicyStepsRegistry(null, null, null, indexSteps, NamedXContentRegistry.EMPTY);
|
PolicyStepsRegistry registry = new PolicyStepsRegistry(null, null, null, indexSteps, NamedXContentRegistry.EMPTY, null);
|
||||||
Step actualStep = registry.getStep(index, MOCK_STEP_KEY);
|
Step actualStep = registry.getStep(index, MOCK_STEP_KEY);
|
||||||
assertThat(actualStep, sameInstance(expectedStep));
|
assertThat(actualStep, sameInstance(expectedStep));
|
||||||
}
|
}
|
||||||
|
@ -82,13 +82,13 @@ public class PolicyStepsRegistryTests extends ESTestCase {
|
||||||
Step expectedStep = new ErrorStep(errorStepKey);
|
Step expectedStep = new ErrorStep(errorStepKey);
|
||||||
Index index = new Index("test", "uuid");
|
Index index = new Index("test", "uuid");
|
||||||
Map<Index, List<Step>> indexSteps = Collections.singletonMap(index, Collections.singletonList(expectedStep));
|
Map<Index, List<Step>> indexSteps = Collections.singletonMap(index, Collections.singletonList(expectedStep));
|
||||||
PolicyStepsRegistry registry = new PolicyStepsRegistry(null, null, null, indexSteps, NamedXContentRegistry.EMPTY);
|
PolicyStepsRegistry registry = new PolicyStepsRegistry(null, null, null, indexSteps, NamedXContentRegistry.EMPTY, null);
|
||||||
Step actualStep = registry.getStep(index, errorStepKey);
|
Step actualStep = registry.getStep(index, errorStepKey);
|
||||||
assertThat(actualStep, equalTo(expectedStep));
|
assertThat(actualStep, equalTo(expectedStep));
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testGetStepUnknownPolicy() {
|
public void testGetStepUnknownPolicy() {
|
||||||
PolicyStepsRegistry registry = new PolicyStepsRegistry(null, null, null, Collections.emptyMap(), NamedXContentRegistry.EMPTY);
|
PolicyStepsRegistry registry = new PolicyStepsRegistry(null, null, null, Collections.emptyMap(), NamedXContentRegistry.EMPTY, null);
|
||||||
assertNull(registry.getStep(new Index("test", "uuid"), MOCK_STEP_KEY));
|
assertNull(registry.getStep(new Index("test", "uuid"), MOCK_STEP_KEY));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -96,7 +96,7 @@ public class PolicyStepsRegistryTests extends ESTestCase {
|
||||||
Step expectedStep = new MockStep(MOCK_STEP_KEY, null);
|
Step expectedStep = new MockStep(MOCK_STEP_KEY, null);
|
||||||
Index index = new Index("test", "uuid");
|
Index index = new Index("test", "uuid");
|
||||||
Map<Index, List<Step>> indexSteps = Collections.singletonMap(index, Collections.singletonList(expectedStep));
|
Map<Index, List<Step>> indexSteps = Collections.singletonMap(index, Collections.singletonList(expectedStep));
|
||||||
PolicyStepsRegistry registry = new PolicyStepsRegistry(null, null, null, indexSteps, NamedXContentRegistry.EMPTY);
|
PolicyStepsRegistry registry = new PolicyStepsRegistry(null, null, null, indexSteps, NamedXContentRegistry.EMPTY, null);
|
||||||
Step.StepKey unknownStepKey = new Step.StepKey(MOCK_STEP_KEY.getPhase(),
|
Step.StepKey unknownStepKey = new Step.StepKey(MOCK_STEP_KEY.getPhase(),
|
||||||
MOCK_STEP_KEY.getAction(),MOCK_STEP_KEY.getName() + "not");
|
MOCK_STEP_KEY.getAction(),MOCK_STEP_KEY.getName() + "not");
|
||||||
assertNull(registry.getStep(index, unknownStepKey));
|
assertNull(registry.getStep(index, unknownStepKey));
|
||||||
|
@ -146,10 +146,10 @@ public class PolicyStepsRegistryTests extends ESTestCase {
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
// start with empty registry
|
// start with empty registry
|
||||||
PolicyStepsRegistry registry = new PolicyStepsRegistry(NamedXContentRegistry.EMPTY);
|
PolicyStepsRegistry registry = new PolicyStepsRegistry(NamedXContentRegistry.EMPTY, client);
|
||||||
|
|
||||||
// add new policy
|
// add new policy
|
||||||
registry.update(currentState, client);
|
registry.update(currentState);
|
||||||
|
|
||||||
assertThat(registry.getFirstStep(newPolicy.getName()), equalTo(policySteps.get(0)));
|
assertThat(registry.getFirstStep(newPolicy.getName()), equalTo(policySteps.get(0)));
|
||||||
assertThat(registry.getLifecyclePolicyMap().size(), equalTo(1));
|
assertThat(registry.getLifecyclePolicyMap().size(), equalTo(1));
|
||||||
|
@ -167,7 +167,7 @@ public class PolicyStepsRegistryTests extends ESTestCase {
|
||||||
.put(LifecycleSettings.LIFECYCLE_PHASE, step.getKey().getPhase()))))
|
.put(LifecycleSettings.LIFECYCLE_PHASE, step.getKey().getPhase()))))
|
||||||
.nodes(DiscoveryNodes.builder().localNodeId(nodeId).masterNodeId(nodeId).add(masterNode).build())
|
.nodes(DiscoveryNodes.builder().localNodeId(nodeId).masterNodeId(nodeId).add(masterNode).build())
|
||||||
.build();
|
.build();
|
||||||
registry.update(currentState, client);
|
registry.update(currentState);
|
||||||
assertThat(registeredStepsForPolicy.get(step.getKey()), equalTo(step));
|
assertThat(registeredStepsForPolicy.get(step.getKey()), equalTo(step));
|
||||||
assertThat(registry.getStep(index, step.getKey()), equalTo(step));
|
assertThat(registry.getStep(index, step.getKey()), equalTo(step));
|
||||||
}
|
}
|
||||||
|
@ -175,7 +175,7 @@ public class PolicyStepsRegistryTests extends ESTestCase {
|
||||||
Map<String, LifecyclePolicyMetadata> registryPolicyMap = registry.getLifecyclePolicyMap();
|
Map<String, LifecyclePolicyMetadata> registryPolicyMap = registry.getLifecyclePolicyMap();
|
||||||
Map<String, Step> registryFirstStepMap = registry.getFirstStepMap();
|
Map<String, Step> registryFirstStepMap = registry.getFirstStepMap();
|
||||||
Map<String, Map<Step.StepKey, Step>> registryStepMap = registry.getStepMap();
|
Map<String, Map<Step.StepKey, Step>> registryStepMap = registry.getStepMap();
|
||||||
registry.update(currentState, client);
|
registry.update(currentState);
|
||||||
assertThat(registry.getLifecyclePolicyMap(), equalTo(registryPolicyMap));
|
assertThat(registry.getLifecyclePolicyMap(), equalTo(registryPolicyMap));
|
||||||
assertThat(registry.getFirstStepMap(), equalTo(registryFirstStepMap));
|
assertThat(registry.getFirstStepMap(), equalTo(registryFirstStepMap));
|
||||||
assertThat(registry.getStepMap(), equalTo(registryStepMap));
|
assertThat(registry.getStepMap(), equalTo(registryStepMap));
|
||||||
|
@ -186,13 +186,13 @@ public class PolicyStepsRegistryTests extends ESTestCase {
|
||||||
.metaData(
|
.metaData(
|
||||||
MetaData.builder(metaData)
|
MetaData.builder(metaData)
|
||||||
.putCustom(IndexLifecycleMetadata.TYPE, lifecycleMetadata)).build();
|
.putCustom(IndexLifecycleMetadata.TYPE, lifecycleMetadata)).build();
|
||||||
registry.update(currentState, client);
|
registry.update(currentState);
|
||||||
assertTrue(registry.getLifecyclePolicyMap().isEmpty());
|
assertTrue(registry.getLifecyclePolicyMap().isEmpty());
|
||||||
assertTrue(registry.getFirstStepMap().isEmpty());
|
assertTrue(registry.getFirstStepMap().isEmpty());
|
||||||
assertTrue(registry.getStepMap().isEmpty());
|
assertTrue(registry.getStepMap().isEmpty());
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testUpdateChangedPolicy() throws Exception {
|
public void testUpdateChangedPolicy() {
|
||||||
Client client = Mockito.mock(Client.class);
|
Client client = Mockito.mock(Client.class);
|
||||||
Mockito.when(client.settings()).thenReturn(Settings.EMPTY);
|
Mockito.when(client.settings()).thenReturn(Settings.EMPTY);
|
||||||
String policyName = randomAlphaOfLengthBetween(5, 10);
|
String policyName = randomAlphaOfLengthBetween(5, 10);
|
||||||
|
@ -217,9 +217,9 @@ public class PolicyStepsRegistryTests extends ESTestCase {
|
||||||
.metaData(metaData)
|
.metaData(metaData)
|
||||||
.nodes(DiscoveryNodes.builder().localNodeId(nodeId).masterNodeId(nodeId).add(masterNode).build())
|
.nodes(DiscoveryNodes.builder().localNodeId(nodeId).masterNodeId(nodeId).add(masterNode).build())
|
||||||
.build();
|
.build();
|
||||||
PolicyStepsRegistry registry = new PolicyStepsRegistry(NamedXContentRegistry.EMPTY);
|
PolicyStepsRegistry registry = new PolicyStepsRegistry(NamedXContentRegistry.EMPTY, client);
|
||||||
// add new policy
|
// add new policy
|
||||||
registry.update(currentState, client);
|
registry.update(currentState);
|
||||||
|
|
||||||
// swap out policy
|
// swap out policy
|
||||||
newPolicy = LifecyclePolicyTests.randomTestLifecyclePolicy(policyName);
|
newPolicy = LifecyclePolicyTests.randomTestLifecyclePolicy(policyName);
|
||||||
|
@ -228,7 +228,7 @@ public class PolicyStepsRegistryTests extends ESTestCase {
|
||||||
randomNonNegativeLong(), randomNonNegativeLong())), OperationMode.RUNNING);
|
randomNonNegativeLong(), randomNonNegativeLong())), OperationMode.RUNNING);
|
||||||
currentState = ClusterState.builder(currentState)
|
currentState = ClusterState.builder(currentState)
|
||||||
.metaData(MetaData.builder(metaData).putCustom(IndexLifecycleMetadata.TYPE, lifecycleMetadata)).build();
|
.metaData(MetaData.builder(metaData).putCustom(IndexLifecycleMetadata.TYPE, lifecycleMetadata)).build();
|
||||||
registry.update(currentState, client);
|
registry.update(currentState);
|
||||||
// TODO(talevy): assert changes... right now we do not support updates to policies. will require internal cleanup
|
// TODO(talevy): assert changes... right now we do not support updates to policies. will require internal cleanup
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -287,10 +287,10 @@ public class PolicyStepsRegistryTests extends ESTestCase {
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
// start with empty registry
|
// start with empty registry
|
||||||
PolicyStepsRegistry registry = new PolicyStepsRegistry(NamedXContentRegistry.EMPTY);
|
PolicyStepsRegistry registry = new PolicyStepsRegistry(NamedXContentRegistry.EMPTY, client);
|
||||||
|
|
||||||
// add new policy
|
// add new policy
|
||||||
registry.update(currentState, client);
|
registry.update(currentState);
|
||||||
|
|
||||||
Map<Step.StepKey, Step> registeredStepsForPolicy = registry.getStepMap().get(newPolicy.getName());
|
Map<Step.StepKey, Step> registeredStepsForPolicy = registry.getStepMap().get(newPolicy.getName());
|
||||||
Step shrinkStep = registeredStepsForPolicy.entrySet().stream()
|
Step shrinkStep = registeredStepsForPolicy.entrySet().stream()
|
||||||
|
@ -316,7 +316,7 @@ public class PolicyStepsRegistryTests extends ESTestCase {
|
||||||
currentState = ClusterState.builder(ClusterName.DEFAULT).metaData(metaData).build();
|
currentState = ClusterState.builder(ClusterName.DEFAULT).metaData(metaData).build();
|
||||||
|
|
||||||
// Update the policies
|
// Update the policies
|
||||||
registry.update(currentState, client);
|
registry.update(currentState);
|
||||||
|
|
||||||
registeredStepsForPolicy = registry.getStepMap().get(newPolicy.getName());
|
registeredStepsForPolicy = registry.getStepMap().get(newPolicy.getName());
|
||||||
shrinkStep = registeredStepsForPolicy.entrySet().stream()
|
shrinkStep = registeredStepsForPolicy.entrySet().stream()
|
||||||
|
|
Loading…
Reference in New Issue