elasticsearch-api 7.11.2 → 7.16.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (212) hide show
  1. checksums.yaml +4 -4
  2. data/Gemfile +4 -4
  3. data/README.md +22 -45
  4. data/Rakefile +46 -62
  5. data/elasticsearch-api.gemspec +6 -7
  6. data/lib/elasticsearch/api/actions/bulk.rb +1 -1
  7. data/lib/elasticsearch/api/actions/cat/aliases.rb +1 -1
  8. data/lib/elasticsearch/api/actions/cat/allocation.rb +1 -1
  9. data/lib/elasticsearch/api/actions/cat/count.rb +1 -1
  10. data/lib/elasticsearch/api/actions/cat/fielddata.rb +1 -1
  11. data/lib/elasticsearch/api/actions/cat/health.rb +1 -1
  12. data/lib/elasticsearch/api/actions/cat/help.rb +1 -1
  13. data/lib/elasticsearch/api/actions/cat/indices.rb +1 -1
  14. data/lib/elasticsearch/api/actions/cat/master.rb +1 -1
  15. data/lib/elasticsearch/api/actions/cat/nodeattrs.rb +1 -1
  16. data/lib/elasticsearch/api/actions/cat/nodes.rb +4 -2
  17. data/lib/elasticsearch/api/actions/cat/pending_tasks.rb +1 -1
  18. data/lib/elasticsearch/api/actions/cat/plugins.rb +3 -1
  19. data/lib/elasticsearch/api/actions/cat/recovery.rb +1 -1
  20. data/lib/elasticsearch/api/actions/cat/repositories.rb +1 -1
  21. data/lib/elasticsearch/api/actions/cat/segments.rb +1 -1
  22. data/lib/elasticsearch/api/actions/cat/shards.rb +1 -1
  23. data/lib/elasticsearch/api/actions/cat/snapshots.rb +1 -1
  24. data/lib/elasticsearch/api/actions/cat/tasks.rb +1 -1
  25. data/lib/elasticsearch/api/actions/cat/templates.rb +1 -1
  26. data/lib/elasticsearch/api/actions/cat/thread_pool.rb +1 -1
  27. data/lib/elasticsearch/api/actions/clear_scroll.rb +1 -1
  28. data/lib/elasticsearch/api/actions/{abort_benchmark.rb → close_point_in_time.rb} +13 -12
  29. data/lib/elasticsearch/api/actions/cluster/allocation_explain.rb +3 -3
  30. data/lib/elasticsearch/api/actions/cluster/delete_component_template.rb +1 -1
  31. data/lib/elasticsearch/api/actions/cluster/delete_voting_config_exclusions.rb +1 -1
  32. data/lib/elasticsearch/api/actions/cluster/exists_component_template.rb +2 -1
  33. data/lib/elasticsearch/api/actions/cluster/get_component_template.rb +1 -1
  34. data/lib/elasticsearch/api/actions/cluster/get_settings.rb +1 -1
  35. data/lib/elasticsearch/api/actions/cluster/health.rb +1 -1
  36. data/lib/elasticsearch/api/actions/cluster/pending_tasks.rb +1 -1
  37. data/lib/elasticsearch/api/actions/cluster/post_voting_config_exclusions.rb +1 -1
  38. data/lib/elasticsearch/api/actions/cluster/put_component_template.rb +1 -1
  39. data/lib/elasticsearch/api/actions/cluster/put_settings.rb +1 -1
  40. data/lib/elasticsearch/api/actions/cluster/remote_info.rb +1 -1
  41. data/lib/elasticsearch/api/actions/cluster/reroute.rb +1 -1
  42. data/lib/elasticsearch/api/actions/cluster/state.rb +1 -1
  43. data/lib/elasticsearch/api/actions/cluster/stats.rb +1 -1
  44. data/lib/elasticsearch/api/actions/count.rb +7 -2
  45. data/lib/elasticsearch/api/actions/create.rb +1 -1
  46. data/lib/elasticsearch/api/actions/dangling_indices/delete_dangling_index.rb +1 -1
  47. data/lib/elasticsearch/api/actions/dangling_indices/import_dangling_index.rb +1 -1
  48. data/lib/elasticsearch/api/actions/dangling_indices/list_dangling_indices.rb +1 -1
  49. data/lib/elasticsearch/api/actions/delete.rb +1 -1
  50. data/lib/elasticsearch/api/actions/delete_by_query.rb +1 -1
  51. data/lib/elasticsearch/api/actions/delete_by_query_rethrottle.rb +1 -1
  52. data/lib/elasticsearch/api/actions/delete_script.rb +1 -1
  53. data/lib/elasticsearch/api/actions/exists.rb +2 -1
  54. data/lib/elasticsearch/api/actions/exists_source.rb +2 -1
  55. data/lib/elasticsearch/api/actions/explain.rb +6 -6
  56. data/lib/elasticsearch/api/actions/{nodes/shutdown.rb → features/get_features.rb} +16 -21
  57. data/lib/elasticsearch/api/actions/features/params_registry.rb +60 -0
  58. data/lib/elasticsearch/api/actions/features/reset_features.rb +47 -0
  59. data/lib/elasticsearch/api/actions/field_caps.rb +6 -6
  60. data/lib/elasticsearch/api/actions/get.rb +1 -1
  61. data/lib/elasticsearch/api/actions/get_script.rb +1 -1
  62. data/lib/elasticsearch/api/actions/get_script_context.rb +1 -5
  63. data/lib/elasticsearch/api/actions/get_script_languages.rb +1 -5
  64. data/lib/elasticsearch/api/actions/get_source.rb +1 -1
  65. data/lib/elasticsearch/api/actions/index.rb +1 -1
  66. data/lib/elasticsearch/api/actions/indices/add_block.rb +1 -1
  67. data/lib/elasticsearch/api/actions/indices/analyze.rb +6 -6
  68. data/lib/elasticsearch/api/actions/indices/clear_cache.rb +1 -1
  69. data/lib/elasticsearch/api/actions/indices/clone.rb +1 -1
  70. data/lib/elasticsearch/api/actions/indices/close.rb +2 -2
  71. data/lib/elasticsearch/api/actions/indices/create.rb +1 -1
  72. data/lib/elasticsearch/api/actions/indices/delete.rb +2 -2
  73. data/lib/elasticsearch/api/actions/indices/delete_alias.rb +1 -1
  74. data/lib/elasticsearch/api/actions/indices/delete_index_template.rb +6 -2
  75. data/lib/elasticsearch/api/actions/indices/delete_template.rb +1 -1
  76. data/lib/elasticsearch/api/actions/indices/disk_usage.rb +68 -0
  77. data/lib/elasticsearch/api/actions/indices/exists.rb +2 -1
  78. data/lib/elasticsearch/api/actions/indices/exists_alias.rb +2 -1
  79. data/lib/elasticsearch/api/actions/indices/exists_index_template.rb +7 -2
  80. data/lib/elasticsearch/api/actions/indices/exists_template.rb +2 -1
  81. data/lib/elasticsearch/api/actions/indices/exists_type.rb +2 -1
  82. data/lib/elasticsearch/api/actions/indices/field_usage_stats.rb +66 -0
  83. data/lib/elasticsearch/api/actions/indices/flush.rb +1 -1
  84. data/lib/elasticsearch/api/actions/indices/flush_synced.rb +1 -1
  85. data/lib/elasticsearch/api/actions/indices/forcemerge.rb +1 -1
  86. data/lib/elasticsearch/api/actions/indices/get.rb +1 -1
  87. data/lib/elasticsearch/api/actions/indices/get_alias.rb +1 -1
  88. data/lib/elasticsearch/api/actions/indices/get_field_mapping.rb +1 -1
  89. data/lib/elasticsearch/api/actions/indices/get_index_template.rb +2 -2
  90. data/lib/elasticsearch/api/actions/indices/get_mapping.rb +1 -1
  91. data/lib/elasticsearch/api/actions/indices/get_settings.rb +1 -1
  92. data/lib/elasticsearch/api/actions/indices/get_template.rb +1 -1
  93. data/lib/elasticsearch/api/actions/indices/get_upgrade.rb +1 -1
  94. data/lib/elasticsearch/api/actions/indices/open.rb +1 -1
  95. data/lib/elasticsearch/api/actions/indices/put_alias.rb +1 -1
  96. data/lib/elasticsearch/api/actions/indices/put_index_template.rb +1 -1
  97. data/lib/elasticsearch/api/actions/indices/put_mapping.rb +1 -1
  98. data/lib/elasticsearch/api/actions/indices/put_settings.rb +1 -1
  99. data/lib/elasticsearch/api/actions/indices/put_template.rb +1 -1
  100. data/lib/elasticsearch/api/actions/indices/recovery.rb +1 -1
  101. data/lib/elasticsearch/api/actions/indices/refresh.rb +1 -1
  102. data/lib/elasticsearch/api/actions/indices/resolve_index.rb +1 -5
  103. data/lib/elasticsearch/api/actions/indices/rollover.rb +1 -1
  104. data/lib/elasticsearch/api/actions/indices/segments.rb +1 -1
  105. data/lib/elasticsearch/api/actions/indices/shard_stores.rb +1 -1
  106. data/lib/elasticsearch/api/actions/indices/shrink.rb +1 -1
  107. data/lib/elasticsearch/api/actions/indices/simulate_index_template.rb +1 -1
  108. data/lib/elasticsearch/api/actions/indices/simulate_template.rb +1 -1
  109. data/lib/elasticsearch/api/actions/indices/split.rb +1 -1
  110. data/lib/elasticsearch/api/actions/indices/stats.rb +1 -1
  111. data/lib/elasticsearch/api/actions/indices/update_aliases.rb +1 -1
  112. data/lib/elasticsearch/api/actions/indices/upgrade.rb +1 -1
  113. data/lib/elasticsearch/api/actions/indices/validate_query.rb +8 -8
  114. data/lib/elasticsearch/api/actions/info.rb +1 -1
  115. data/lib/elasticsearch/api/actions/ingest/delete_pipeline.rb +1 -1
  116. data/lib/elasticsearch/api/actions/ingest/geo_ip_stats.rb +43 -0
  117. data/lib/elasticsearch/api/actions/ingest/get_pipeline.rb +3 -1
  118. data/lib/elasticsearch/api/actions/ingest/processor_grok.rb +1 -1
  119. data/lib/elasticsearch/api/actions/ingest/put_pipeline.rb +3 -1
  120. data/lib/elasticsearch/api/actions/ingest/simulate.rb +1 -1
  121. data/lib/elasticsearch/api/actions/mget.rb +1 -1
  122. data/lib/elasticsearch/api/actions/msearch.rb +2 -2
  123. data/lib/elasticsearch/api/actions/msearch_template.rb +2 -2
  124. data/lib/elasticsearch/api/actions/mtermvectors.rb +8 -8
  125. data/lib/elasticsearch/api/actions/nodes/clear_repositories_metering_archive.rb +56 -0
  126. data/lib/elasticsearch/api/actions/nodes/get_repositories_metering_info.rb +52 -0
  127. data/lib/elasticsearch/api/actions/nodes/hot_threads.rb +4 -2
  128. data/lib/elasticsearch/api/actions/nodes/info.rb +2 -2
  129. data/lib/elasticsearch/api/actions/nodes/reload_secure_settings.rb +1 -1
  130. data/lib/elasticsearch/api/actions/nodes/stats.rb +5 -3
  131. data/lib/elasticsearch/api/actions/nodes/usage.rb +1 -1
  132. data/lib/elasticsearch/api/actions/open_point_in_time.rb +62 -0
  133. data/lib/elasticsearch/api/actions/ping.rb +3 -3
  134. data/lib/elasticsearch/api/actions/put_script.rb +1 -1
  135. data/lib/elasticsearch/api/actions/rank_eval.rb +1 -5
  136. data/lib/elasticsearch/api/actions/reindex.rb +1 -1
  137. data/lib/elasticsearch/api/actions/reindex_rethrottle.rb +1 -1
  138. data/lib/elasticsearch/api/actions/render_search_template.rb +6 -6
  139. data/lib/elasticsearch/api/actions/scripts_painless_execute.rb +2 -2
  140. data/lib/elasticsearch/api/actions/scroll.rb +6 -6
  141. data/lib/elasticsearch/api/actions/search.rb +11 -9
  142. data/lib/elasticsearch/api/actions/search_mvt.rb +85 -0
  143. data/lib/elasticsearch/api/actions/search_shards.rb +1 -1
  144. data/lib/elasticsearch/api/actions/search_template.rb +2 -2
  145. data/lib/elasticsearch/api/actions/shutdown/delete_node.rb +48 -0
  146. data/lib/elasticsearch/api/actions/shutdown/get_node.rb +50 -0
  147. data/lib/elasticsearch/api/actions/shutdown/params_registry.rb +60 -0
  148. data/lib/elasticsearch/api/actions/shutdown/put_node.rb +50 -0
  149. data/lib/elasticsearch/api/actions/snapshot/cleanup_repository.rb +1 -1
  150. data/lib/elasticsearch/api/actions/snapshot/clone.rb +1 -1
  151. data/lib/elasticsearch/api/actions/snapshot/create.rb +1 -1
  152. data/lib/elasticsearch/api/actions/snapshot/create_repository.rb +1 -1
  153. data/lib/elasticsearch/api/actions/snapshot/delete.rb +1 -1
  154. data/lib/elasticsearch/api/actions/snapshot/delete_repository.rb +1 -1
  155. data/lib/elasticsearch/api/actions/snapshot/get.rb +5 -1
  156. data/lib/elasticsearch/api/actions/snapshot/get_repository.rb +1 -1
  157. data/lib/elasticsearch/api/actions/snapshot/repository_analyze.rb +76 -0
  158. data/lib/elasticsearch/api/actions/snapshot/restore.rb +1 -1
  159. data/lib/elasticsearch/api/actions/snapshot/status.rb +1 -1
  160. data/lib/elasticsearch/api/actions/snapshot/verify_repository.rb +1 -1
  161. data/lib/elasticsearch/api/actions/tasks/cancel.rb +1 -1
  162. data/lib/elasticsearch/api/actions/tasks/get.rb +1 -1
  163. data/lib/elasticsearch/api/actions/tasks/list.rb +1 -1
  164. data/lib/elasticsearch/api/actions/termvectors.rb +11 -10
  165. data/lib/elasticsearch/api/actions/update.rb +1 -1
  166. data/lib/elasticsearch/api/actions/update_by_query.rb +1 -1
  167. data/lib/elasticsearch/api/actions/update_by_query_rethrottle.rb +1 -1
  168. data/lib/elasticsearch/api/{actions/remote/info.rb → namespace/features.rb} +12 -13
  169. data/lib/elasticsearch/api/namespace/security.rb +36 -0
  170. data/lib/elasticsearch/api/namespace/shutdown.rb +37 -0
  171. data/lib/elasticsearch/api/version.rb +1 -1
  172. data/lib/elasticsearch/api.rb +3 -1
  173. data/spec/elasticsearch/api/actions/{benchmark_spec.rb → close_point_in_time_spec.rb} +6 -6
  174. data/spec/elasticsearch/api/actions/count_spec.rb +2 -5
  175. data/spec/elasticsearch/api/actions/{remote/info_spec.rb → features/get_features_spec.rb} +7 -8
  176. data/spec/elasticsearch/api/actions/features/reset_features_spec.rb +34 -0
  177. data/spec/elasticsearch/api/actions/indices/clear_cache_spec.rb +16 -3
  178. data/spec/elasticsearch/api/actions/indices/disk_usage_spec.rb +48 -0
  179. data/spec/elasticsearch/api/actions/indices/field_usage_stats_spec.rb +46 -0
  180. data/spec/elasticsearch/api/actions/ingest/geo_ip_stats_spec.rb +34 -0
  181. data/spec/elasticsearch/api/actions/nodes/clear_repositories_metering_archive_spec.rb +51 -0
  182. data/spec/elasticsearch/api/actions/nodes/get_repositories_metering_info_spec.rb +44 -0
  183. data/spec/elasticsearch/api/actions/{abort_benchmark_spec.rb → open_point_in_time_spec.rb} +5 -5
  184. data/spec/elasticsearch/api/actions/search_mvt_spec.rb +52 -0
  185. data/spec/elasticsearch/api/actions/shutdown/delete_node_spec.rb +44 -0
  186. data/spec/elasticsearch/api/actions/shutdown/get_node_spec.rb +46 -0
  187. data/spec/elasticsearch/api/actions/shutdown/put_node_spec.rb +50 -0
  188. data/spec/elasticsearch/api/actions/snapshot/repository_analize_spec.rb +48 -0
  189. data/spec/elasticsearch/api/rest_api_yaml_spec.rb +23 -3
  190. data/spec/rest_yaml_tests_helper.rb +17 -53
  191. data/spec/skipped_tests.yml +29 -0
  192. data/spec/spec_helper.rb +4 -1
  193. data/utils/Gemfile +4 -3
  194. data/utils/README.md +6 -1
  195. data/utils/thor/.rubocop.yml +2 -0
  196. data/utils/thor/generate_source.rb +18 -13
  197. data/utils/thor/generator/endpoint_specifics.rb +7 -1
  198. data/utils/thor/generator/files_helper.rb +38 -20
  199. data/utils/thor/templates/_documentation_top.erb +19 -0
  200. data/utils/thor/templates/_method_setup.erb +18 -0
  201. data/utils/thor/templates/_params_registry.erb +19 -0
  202. data/utils/thor/templates/_perform_request.erb +19 -1
  203. data/utils/thor/templates/test.erb +16 -3
  204. data/utils/thor/templates/test_helper.rb +0 -4
  205. metadata +58 -48
  206. data/lib/elasticsearch/api/actions/benchmark.rb +0 -81
  207. data/lib/elasticsearch/api/actions/delete_by_rethrottle.rb +0 -47
  208. data/lib/elasticsearch/api/actions/indices/freeze.rb +0 -56
  209. data/lib/elasticsearch/api/actions/indices/unfreeze.rb +0 -56
  210. data/spec/elasticsearch/api/actions/indices/freeze_spec.rb +0 -85
  211. data/spec/elasticsearch/api/actions/indices/unfreeze_spec.rb +0 -85
  212. data/spec/elasticsearch/api/actions/nodes/shutdown_spec.rb +0 -76
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: e730da6569c6274bebfdf0d5bcb752a4032854fae9807c9773040aa176077d59
4
- data.tar.gz: ac71678126d925fa76f2997f7bd1f2066974ad00af7a223c4e5f30ce7f29f535
3
+ metadata.gz: '0368667b90ead4c4691c306563eec23be738840b4e44b726d089f278eafb262f'
4
+ data.tar.gz: f0310659e54f9499fc6c04e4190787c304e4a458ef4b732bf98d7db758b59272
5
5
  SHA512:
6
- metadata.gz: c8d30129cb9af0f7d132d98a98058777daafbb757d79c0f71515b62a375d708c71399f3c4a57584fb0ebcbe2fda96ee05aa3a529ef66d55775c2b4af6d2a77c1
7
- data.tar.gz: a634d1f8280a090bf4b470b54492e431ff05f491683c2d14bb284924c96410dd415b494301099dbe268f973b9afda819d70b8bcecc5b9ee5c4ed57b40d2fcd60
6
+ metadata.gz: ffa76d5e831a16db2cecae956989d2ea930dda0d9d492cf036416169e9d1155d835c042502783f5cada9cbff8d7a0d7d56d84a0b78703c0567844232eba09360
7
+ data.tar.gz: 9608f8eff97eb417373ddc41600c8885f22f9b4eda69a5629060f630a076e16ee53747aab4baf95af0f3636e68c1a8e3f0e73c5199991f84dd05ea352aa1d35c
data/Gemfile CHANGED
@@ -20,14 +20,14 @@ source 'https://rubygems.org'
20
20
  # Specify your gem's dependencies in elasticsearch-api.gemspec
21
21
  gemspec
22
22
 
23
- if File.exist? File.expand_path("../../elasticsearch/elasticsearch.gemspec", __FILE__)
24
- gem 'elasticsearch', path: File.expand_path("../../elasticsearch", __FILE__), require: false
25
- end
26
-
27
23
  if File.exist? File.expand_path("../../elasticsearch-transport", __FILE__)
28
24
  gem 'elasticsearch-transport', path: File.expand_path("../../elasticsearch-transport", __FILE__), require: true
29
25
  end
30
26
 
27
+ if File.exist? File.expand_path("../../elasticsearch/elasticsearch.gemspec", __FILE__)
28
+ gem 'elasticsearch', path: File.expand_path("../../elasticsearch", __FILE__), require: false
29
+ end
30
+
31
31
  if File.exist? File.expand_path("../../elasticsearch-extensions", __FILE__)
32
32
  gem 'elasticsearch-extensions', path: File.expand_path("../../elasticsearch-extensions", __FILE__), require: false
33
33
  end
data/README.md CHANGED
@@ -1,72 +1,50 @@
1
1
  # Elasticsearch::API
2
2
 
3
- **This library is part of the [`elasticsearch-ruby`](https://github.com/elasticsearch/elasticsearch-ruby/) package;
4
- please refer to it, unless you want to use this library standalone.**
3
+ **This library is part of the [`elasticsearch-ruby`](https://github.com/elasticsearch/elasticsearch-ruby/) package; please refer to it, unless you want to use this library standalone.**
5
4
 
6
5
  ----
7
6
 
8
- The `elasticsearch-api` library provides a Ruby implementation of
9
- the [Elasticsearch](http://elasticsearch.com) REST API.
7
+ The `elasticsearch-api` library provides a Ruby implementation of the [Elasticsearch](http://elasticsearch.com) REST API.
10
8
 
11
- It does not provide an Elasticsearch client; see the
12
- [`elasticsearch-transport`](https://github.com/elasticsearch/elasticsearch-ruby/tree/master/elasticsearch-transport) library.
9
+ It does not provide an Elasticsearch client; see the [`elasticsearch-transport`](https://github.com/elasticsearch/elasticsearch-ruby/tree/master/elasticsearch-transport) library.
13
10
 
14
- The library is compatible with Ruby 1.9 and higher.
15
-
16
- It is compatible with Elasticsearch's API versions from 0.90 till current,
17
- just use a release matching major version of Elasticsearch.
18
-
19
- | Ruby | | Elasticsearch |
20
- |:-------------:|:-:| :-----------: |
21
- | 0.90 | → | 0.90 |
22
- | 1.x | → | 1.x |
23
- | 2.x | → | 2.x |
24
- | 5.x | → | 5.x |
25
- | 6.x | → | 6.x |
26
- | 7.x | → | 7.x |
27
- | master | → | master |
11
+ Language clients are forward compatible; meaning that clients support communicating with greater or equal minor versions of Elasticsearch. Elasticsearch language clients are only backwards compatible with default distributions and without guarantees made.
28
12
 
29
13
  ## Installation
30
14
 
31
15
  Install the package from [Rubygems](https://rubygems.org):
32
16
 
33
- gem install elasticsearch-api
34
-
35
- To use an unreleased version, either add it to your `Gemfile` for [Bundler](http://gembundler.com):
36
-
37
- gem 'elasticsearch-api', git: 'git://github.com/elasticsearch/elasticsearch-ruby.git'
17
+ ```
18
+ gem install elasticsearch-api
19
+ ```
38
20
 
39
- or install it from a source code checkout:
21
+ Or add it to your Gemfile:
40
22
 
41
- git clone https://github.com/elasticsearch/elasticsearch-ruby.git
42
- cd elasticsearch-ruby/elasticsearch-api
43
- bundle install
44
- rake install
23
+ ```
24
+ gem 'elasticsearch-api'
25
+ ```
45
26
 
46
27
  ## Usage
47
28
 
48
- The library is designed as a group of standalone Ruby modules, which can be mixed into a class
49
- providing connection to Elasticsearch -- an Elasticsearch client.
29
+ The library is designed as a group of standalone Ruby modules, which can be mixed into a class providing connection to Elasticsearch -- an Elasticsearch client. It's possible to mix it into any client, and the methods will be available in the top namespace.
50
30
 
51
31
  ### Usage with the `elasticsearch` gem
52
32
 
53
- **When you use the client from the [`elasticsearch-ruby`](https://github.com/elasticsearch/elasticsearch-ruby/) package,
54
- the library modules have been already included**, so you just call the API methods:
33
+ **When you use the client from the [`elasticsearch-ruby`](https://github.com/elasticsearch/elasticsearch-ruby/) package, the library modules have been already included**, so you just call the API methods:
55
34
 
56
35
  ```ruby
57
36
  require 'elasticsearch'
58
37
 
59
- client = Elasticsearch::Client.new log: true
38
+ client = Elasticsearch::Client.new(log: true)
60
39
 
61
- client.index index: 'myindex', type: 'mytype', id: 1, body: { title: 'Test' }
40
+ client.index(index: 'myindex', type: 'mytype', id: 1, body: { title: 'Test' })
62
41
  # => {"_index"=>"myindex", ... "created"=>true}
63
42
 
64
- client.search index: 'myindex', body: { query: { match: { title: 'test' } } }
43
+ client.search(index: 'myindex', body: { query: { match: { title: 'test' } } })
65
44
  # => {"took"=>2, ..., "hits"=>{"total":5, ...}}
66
45
  ```
67
46
 
68
- Full documentation and examples are included as RDoc annotations in the source code
69
- and available online at <http://rubydoc.info/gems/elasticsearch-api>.
47
+ Full documentation is included as RDoc annotations in the source code and available online at <http://rubydoc.info/gems/elasticsearch-api>.
70
48
 
71
49
  ### Usage with a custom client
72
50
 
@@ -190,19 +168,18 @@ Elasticsearch::API.serializer.dump({foo: 'bar'})
190
168
 
191
169
  ## Development
192
170
 
193
- To work on the code, clone and bootstrap the main repository first --
194
- please see instructions in the main [README](../README.md#development).
171
+ To work on the code, clone and bootstrap the main repository first -- please see instructions in the main [README](../README.md#development).
195
172
 
196
- To run tests, launch a testing cluster -- again, see instructions
197
- in the main [README](../README.md#development) -- and use the Rake tasks:
173
+ To run tests, launch a testing cluster -- again, see instructions in the main [README](../README.md#development) -- and use the Rake tasks:
198
174
 
199
175
  ```
200
176
  time rake test:unit
201
177
  time rake test:integration
202
178
  ```
203
179
 
204
- Unit tests have to use Ruby 1.8 compatible syntax, integration tests
205
- can use Ruby 2.x syntax and features.
180
+ We run the test suite for Elasticsearch's Rest API tests. You can read more about this in [the test runner README](https://github.com/elastic/elasticsearch-ruby/tree/master/api-spec-testing#rest-api-yaml-test-runner).
181
+
182
+ The `rest_api` needs the test files from Elasticsearch. You can run the rake task to download the test artifacts in the root folder of the project. This task needs a running cluster to determine which version and build hash of Elasticsearch to use and test against. `TEST_ES_SERVER=http://localhost:9200 rake elasticsearch:download_artifacts`. This will download the necessary files used for the integration tests to `./tmp`.
206
183
 
207
184
  ## License
208
185
 
data/Rakefile CHANGED
@@ -16,14 +16,7 @@
16
16
  # under the License.
17
17
 
18
18
  require 'bundler/gem_tasks'
19
-
20
- def __current__
21
- Pathname( File.expand_path('..', __FILE__) )
22
- end
23
-
24
- def git_specs(command, options={})
25
- sh "git --git-dir=#{__current__.join('../tmp/elasticsearch/.git')} --work-tree=#{__current__.join('../tmp/elasticsearch')} #{command}", options
26
- end
19
+ require 'json'
27
20
 
28
21
  task(:default) { system 'rake --tasks' }
29
22
  task test: 'test:unit'
@@ -46,73 +39,28 @@ namespace :test do
46
39
  t.exclude_pattern = 'spec/**{,/*/**}/rest_api_yaml_spec.rb'
47
40
  end
48
41
 
49
- # Rest API Spec tests - rake test:rest_api
42
+ desc "Run Rest API Spec tests"
50
43
  RSpec::Core::RakeTask.new(:rest_api) do |t|
51
- t.pattern = 'spec/**{,/*/**}/rest_api_yaml_spec.rb'
52
- end
53
-
54
- desc 'Update the repository with YAML tests'
55
- task :update do
56
- git_specs 'fetch origin', verbose: true
57
- end
58
-
59
- desc "Run integration tests"
60
- task integration: :update do
61
44
  require 'elasticsearch'
62
-
63
- branches = `git --git-dir=#{__current__.join('../tmp/elasticsearch/.git')} --work-tree=#{__current__.join('../tmp/elasticsearch')} branch --no-color`
64
-
65
- current_branch = branches.
66
- split("\n").
67
- select { |b| b =~ /^\*/ }.
68
- reject { |b| b =~ /no branch|detached/ }.
69
- map { |b| b.gsub(/^\*\s*/, '') }.
70
- first
71
-
72
- unless current_branch
73
- STDERR.puts "[!] Unable to determine current branch, defaulting to 'master'"
74
- current_branch = 'master'
75
- end
76
-
77
45
  # Check if a test cluster is running
78
46
  begin
79
47
  url = ENV['TEST_CLUSTER_URL'] || ENV['TEST_ES_SERVER']
80
- url = "http://localhost:#{ENV['TEST_CLUSTER_PORT'] || 9250}" unless url
48
+ url = "http://localhost:#{ENV['TEST_CLUSTER_PORT'] || 9200}" unless url
81
49
  client = Elasticsearch::Client.new :url => url
82
50
  es_version_info = client.info['version']
51
+ version_number = es_version_info['number']
83
52
  build_hash = es_version_info['build_hash']
84
- cluster_running = true
85
53
  rescue Faraday::ConnectionFailed
86
54
  STDERR.puts "[!] Test cluster not running?"
87
- cluster_running = false
55
+ exit 1
88
56
  end
89
57
 
90
- checkout_specs_version = ENV['TEST_NO_CHECKOUT'].nil? ? true : false
91
- checkout_build_hash = ENV['TEST_BUILD_REF'] || build_hash
92
- ENV['TEST_BUILD_REF'] = checkout_build_hash
58
+ t.pattern = 'spec/**{,/*/**}/rest_api_yaml_spec.rb'
59
+ end
93
60
 
94
- begin
95
- unless checkout_specs_version
96
- STDERR.puts '-'*80, "YAML tests: Not switching, TEST_NO_CHECKOUT=y", '-'*80
97
- end
98
-
99
- if checkout_specs_version && !checkout_build_hash
100
- STDERR.puts "[!] Cannot determine checkout build hash -- server not running or TEST_BUILD_REF not specified"
101
- exit(1)
102
- end
103
-
104
- if checkout_specs_version && checkout_build_hash
105
- # Checkout the commit corresponding to the running server build, or passed TEST_BUILD_REF
106
- name = ENV['CI'] ? checkout_build_hash : "[\e[1m#{checkout_build_hash}\e[0m]"
107
- STDERR.puts '-'*80, "YAML tests: Switching to #{name} from #{current_branch}", '-'*80
108
- git_specs "checkout #{checkout_build_hash} --force --quiet"
109
- end
110
-
111
- Rake::Task['test:rest_api'].invoke
112
-
113
- ensure
114
- git_specs "checkout #{current_branch} --force --quiet" if checkout_specs_version && current_branch
115
- end
61
+ desc "Run integration tests"
62
+ task :integration do
63
+ Rake::Task['test:rest_api'].invoke
116
64
  end
117
65
 
118
66
  desc 'Run unit and integration tests'
@@ -121,6 +69,42 @@ namespace :test do
121
69
  Rake::Task['test:integration'].invoke
122
70
  end
123
71
 
72
+ def refresh_artifacts(build_hash, version_number)
73
+ unless build_hash
74
+ STDERR.puts "[!] Cannot determine checkout build hash -- server not running"
75
+ exit(1)
76
+ end
77
+
78
+ puts 'Downloading artifacts file...'
79
+ filename = 'tmp/artifacts.json'
80
+ `curl -s https://artifacts-api.elastic.co/v1/versions/#{version_number} -o #{filename}`
81
+
82
+ unless File.exists?("./#{filename}")
83
+ STDERR.puts '[!] Couldn\'t download artifacts file'
84
+ exit 1
85
+ end
86
+
87
+ artifacts = JSON.parse(File.read('./tmp/artifacts.json'))
88
+
89
+ build_hash_artifact = artifacts['version']['builds'].select do |a|
90
+ a.dig('projects', 'elasticsearch', 'commit_hash') == build_hash
91
+ end.first
92
+ # Dig into the elasticsearch packages, search for the rest-resources-zip package and catch the URL:
93
+ zip_url = build_hash_artifact.dig('projects', 'elasticsearch', 'packages').select { |k,v| k =~ /rest-resources-zip/ }.map { | _, v| v['url'] }.first
94
+
95
+ filename = zip_url.split('/').last
96
+ puts 'Downloading zip file:'
97
+ `curl -s #{zip_url} -o tmp/#{filename}`
98
+
99
+ unless File.exists?("./tmp/#{filename}")
100
+ STDERR.puts '[!] Couldn\'t download artifact'
101
+ exit 1
102
+ end
103
+
104
+ puts "Unzipping file #{filename}"
105
+ `unzip -o tmp/#{filename} -d tmp/`
106
+ end
107
+
124
108
  namespace :cluster do
125
109
  desc "Start Elasticsearch nodes for tests"
126
110
  task :start do
@@ -26,12 +26,12 @@ Gem::Specification.new do |s|
26
26
  s.authors = ['Karel Minarik']
27
27
  s.email = ['karel.minarik@elasticsearch.org']
28
28
  s.summary = 'Ruby API for Elasticsearch.'
29
- s.homepage = 'https://www.elastic.co/guide/en/elasticsearch/client/ruby-api/7.x/index.html'
29
+ s.homepage = 'https://www.elastic.co/guide/en/elasticsearch/client/ruby-api/7.16/index.html'
30
30
  s.license = 'Apache-2.0'
31
31
  s.metadata = {
32
- 'homepage_uri' => 'https://www.elastic.co/guide/en/elasticsearch/client/ruby-api/7.x/index.html',
33
- 'changelog_uri' => 'https://github.com/elastic/elasticsearch-ruby/blob/7.x/CHANGELOG.md',
34
- 'source_code_uri' => 'https://github.com/elastic/elasticsearch-ruby/tree/7.x/elasticsearch-api',
32
+ 'homepage_uri' => 'https://www.elastic.co/guide/en/elasticsearch/client/ruby-api/7.16/index.html',
33
+ 'changelog_uri' => 'https://github.com/elastic/elasticsearch-ruby/blob/7.16/CHANGELOG.md',
34
+ 'source_code_uri' => 'https://github.com/elastic/elasticsearch-ruby/tree/7.16/elasticsearch-api',
35
35
  'bug_tracker_uri' => 'https://github.com/elastic/elasticsearch-ruby/issues'
36
36
  }
37
37
  s.files = `git ls-files`.split($/)
@@ -49,8 +49,8 @@ Gem::Specification.new do |s|
49
49
  s.add_development_dependency 'ansi'
50
50
  s.add_development_dependency 'bundler'
51
51
  s.add_development_dependency 'elasticsearch'
52
- s.add_development_dependency 'elasticsearch-extensions'
53
52
  s.add_development_dependency 'elasticsearch-transport'
53
+ s.add_development_dependency 'elasticsearch-xpack'
54
54
  s.add_development_dependency 'minitest'
55
55
  s.add_development_dependency 'minitest-reporters'
56
56
  s.add_development_dependency 'mocha'
@@ -67,8 +67,7 @@ Gem::Specification.new do |s|
67
67
  s.add_development_dependency 'escape_utils' unless defined? JRUBY_VERSION
68
68
  s.add_development_dependency 'jbuilder'
69
69
  s.add_development_dependency 'require-prof' unless defined?(JRUBY_VERSION) || defined?(Rubinius)
70
- s.add_development_dependency 'simplecov', '~> 0.17', '< 0.18'
71
- s.add_development_dependency 'simplecov-rcov'
70
+ s.add_development_dependency 'simplecov'
72
71
  s.add_development_dependency 'test-unit', '~> 2'
73
72
  s.add_development_dependency 'ruby-prof' unless defined?(JRUBY_VERSION) || defined?(Rubinius)
74
73
 
@@ -35,7 +35,7 @@ module Elasticsearch
35
35
  # @option arguments [String|Array] :body The operation definition and data (action-data pairs), separated by newlines. Array of Strings, Header/Data pairs,
36
36
  # or the conveniency "combined" format can be passed, refer to Elasticsearch::API::Utils.__bulkify documentation.
37
37
  #
38
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.11/docs-bulk.html
38
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.16/docs-bulk.html
39
39
  #
40
40
  def bulk(arguments = {})
41
41
  raise ArgumentError, "Required argument 'body' missing" unless arguments[:body]
@@ -31,7 +31,7 @@ module Elasticsearch
31
31
  # @option arguments [String] :expand_wildcards Whether to expand wildcard expression to concrete indices that are open, closed or both. (options: open, closed, hidden, none, all)
32
32
  # @option arguments [Hash] :headers Custom HTTP headers
33
33
  #
34
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.11/cat-alias.html
34
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.16/cat-alias.html
35
35
  #
36
36
  def aliases(arguments = {})
37
37
  headers = arguments.delete(:headers) || {}
@@ -32,7 +32,7 @@ module Elasticsearch
32
32
  # @option arguments [Boolean] :v Verbose mode. Display column headers
33
33
  # @option arguments [Hash] :headers Custom HTTP headers
34
34
  #
35
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.11/cat-allocation.html
35
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.16/cat-allocation.html
36
36
  #
37
37
  def allocation(arguments = {})
38
38
  headers = arguments.delete(:headers) || {}
@@ -29,7 +29,7 @@ module Elasticsearch
29
29
  # @option arguments [Boolean] :v Verbose mode. Display column headers
30
30
  # @option arguments [Hash] :headers Custom HTTP headers
31
31
  #
32
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.11/cat-count.html
32
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.16/cat-count.html
33
33
  #
34
34
  def count(arguments = {})
35
35
  headers = arguments.delete(:headers) || {}
@@ -30,7 +30,7 @@ module Elasticsearch
30
30
  # @option arguments [Boolean] :v Verbose mode. Display column headers
31
31
  # @option arguments [Hash] :headers Custom HTTP headers
32
32
  #
33
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.11/cat-fielddata.html
33
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.16/cat-fielddata.html
34
34
  #
35
35
  def fielddata(arguments = {})
36
36
  headers = arguments.delete(:headers) || {}
@@ -30,7 +30,7 @@ module Elasticsearch
30
30
  # @option arguments [Boolean] :v Verbose mode. Display column headers
31
31
  # @option arguments [Hash] :headers Custom HTTP headers
32
32
  #
33
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.11/cat-health.html
33
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.16/cat-health.html
34
34
  #
35
35
  def health(arguments = {})
36
36
  headers = arguments.delete(:headers) || {}
@@ -25,7 +25,7 @@ module Elasticsearch
25
25
  # @option arguments [List] :s Comma-separated list of column names or column aliases to sort by
26
26
  # @option arguments [Hash] :headers Custom HTTP headers
27
27
  #
28
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.11/cat.html
28
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.16/cat.html
29
29
  #
30
30
  def help(arguments = {})
31
31
  headers = arguments.delete(:headers) || {}
@@ -37,7 +37,7 @@ module Elasticsearch
37
37
  # @option arguments [String] :expand_wildcards Whether to expand wildcard expression to concrete indices that are open, closed or both. (options: open, closed, hidden, none, all)
38
38
  # @option arguments [Hash] :headers Custom HTTP headers
39
39
  #
40
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.11/cat-indices.html
40
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.16/cat-indices.html
41
41
  #
42
42
  def indices(arguments = {})
43
43
  headers = arguments.delete(:headers) || {}
@@ -30,7 +30,7 @@ module Elasticsearch
30
30
  # @option arguments [Boolean] :v Verbose mode. Display column headers
31
31
  # @option arguments [Hash] :headers Custom HTTP headers
32
32
  #
33
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.11/cat-master.html
33
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.16/cat-master.html
34
34
  #
35
35
  def master(arguments = {})
36
36
  headers = arguments.delete(:headers) || {}
@@ -30,7 +30,7 @@ module Elasticsearch
30
30
  # @option arguments [Boolean] :v Verbose mode. Display column headers
31
31
  # @option arguments [Hash] :headers Custom HTTP headers
32
32
  #
33
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.11/cat-nodeattrs.html
33
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.16/cat-nodeattrs.html
34
34
  #
35
35
  def nodeattrs(arguments = {})
36
36
  headers = arguments.delete(:headers) || {}
@@ -31,9 +31,10 @@ module Elasticsearch
31
31
  # @option arguments [List] :s Comma-separated list of column names or column aliases to sort by
32
32
  # @option arguments [String] :time The unit in which to display time values (options: d, h, m, s, ms, micros, nanos)
33
33
  # @option arguments [Boolean] :v Verbose mode. Display column headers
34
+ # @option arguments [Boolean] :include_unloaded_segments If set to true segment stats will include stats for segments that are not currently loaded into memory
34
35
  # @option arguments [Hash] :headers Custom HTTP headers
35
36
  #
36
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.11/cat-nodes.html
37
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.16/cat-nodes.html
37
38
  #
38
39
  def nodes(arguments = {})
39
40
  headers = arguments.delete(:headers) || {}
@@ -62,7 +63,8 @@ module Elasticsearch
62
63
  :help,
63
64
  :s,
64
65
  :time,
65
- :v
66
+ :v,
67
+ :include_unloaded_segments
66
68
  ].freeze)
67
69
  end
68
70
  end
@@ -31,7 +31,7 @@ module Elasticsearch
31
31
  # @option arguments [Boolean] :v Verbose mode. Display column headers
32
32
  # @option arguments [Hash] :headers Custom HTTP headers
33
33
  #
34
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.11/cat-pending-tasks.html
34
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.16/cat-pending-tasks.html
35
35
  #
36
36
  def pending_tasks(arguments = {})
37
37
  headers = arguments.delete(:headers) || {}
@@ -26,11 +26,12 @@ module Elasticsearch
26
26
  # @option arguments [Time] :master_timeout Explicit operation timeout for connection to master node
27
27
  # @option arguments [List] :h Comma-separated list of column names to display
28
28
  # @option arguments [Boolean] :help Return help information
29
+ # @option arguments [Boolean] :include_bootstrap Include bootstrap plugins in the response
29
30
  # @option arguments [List] :s Comma-separated list of column names or column aliases to sort by
30
31
  # @option arguments [Boolean] :v Verbose mode. Display column headers
31
32
  # @option arguments [Hash] :headers Custom HTTP headers
32
33
  #
33
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.11/cat-plugins.html
34
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.16/cat-plugins.html
34
35
  #
35
36
  def plugins(arguments = {})
36
37
  headers = arguments.delete(:headers) || {}
@@ -54,6 +55,7 @@ module Elasticsearch
54
55
  :master_timeout,
55
56
  :h,
56
57
  :help,
58
+ :include_bootstrap,
57
59
  :s,
58
60
  :v
59
61
  ].freeze)
@@ -33,7 +33,7 @@ module Elasticsearch
33
33
  # @option arguments [Boolean] :v Verbose mode. Display column headers
34
34
  # @option arguments [Hash] :headers Custom HTTP headers
35
35
  #
36
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.11/cat-recovery.html
36
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.16/cat-recovery.html
37
37
  #
38
38
  def recovery(arguments = {})
39
39
  headers = arguments.delete(:headers) || {}
@@ -30,7 +30,7 @@ module Elasticsearch
30
30
  # @option arguments [Boolean] :v Verbose mode. Display column headers
31
31
  # @option arguments [Hash] :headers Custom HTTP headers
32
32
  #
33
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.11/cat-repositories.html
33
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.16/cat-repositories.html
34
34
  #
35
35
  def repositories(arguments = {})
36
36
  headers = arguments.delete(:headers) || {}
@@ -30,7 +30,7 @@ module Elasticsearch
30
30
  # @option arguments [Boolean] :v Verbose mode. Display column headers
31
31
  # @option arguments [Hash] :headers Custom HTTP headers
32
32
  #
33
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.11/cat-segments.html
33
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.16/cat-segments.html
34
34
  #
35
35
  def segments(arguments = {})
36
36
  headers = arguments.delete(:headers) || {}
@@ -33,7 +33,7 @@ module Elasticsearch
33
33
  # @option arguments [Boolean] :v Verbose mode. Display column headers
34
34
  # @option arguments [Hash] :headers Custom HTTP headers
35
35
  #
36
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.11/cat-shards.html
36
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.16/cat-shards.html
37
37
  #
38
38
  def shards(arguments = {})
39
39
  headers = arguments.delete(:headers) || {}
@@ -32,7 +32,7 @@ module Elasticsearch
32
32
  # @option arguments [Boolean] :v Verbose mode. Display column headers
33
33
  # @option arguments [Hash] :headers Custom HTTP headers
34
34
  #
35
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.11/cat-snapshots.html
35
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.16/cat-snapshots.html
36
36
  #
37
37
  def snapshots(arguments = {})
38
38
  headers = arguments.delete(:headers) || {}
@@ -33,7 +33,7 @@ module Elasticsearch
33
33
  # @option arguments [Boolean] :v Verbose mode. Display column headers
34
34
  # @option arguments [Hash] :headers Custom HTTP headers
35
35
  #
36
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.11/tasks.html
36
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.16/tasks.html
37
37
  #
38
38
  def tasks(arguments = {})
39
39
  headers = arguments.delete(:headers) || {}
@@ -31,7 +31,7 @@ module Elasticsearch
31
31
  # @option arguments [Boolean] :v Verbose mode. Display column headers
32
32
  # @option arguments [Hash] :headers Custom HTTP headers
33
33
  #
34
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.11/cat-templates.html
34
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.16/cat-templates.html
35
35
  #
36
36
  def templates(arguments = {})
37
37
  headers = arguments.delete(:headers) || {}
@@ -33,7 +33,7 @@ module Elasticsearch
33
33
  # @option arguments [Boolean] :v Verbose mode. Display column headers
34
34
  # @option arguments [Hash] :headers Custom HTTP headers
35
35
  #
36
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.11/cat-thread-pool.html
36
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.16/cat-thread-pool.html
37
37
  #
38
38
  def thread_pool(arguments = {})
39
39
  headers = arguments.delete(:headers) || {}
@@ -29,7 +29,7 @@ module Elasticsearch
29
29
  # Deprecated since version 7.0.0
30
30
  #
31
31
  #
32
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.11/clear-scroll-api.html
32
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.16/clear-scroll-api.html
33
33
  #
34
34
  def clear_scroll(arguments = {})
35
35
  headers = arguments.delete(:headers) || {}
@@ -18,23 +18,24 @@
18
18
  module Elasticsearch
19
19
  module API
20
20
  module Actions
21
- # Abort a running benchmark
21
+ # Close a point in time
22
22
  #
23
- # @example
23
+ # @option arguments [Hash] :headers Custom HTTP headers
24
+ # @option arguments [Hash] :body a point-in-time id to close
24
25
  #
25
- # client.abort_benchmark name: 'my_benchmark'
26
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.16/point-in-time-api.html
26
27
  #
27
- # @option arguments [String] :name A benchmark name
28
- #
29
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/master/search-benchmark.html
30
- #
31
- def abort_benchmark(arguments = {})
32
- method = HTTP_POST
33
- path = "_bench/abort/#{arguments[:name]}"
28
+ def close_point_in_time(arguments = {})
29
+ headers = arguments.delete(:headers) || {}
30
+
31
+ arguments = arguments.clone
32
+
33
+ method = Elasticsearch::API::HTTP_DELETE
34
+ path = "_pit"
34
35
  params = {}
35
- body = nil
36
36
 
37
- perform_request(method, path, params, body).body
37
+ body = arguments[:body]
38
+ perform_request(method, path, params, body, headers).body
38
39
  end
39
40
  end
40
41
  end