-
Notifications
You must be signed in to change notification settings - Fork 1.9k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
[Backport 2.x] Add wait_for_completion parameter to resize, open, and…
… forcemerge APIs (#6855) * Add wait_for_completion parameter to resize, open, and forcemerge APIs (#6434) * Add wait_for_completion parameter to resize&open&forcemerge APIs (#6228) Signed-off-by: Gao Binlong <[email protected]> * Modify changelog Signed-off-by: Gao Binlong <[email protected]> * fix test failure Signed-off-by: Gao Binlong <[email protected]> * Fix test failure Signed-off-by: Gao Binlong <[email protected]> * change header of new file Signed-off-by: Gao Binlong <[email protected]> * modify changelog Signed-off-by: Gao Binlong <[email protected]> --------- Signed-off-by: Gao Binlong <[email protected]> (cherry picked from commit 3fec567) Modify the yaml test file Signed-off-by: Gao Binlong <[email protected]> * Modify package name Signed-off-by: Gao Binlong <[email protected]> --------- Signed-off-by: Gao Binlong <[email protected]> Co-authored-by: Andrew Ross <[email protected]>
- Loading branch information
1 parent
ac79a63
commit 47a95e4
Showing
31 changed files
with
778 additions
and
76 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
88 changes: 88 additions & 0 deletions
88
rest-api-spec/src/main/resources/rest-api-spec/test/indices.clone/40_wait_for_completion.yml
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,88 @@ | ||
--- | ||
"Clone index with wait_for_completion": | ||
# clone index with wait_for_completion parameter, when the parameter is set to false, the API | ||
# will return a task immediately and the clone operation will run in background. | ||
|
||
- skip: | ||
version: " - 2.6.99" | ||
reason: "only available in 2.7+" | ||
features: allowed_warnings | ||
|
||
- do: | ||
nodes.info: | ||
node_id: data:true | ||
- set: | ||
nodes._arbitrary_key_: node_id | ||
|
||
- do: | ||
indices.create: | ||
index: source | ||
wait_for_active_shards: 1 | ||
body: | ||
settings: | ||
# ensure everything is allocated on the same data node | ||
index.routing.allocation.include._id: $node_id | ||
index.number_of_shards: 1 | ||
index.number_of_replicas: 0 | ||
- do: | ||
index: | ||
index: source | ||
id: "1" | ||
body: { "foo": "hello world" } | ||
|
||
- do: | ||
get: | ||
index: source | ||
id: "1" | ||
|
||
- match: { _index: source } | ||
- match: { _id: "1" } | ||
- match: { _source: { foo: "hello world" } } | ||
|
||
# make it read-only | ||
- do: | ||
indices.put_settings: | ||
index: source | ||
body: | ||
index.blocks.write: true | ||
index.number_of_replicas: 0 | ||
|
||
- do: | ||
cluster.health: | ||
wait_for_status: green | ||
index: source | ||
|
||
# clone with wait_for_completion | ||
- do: | ||
indices.clone: | ||
index: "source" | ||
target: "new_cloned_index" | ||
wait_for_active_shards: 1 | ||
cluster_manager_timeout: 10s | ||
wait_for_completion: false | ||
task_execution_timeout: 30s | ||
body: | ||
settings: | ||
index.number_of_shards: 1 | ||
"index.number_of_replicas": 0 | ||
|
||
- match: { task: /^.+$/ } | ||
- set: { task: taskId } | ||
|
||
- do: | ||
tasks.get: | ||
wait_for_completion: true | ||
task_id: $taskId | ||
- match: { task.action: "indices:admin/resize" } | ||
- match: { task.description: "clone from [source] to [new_cloned_index]" } | ||
|
||
# .tasks index is created when the clone index operation completes, so we should delete .tasks index finally, | ||
# if not, the .tasks index may introduce unexpected warnings and then cause other test cases to fail. | ||
# Delete the .tasks index directly will also introduce warning, but currently we don't have such APIs which can delete one | ||
# specified task or clear all completed tasks, so we have to do so. Expect we can introduce more tasks related APIs in future | ||
- do: | ||
allowed_warnings: | ||
- "this request accesses system indices: [.tasks], but in a future major version, direct access to system indices will be prevented by default" | ||
indices.delete: | ||
index: .tasks | ||
ignore_unavailable: true |
39 changes: 39 additions & 0 deletions
39
...-spec/src/main/resources/rest-api-spec/test/indices.forcemerge/20_wait_for_completion.yml
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,39 @@ | ||
--- | ||
"Force merge index with wait_for_completion": | ||
# force merge index with wait_for_completion parameter, when the parameter is set to false, the API | ||
# will return a task immediately and the merge process will run in background. | ||
|
||
- skip: | ||
version: " - 2.6.99" | ||
reason: "only available in 2.7+" | ||
features: allowed_warnings | ||
|
||
- do: | ||
indices.create: | ||
index: test_index | ||
|
||
- do: | ||
indices.forcemerge: | ||
index: test_index | ||
wait_for_completion: false | ||
max_num_segments: 1 | ||
- match: { task: /^.+$/ } | ||
- set: { task: taskId } | ||
|
||
- do: | ||
tasks.get: | ||
wait_for_completion: true | ||
task_id: $taskId | ||
- match: { task.action: "indices:admin/forcemerge" } | ||
- match: { task.description: "Force-merge indices [test_index], maxSegments[1], onlyExpungeDeletes[false], flush[true]" } | ||
|
||
# .tasks index is created when the force-merge operation completes, so we should delete .tasks index finally, | ||
# if not, the .tasks index may introduce unexpected warnings and then cause other test cases to fail. | ||
# Delete the .tasks index directly will also introduce warning, but currently we don't have such APIs which can delete one | ||
# specified task or clear all completed tasks, so we have to do so. Expect we can introduce more tasks related APIs in future | ||
- do: | ||
allowed_warnings: | ||
- "this request accesses system indices: [.tasks], but in a future major version, direct access to system indices will be prevented by default" | ||
indices.delete: | ||
index: .tasks | ||
ignore_unavailable: true |
50 changes: 50 additions & 0 deletions
50
rest-api-spec/src/main/resources/rest-api-spec/test/indices.open/30_wait_for_completion.yml
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,50 @@ | ||
--- | ||
"Open index with wait_for_completion": | ||
# open index with wait_for_completion parameter, when the parameter is set to false, the API | ||
# will return a task immediately and the open operation will run in background. | ||
|
||
- skip: | ||
version: " - 2.6.99" | ||
reason: "only available in 2.7+" | ||
features: allowed_warnings | ||
|
||
- do: | ||
indices.create: | ||
index: test_index | ||
body: | ||
settings: | ||
number_of_replicas: 0 | ||
number_of_shards: 1 | ||
|
||
- do: | ||
indices.close: | ||
index: test_index | ||
- is_true: acknowledged | ||
|
||
- do: | ||
indices.open: | ||
index: test_index | ||
wait_for_active_shards: all | ||
cluster_manager_timeout: 10s | ||
wait_for_completion: false | ||
task_execution_timeout: 30s | ||
- match: { task: /^.+$/ } | ||
- set: { task: taskId } | ||
|
||
- do: | ||
tasks.get: | ||
wait_for_completion: true | ||
task_id: $taskId | ||
- match: { task.action: "indices:admin/open" } | ||
- match: { task.description: "open indices [test_index]" } | ||
|
||
# .tasks index is created when the open index operation completes, so we should delete .tasks index finally, | ||
# if not, the .tasks index may introduce unexpected warnings and then cause other test cases to fail. | ||
# Delete the .tasks index directly will also introduce warning, but currently we don't have such APIs which can delete one | ||
# specified task or clear all completed tasks, so we have to do so. Expect we can introduce more tasks related APIs in future | ||
- do: | ||
allowed_warnings: | ||
- "this request accesses system indices: [.tasks], but in a future major version, direct access to system indices will be prevented by default" | ||
indices.delete: | ||
index: .tasks | ||
ignore_unavailable: true |
88 changes: 88 additions & 0 deletions
88
...-api-spec/src/main/resources/rest-api-spec/test/indices.shrink/50_wait_for_completion.yml
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,88 @@ | ||
--- | ||
"Shrink index with wait_for_completion": | ||
# shrink index with wait_for_completion parameter, when the parameter is set to false, the API | ||
# will return a task immediately and the shrink operation will run in background. | ||
|
||
- skip: | ||
version: " - 2.6.99" | ||
reason: "only available in 2.7+" | ||
features: allowed_warnings | ||
|
||
- do: | ||
nodes.info: | ||
node_id: data:true | ||
- set: | ||
nodes._arbitrary_key_: node_id | ||
|
||
- do: | ||
indices.create: | ||
index: source | ||
wait_for_active_shards: 1 | ||
body: | ||
settings: | ||
# ensure everything is allocated on the same data node | ||
index.routing.allocation.include._id: $node_id | ||
index.number_of_shards: 3 | ||
index.number_of_replicas: 0 | ||
- do: | ||
index: | ||
index: source | ||
id: "1" | ||
body: { "foo": "hello world" } | ||
|
||
- do: | ||
get: | ||
index: source | ||
id: "1" | ||
|
||
- match: { _index: source } | ||
- match: { _id: "1" } | ||
- match: { _source: { foo: "hello world" } } | ||
|
||
# make it read-only | ||
- do: | ||
indices.put_settings: | ||
index: source | ||
body: | ||
index.blocks.write: true | ||
index.number_of_replicas: 0 | ||
|
||
- do: | ||
cluster.health: | ||
wait_for_status: green | ||
index: source | ||
|
||
# shrink with wait_for_completion | ||
- do: | ||
indices.shrink: | ||
index: "source" | ||
target: "new_shrunken_index" | ||
wait_for_active_shards: 1 | ||
cluster_manager_timeout: 10s | ||
wait_for_completion: false | ||
task_execution_timeout: 30s | ||
body: | ||
settings: | ||
index.number_of_shards: 1 | ||
"index.number_of_replicas": 0 | ||
|
||
- match: { task: /^.+$/ } | ||
- set: { task: taskId } | ||
|
||
- do: | ||
tasks.get: | ||
wait_for_completion: true | ||
task_id: $taskId | ||
- match: { task.action: "indices:admin/resize" } | ||
- match: { task.description: "shrink from [source] to [new_shrunken_index]" } | ||
|
||
# .tasks index is created when the shrink index operation completes, so we should delete .tasks index finally, | ||
# if not, the .tasks index may introduce unexpected warnings and then cause other test cases to fail. | ||
# Delete the .tasks index directly will also introduce warning, but currently we don't have such APIs which can delete one | ||
# specified task or clear all completed tasks, so we have to do so. Expect we can introduce more tasks related APIs in future | ||
- do: | ||
allowed_warnings: | ||
- "this request accesses system indices: [.tasks], but in a future major version, direct access to system indices will be prevented by default" | ||
indices.delete: | ||
index: .tasks | ||
ignore_unavailable: true |
Oops, something went wrong.