elasticsearch-api 7.11.2 → 8.6.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/Gemfile +1 -9
- data/README.md +15 -188
- data/Rakefile +23 -87
- data/api-spec-testing/README.md +118 -0
- data/api-spec-testing/custom_cleanup.rb +32 -0
- data/api-spec-testing/logging.rb +28 -0
- data/api-spec-testing/rspec_matchers.rb +336 -0
- data/api-spec-testing/test_file/action.rb +239 -0
- data/api-spec-testing/test_file/task_group.rb +340 -0
- data/api-spec-testing/test_file/test.rb +296 -0
- data/api-spec-testing/test_file.rb +179 -0
- data/api-spec-testing/wipe_cluster.rb +424 -0
- data/elasticsearch-api.gemspec +19 -14
- data/lib/elasticsearch/api/actions/async_search/delete.rb +53 -0
- data/lib/elasticsearch/api/actions/async_search/get.rb +56 -0
- data/lib/elasticsearch/api/actions/async_search/status.rb +53 -0
- data/lib/elasticsearch/api/actions/async_search/submit.rb +97 -0
- data/lib/elasticsearch/api/actions/autoscaling/delete_autoscaling_policy.rb +53 -0
- data/lib/elasticsearch/api/actions/autoscaling/get_autoscaling_capacity.rb +48 -0
- data/lib/elasticsearch/api/actions/autoscaling/get_autoscaling_policy.rb +53 -0
- data/lib/elasticsearch/api/actions/autoscaling/put_autoscaling_policy.rb +55 -0
- data/lib/elasticsearch/api/actions/bulk.rb +13 -28
- data/lib/elasticsearch/api/actions/cat/aliases.rb +11 -19
- data/lib/elasticsearch/api/actions/cat/allocation.rb +11 -20
- data/lib/elasticsearch/api/actions/cat/component_templates.rb +62 -0
- data/lib/elasticsearch/api/actions/cat/count.rb +11 -17
- data/lib/elasticsearch/api/actions/cat/fielddata.rb +11 -19
- data/lib/elasticsearch/api/actions/cat/health.rb +11 -19
- data/lib/elasticsearch/api/actions/cat/help.rb +11 -14
- data/lib/elasticsearch/api/actions/cat/indices.rb +11 -26
- data/lib/elasticsearch/api/actions/cat/master.rb +11 -19
- data/lib/elasticsearch/api/actions/cat/ml_data_frame_analytics.rb +63 -0
- data/lib/elasticsearch/api/actions/cat/ml_datafeeds.rb +62 -0
- data/lib/elasticsearch/api/actions/cat/ml_jobs.rb +63 -0
- data/lib/elasticsearch/api/actions/cat/ml_trained_models.rb +65 -0
- data/lib/elasticsearch/api/actions/cat/nodeattrs.rb +11 -19
- data/lib/elasticsearch/api/actions/cat/nodes.rb +12 -23
- data/lib/elasticsearch/api/actions/cat/pending_tasks.rb +11 -20
- data/lib/elasticsearch/api/actions/cat/plugins.rb +12 -19
- data/lib/elasticsearch/api/actions/cat/recovery.rb +11 -22
- data/lib/elasticsearch/api/actions/cat/repositories.rb +11 -19
- data/lib/elasticsearch/api/actions/cat/segments.rb +11 -18
- data/lib/elasticsearch/api/actions/cat/shards.rb +11 -22
- data/lib/elasticsearch/api/actions/cat/snapshots.rb +11 -20
- data/lib/elasticsearch/api/actions/cat/tasks.rb +15 -22
- data/lib/elasticsearch/api/actions/cat/templates.rb +11 -19
- data/lib/elasticsearch/api/actions/cat/thread_pool.rb +12 -21
- data/lib/elasticsearch/api/actions/cat/transforms.rb +64 -0
- data/lib/elasticsearch/api/actions/clear_scroll.rb +10 -5
- data/lib/elasticsearch/api/actions/close_point_in_time.rb +47 -0
- data/lib/elasticsearch/api/actions/cluster/allocation_explain.rb +14 -17
- data/lib/elasticsearch/api/actions/cluster/delete_component_template.rb +11 -14
- data/lib/elasticsearch/api/actions/cluster/delete_voting_config_exclusions.rb +12 -13
- data/lib/elasticsearch/api/actions/cluster/exists_component_template.rb +11 -13
- data/lib/elasticsearch/api/actions/cluster/get_component_template.rb +11 -14
- data/lib/elasticsearch/api/actions/cluster/get_settings.rb +11 -16
- data/lib/elasticsearch/api/actions/cluster/health.rb +11 -23
- data/lib/elasticsearch/api/actions/cluster/pending_tasks.rb +11 -14
- data/lib/elasticsearch/api/actions/cluster/post_voting_config_exclusions.rb +12 -15
- data/lib/elasticsearch/api/actions/cluster/put_component_template.rb +11 -15
- data/lib/elasticsearch/api/actions/cluster/put_settings.rb +11 -15
- data/lib/elasticsearch/api/actions/cluster/remote_info.rb +10 -5
- data/lib/elasticsearch/api/actions/cluster/reroute.rb +12 -19
- data/lib/elasticsearch/api/actions/cluster/state.rb +11 -20
- data/lib/elasticsearch/api/actions/cluster/stats.rb +11 -14
- data/lib/elasticsearch/api/actions/count.rb +17 -37
- data/lib/elasticsearch/api/actions/create.rb +5 -8
- data/lib/elasticsearch/api/actions/cross_cluster_replication/delete_auto_follow_pattern.rb +53 -0
- data/lib/elasticsearch/api/actions/cross_cluster_replication/follow.rb +56 -0
- data/lib/elasticsearch/api/actions/cross_cluster_replication/follow_info.rb +53 -0
- data/lib/elasticsearch/api/actions/cross_cluster_replication/follow_stats.rb +53 -0
- data/lib/elasticsearch/api/actions/cross_cluster_replication/forget_follower.rb +55 -0
- data/lib/elasticsearch/api/actions/cross_cluster_replication/get_auto_follow_pattern.rb +55 -0
- data/lib/elasticsearch/api/actions/cross_cluster_replication/pause_auto_follow_pattern.rb +53 -0
- data/lib/elasticsearch/api/actions/{indices/freeze.rb → cross_cluster_replication/pause_follow.rb} +20 -23
- data/lib/elasticsearch/api/actions/cross_cluster_replication/put_auto_follow_pattern.rb +55 -0
- data/lib/elasticsearch/api/actions/cross_cluster_replication/resume_auto_follow_pattern.rb +53 -0
- data/lib/elasticsearch/api/actions/cross_cluster_replication/resume_follow.rb +54 -0
- data/lib/elasticsearch/api/actions/cross_cluster_replication/stats.rb +48 -0
- data/lib/elasticsearch/api/actions/cross_cluster_replication/unfollow.rb +53 -0
- data/lib/elasticsearch/api/actions/dangling_indices/delete_dangling_index.rb +11 -15
- data/lib/elasticsearch/api/actions/dangling_indices/import_dangling_index.rb +11 -15
- data/lib/elasticsearch/api/actions/dangling_indices/list_dangling_indices.rb +10 -5
- data/lib/elasticsearch/api/actions/delete.rb +18 -35
- data/lib/elasticsearch/api/actions/delete_by_query.rb +14 -64
- data/lib/elasticsearch/api/actions/delete_by_query_rethrottle.rb +11 -13
- data/lib/elasticsearch/api/actions/delete_script.rb +11 -14
- data/lib/elasticsearch/api/actions/enrich/delete_policy.rb +53 -0
- data/lib/elasticsearch/api/actions/enrich/execute_policy.rb +54 -0
- data/lib/elasticsearch/api/actions/enrich/get_policy.rb +55 -0
- data/lib/elasticsearch/api/actions/enrich/put_policy.rb +55 -0
- data/lib/elasticsearch/api/actions/enrich/stats.rb +48 -0
- data/lib/elasticsearch/api/actions/eql/delete.rb +53 -0
- data/lib/elasticsearch/api/actions/eql/get.rb +55 -0
- data/lib/elasticsearch/api/actions/eql/get_status.rb +53 -0
- data/lib/elasticsearch/api/actions/eql/search.rb +60 -0
- data/lib/elasticsearch/api/actions/exists.rb +10 -35
- data/lib/elasticsearch/api/actions/exists_source.rb +13 -34
- data/lib/elasticsearch/api/actions/explain.rb +13 -38
- data/lib/elasticsearch/api/actions/features/get_features.rb +49 -0
- data/lib/elasticsearch/api/actions/features/reset_features.rb +52 -0
- data/lib/elasticsearch/api/actions/field_caps.rb +19 -23
- data/lib/elasticsearch/api/actions/fleet/global_checkpoints.rb +57 -0
- data/lib/elasticsearch/api/actions/fleet/msearch.rb +85 -0
- data/lib/elasticsearch/api/actions/fleet/search.rb +68 -0
- data/lib/elasticsearch/api/actions/get.rb +19 -37
- data/lib/elasticsearch/api/actions/get_script.rb +11 -13
- data/lib/elasticsearch/api/actions/get_script_context.rb +10 -9
- data/lib/elasticsearch/api/actions/get_script_languages.rb +10 -9
- data/lib/elasticsearch/api/actions/get_source.rb +13 -35
- data/lib/elasticsearch/api/actions/graph/explore.rb +61 -0
- data/lib/elasticsearch/api/actions/index.rb +12 -36
- data/lib/elasticsearch/api/actions/index_lifecycle_management/delete_lifecycle.rb +53 -0
- data/lib/elasticsearch/api/actions/index_lifecycle_management/explain_lifecycle.rb +55 -0
- data/lib/elasticsearch/api/actions/index_lifecycle_management/get_lifecycle.rb +55 -0
- data/lib/elasticsearch/api/actions/index_lifecycle_management/get_status.rb +48 -0
- data/lib/elasticsearch/api/actions/index_lifecycle_management/migrate_to_data_tiers.rb +50 -0
- data/lib/elasticsearch/api/actions/index_lifecycle_management/move_to_step.rb +54 -0
- data/lib/elasticsearch/api/actions/index_lifecycle_management/put_lifecycle.rb +54 -0
- data/lib/elasticsearch/api/actions/index_lifecycle_management/remove_policy.rb +53 -0
- data/lib/elasticsearch/api/actions/index_lifecycle_management/retry.rb +53 -0
- data/lib/elasticsearch/api/actions/index_lifecycle_management/start.rb +48 -0
- data/lib/elasticsearch/api/actions/index_lifecycle_management/stop.rb +48 -0
- data/lib/elasticsearch/api/actions/indices/add_block.rb +11 -17
- data/lib/elasticsearch/api/actions/indices/analyze.rb +17 -19
- data/lib/elasticsearch/api/actions/indices/clear_cache.rb +11 -20
- data/lib/elasticsearch/api/actions/indices/clone.rb +11 -15
- data/lib/elasticsearch/api/actions/indices/close.rb +11 -18
- data/lib/elasticsearch/api/actions/indices/create.rb +11 -17
- data/lib/elasticsearch/api/actions/indices/create_data_stream.rb +53 -0
- data/lib/elasticsearch/api/actions/indices/data_streams_stats.rb +55 -0
- data/lib/elasticsearch/api/actions/indices/delete.rb +17 -19
- data/lib/elasticsearch/api/actions/indices/delete_alias.rb +11 -14
- data/lib/elasticsearch/api/actions/indices/delete_data_stream.rb +54 -0
- data/lib/elasticsearch/api/actions/indices/delete_index_template.rb +11 -14
- data/lib/elasticsearch/api/actions/indices/delete_template.rb +16 -15
- data/lib/elasticsearch/api/actions/indices/{exists_type.rb → disk_usage.rb} +22 -30
- data/lib/elasticsearch/api/actions/indices/downsample.rb +63 -0
- data/lib/elasticsearch/api/actions/indices/exists.rb +8 -17
- data/lib/elasticsearch/api/actions/indices/exists_alias.rb +8 -15
- data/lib/elasticsearch/api/actions/indices/exists_index_template.rb +11 -14
- data/lib/elasticsearch/api/actions/indices/exists_template.rb +8 -14
- data/lib/elasticsearch/api/actions/indices/{upgrade.rb → field_usage_stats.rb} +24 -34
- data/lib/elasticsearch/api/actions/indices/flush.rb +11 -17
- data/lib/elasticsearch/api/actions/indices/forcemerge.rb +12 -18
- data/lib/elasticsearch/api/actions/indices/get.rb +12 -21
- data/lib/elasticsearch/api/actions/indices/get_alias.rb +11 -16
- data/lib/elasticsearch/api/actions/indices/get_data_stream.rb +56 -0
- data/lib/elasticsearch/api/actions/indices/get_field_mapping.rb +12 -32
- data/lib/elasticsearch/api/actions/indices/get_index_template.rb +12 -16
- data/lib/elasticsearch/api/actions/indices/get_mapping.rb +12 -32
- data/lib/elasticsearch/api/actions/indices/get_settings.rb +11 -19
- data/lib/elasticsearch/api/actions/indices/get_template.rb +11 -17
- data/lib/elasticsearch/api/actions/indices/migrate_to_data_stream.rb +53 -0
- data/lib/elasticsearch/api/actions/indices/modify_data_stream.rb +51 -0
- data/lib/elasticsearch/api/actions/indices/open.rb +11 -18
- data/lib/elasticsearch/api/actions/indices/promote_data_stream.rb +53 -0
- data/lib/elasticsearch/api/actions/indices/put_alias.rb +11 -14
- data/lib/elasticsearch/api/actions/indices/put_index_template.rb +11 -15
- data/lib/elasticsearch/api/actions/indices/put_mapping.rb +13 -35
- data/lib/elasticsearch/api/actions/indices/put_settings.rb +11 -19
- data/lib/elasticsearch/api/actions/indices/put_template.rb +11 -17
- data/lib/elasticsearch/api/actions/indices/recovery.rb +11 -14
- data/lib/elasticsearch/api/actions/indices/refresh.rb +11 -15
- data/lib/elasticsearch/api/actions/indices/{get_upgrade.rb → reload_search_analyzers.rb} +17 -28
- data/lib/elasticsearch/api/actions/indices/resolve_index.rb +11 -17
- data/lib/elasticsearch/api/actions/indices/rollover.rb +11 -18
- data/lib/elasticsearch/api/actions/indices/segments.rb +12 -17
- data/lib/elasticsearch/api/actions/indices/shard_stores.rb +11 -16
- data/lib/elasticsearch/api/actions/indices/shrink.rb +11 -17
- data/lib/elasticsearch/api/actions/indices/simulate_index_template.rb +11 -15
- data/lib/elasticsearch/api/actions/indices/simulate_template.rb +11 -15
- data/lib/elasticsearch/api/actions/indices/split.rb +11 -17
- data/lib/elasticsearch/api/actions/indices/stats.rb +28 -49
- data/lib/elasticsearch/api/actions/indices/unfreeze.rb +28 -20
- data/lib/elasticsearch/api/actions/indices/update_aliases.rb +11 -14
- data/lib/elasticsearch/api/actions/indices/validate_query.rb +17 -40
- data/lib/elasticsearch/api/actions/info.rb +10 -5
- data/lib/elasticsearch/api/actions/ingest/delete_pipeline.rb +11 -14
- data/lib/elasticsearch/api/actions/ingest/geo_ip_stats.rb +48 -0
- data/lib/elasticsearch/api/actions/ingest/get_pipeline.rb +12 -13
- data/lib/elasticsearch/api/actions/ingest/processor_grok.rb +10 -5
- data/lib/elasticsearch/api/actions/ingest/put_pipeline.rb +12 -14
- data/lib/elasticsearch/api/actions/ingest/simulate.rb +11 -13
- data/lib/elasticsearch/api/actions/knn_search.rb +62 -0
- data/lib/elasticsearch/api/actions/license/delete.rb +48 -0
- data/lib/elasticsearch/api/actions/license/get.rb +50 -0
- data/lib/elasticsearch/api/actions/license/get_basic_status.rb +48 -0
- data/lib/elasticsearch/api/actions/license/get_trial_status.rb +48 -0
- data/lib/elasticsearch/api/actions/license/post.rb +50 -0
- data/lib/elasticsearch/api/actions/license/post_start_basic.rb +49 -0
- data/lib/elasticsearch/api/actions/license/post_start_trial.rb +50 -0
- data/lib/elasticsearch/api/actions/logstash/delete_pipeline.rb +53 -0
- data/lib/elasticsearch/api/actions/logstash/get_pipeline.rb +53 -0
- data/lib/elasticsearch/api/actions/logstash/put_pipeline.rb +55 -0
- data/lib/elasticsearch/api/actions/machine_learning/clear_trained_model_deployment_cache.rb +57 -0
- data/lib/elasticsearch/api/actions/machine_learning/close_job.rb +57 -0
- data/lib/elasticsearch/api/actions/machine_learning/delete_calendar.rb +53 -0
- data/lib/elasticsearch/api/actions/machine_learning/delete_calendar_event.rb +57 -0
- data/lib/elasticsearch/api/actions/machine_learning/delete_calendar_job.rb +57 -0
- data/lib/elasticsearch/api/actions/machine_learning/delete_data_frame_analytics.rb +55 -0
- data/lib/elasticsearch/api/actions/machine_learning/delete_datafeed.rb +54 -0
- data/lib/elasticsearch/api/actions/machine_learning/delete_expired_data.rb +58 -0
- data/lib/elasticsearch/api/actions/machine_learning/delete_filter.rb +53 -0
- data/lib/elasticsearch/api/actions/machine_learning/delete_forecast.rb +62 -0
- data/lib/elasticsearch/api/actions/machine_learning/delete_job.rb +55 -0
- data/lib/elasticsearch/api/actions/machine_learning/delete_model_snapshot.rb +57 -0
- data/lib/elasticsearch/api/actions/machine_learning/delete_trained_model.rb +55 -0
- data/lib/elasticsearch/api/actions/machine_learning/delete_trained_model_alias.rb +57 -0
- data/lib/elasticsearch/api/actions/machine_learning/estimate_model_memory.rb +51 -0
- data/lib/elasticsearch/api/actions/machine_learning/evaluate_data_frame.rb +51 -0
- data/lib/elasticsearch/api/actions/machine_learning/explain_data_frame_analytics.rb +61 -0
- data/lib/elasticsearch/api/actions/machine_learning/flush_job.rb +59 -0
- data/lib/elasticsearch/api/actions/machine_learning/forecast.rb +57 -0
- data/lib/elasticsearch/api/actions/machine_learning/get_buckets.rb +75 -0
- data/lib/elasticsearch/api/actions/machine_learning/get_calendar_events.rb +58 -0
- data/lib/elasticsearch/api/actions/machine_learning/get_calendars.rb +63 -0
- data/lib/elasticsearch/api/actions/machine_learning/get_categories.rb +69 -0
- data/lib/elasticsearch/api/actions/machine_learning/get_data_frame_analytics.rb +59 -0
- data/lib/elasticsearch/api/actions/machine_learning/get_data_frame_analytics_stats.rb +59 -0
- data/lib/elasticsearch/api/actions/machine_learning/get_datafeed_stats.rb +56 -0
- data/lib/elasticsearch/api/actions/machine_learning/get_datafeeds.rb +57 -0
- data/lib/elasticsearch/api/actions/machine_learning/get_filters.rb +57 -0
- data/lib/elasticsearch/api/actions/machine_learning/get_influencers.rb +67 -0
- data/lib/elasticsearch/api/actions/machine_learning/get_job_stats.rb +56 -0
- data/lib/elasticsearch/api/actions/machine_learning/get_jobs.rb +57 -0
- data/lib/elasticsearch/api/actions/machine_learning/get_memory_stats.rb +57 -0
- data/lib/elasticsearch/api/actions/machine_learning/get_model_snapshot_upgrade_stats.rb +58 -0
- data/lib/elasticsearch/api/actions/machine_learning/get_model_snapshots.rb +72 -0
- data/lib/elasticsearch/api/actions/machine_learning/get_overall_buckets.rb +66 -0
- data/lib/elasticsearch/api/actions/machine_learning/get_records.rb +67 -0
- data/lib/elasticsearch/api/actions/machine_learning/get_trained_models.rb +63 -0
- data/lib/elasticsearch/api/actions/machine_learning/get_trained_models_stats.rb +58 -0
- data/lib/elasticsearch/api/actions/machine_learning/infer_trained_model.rb +67 -0
- data/lib/elasticsearch/api/actions/machine_learning/info.rb +48 -0
- data/lib/elasticsearch/api/actions/machine_learning/open_job.rb +54 -0
- data/lib/elasticsearch/api/actions/machine_learning/post_calendar_events.rb +55 -0
- data/lib/elasticsearch/api/actions/machine_learning/post_data.rb +57 -0
- data/lib/elasticsearch/api/actions/machine_learning/preview_data_frame_analytics.rb +61 -0
- data/lib/elasticsearch/api/actions/machine_learning/preview_datafeed.rb +63 -0
- data/lib/elasticsearch/api/actions/machine_learning/put_calendar.rb +54 -0
- data/lib/elasticsearch/api/actions/machine_learning/put_calendar_job.rb +57 -0
- data/lib/elasticsearch/api/actions/machine_learning/put_data_frame_analytics.rb +55 -0
- data/lib/elasticsearch/api/actions/machine_learning/put_datafeed.rb +59 -0
- data/lib/elasticsearch/api/actions/machine_learning/put_filter.rb +55 -0
- data/lib/elasticsearch/api/actions/machine_learning/put_job.rb +59 -0
- data/lib/elasticsearch/api/actions/machine_learning/put_trained_model.rb +56 -0
- data/lib/elasticsearch/api/actions/machine_learning/put_trained_model_alias.rb +58 -0
- data/lib/elasticsearch/api/actions/machine_learning/put_trained_model_definition_part.rb +63 -0
- data/lib/elasticsearch/api/actions/machine_learning/put_trained_model_vocabulary.rb +59 -0
- data/lib/elasticsearch/api/actions/machine_learning/reset_job.rb +54 -0
- data/lib/elasticsearch/api/actions/machine_learning/revert_model_snapshot.rb +59 -0
- data/lib/elasticsearch/api/actions/machine_learning/set_upgrade_mode.rb +50 -0
- data/lib/elasticsearch/api/actions/machine_learning/start_data_frame_analytics.rb +55 -0
- data/lib/elasticsearch/api/actions/machine_learning/start_datafeed.rb +57 -0
- data/lib/elasticsearch/api/actions/machine_learning/start_trained_model_deployment.rb +64 -0
- data/lib/elasticsearch/api/actions/machine_learning/stop_data_frame_analytics.rb +57 -0
- data/lib/elasticsearch/api/actions/machine_learning/stop_datafeed.rb +58 -0
- data/lib/elasticsearch/api/actions/machine_learning/stop_trained_model_deployment.rb +60 -0
- data/lib/elasticsearch/api/actions/machine_learning/update_data_frame_analytics.rb +55 -0
- data/lib/elasticsearch/api/actions/machine_learning/update_datafeed.rb +59 -0
- data/lib/elasticsearch/api/actions/machine_learning/update_filter.rb +55 -0
- data/lib/elasticsearch/api/actions/machine_learning/update_job.rb +55 -0
- data/lib/elasticsearch/api/actions/machine_learning/update_model_snapshot.rb +59 -0
- data/lib/elasticsearch/api/actions/machine_learning/update_trained_model_deployment.rb +59 -0
- data/lib/elasticsearch/api/actions/machine_learning/upgrade_job_snapshot.rb +59 -0
- data/lib/elasticsearch/api/actions/machine_learning/validate.rb +51 -0
- data/lib/elasticsearch/api/actions/machine_learning/validate_detector.rb +51 -0
- data/lib/elasticsearch/api/actions/mget.rb +14 -32
- data/lib/elasticsearch/api/actions/migration/deprecations.rb +55 -0
- data/lib/elasticsearch/api/actions/migration/get_feature_upgrade_status.rb +48 -0
- data/lib/elasticsearch/api/actions/migration/post_feature_upgrade.rb +48 -0
- data/lib/elasticsearch/api/actions/monitoring/bulk.rb +74 -0
- data/lib/elasticsearch/api/actions/msearch.rb +13 -31
- data/lib/elasticsearch/api/actions/msearch_template.rb +13 -29
- data/lib/elasticsearch/api/actions/mtermvectors.rb +22 -46
- data/lib/elasticsearch/api/actions/nodes/clear_repositories_metering_archive.rb +63 -0
- data/lib/elasticsearch/api/actions/nodes/get_repositories_metering_info.rb +57 -0
- data/lib/elasticsearch/api/actions/nodes/hot_threads.rb +15 -26
- data/lib/elasticsearch/api/actions/nodes/info.rb +12 -15
- data/lib/elasticsearch/api/actions/nodes/reload_secure_settings.rb +11 -13
- data/lib/elasticsearch/api/actions/nodes/stats.rb +15 -23
- data/lib/elasticsearch/api/actions/nodes/usage.rb +11 -13
- data/lib/elasticsearch/api/actions/open_point_in_time.rb +56 -0
- data/lib/elasticsearch/api/actions/ping.rb +9 -6
- data/lib/elasticsearch/api/actions/put_script.rb +11 -15
- data/lib/elasticsearch/api/actions/rank_eval.rb +11 -20
- data/lib/elasticsearch/api/actions/reindex.rb +11 -20
- data/lib/elasticsearch/api/actions/reindex_rethrottle.rb +11 -13
- data/lib/elasticsearch/api/actions/render_search_template.rb +16 -11
- data/lib/elasticsearch/api/actions/rollup/delete_job.rb +57 -0
- data/lib/elasticsearch/api/actions/rollup/get_jobs.rb +59 -0
- data/lib/elasticsearch/api/actions/rollup/get_rollup_caps.rb +59 -0
- data/lib/elasticsearch/api/actions/rollup/get_rollup_index_caps.rb +57 -0
- data/lib/elasticsearch/api/actions/rollup/put_job.rb +59 -0
- data/lib/elasticsearch/api/actions/rollup/rollup_search.rb +61 -0
- data/lib/elasticsearch/api/actions/rollup/start_job.rb +57 -0
- data/lib/elasticsearch/api/actions/rollup/stop_job.rb +59 -0
- data/lib/elasticsearch/api/actions/scripts_painless_execute.rb +12 -7
- data/lib/elasticsearch/api/actions/scroll.rb +17 -21
- data/lib/elasticsearch/api/actions/search.rb +21 -71
- data/lib/elasticsearch/api/actions/search_mvt.rb +79 -0
- data/lib/elasticsearch/api/actions/search_shards.rb +11 -18
- data/lib/elasticsearch/api/actions/search_template.rb +13 -37
- data/lib/elasticsearch/api/actions/searchable_snapshots/cache_stats.rb +59 -0
- data/lib/elasticsearch/api/actions/{indices/flush_synced.rb → searchable_snapshots/clear_cache.rb} +21 -30
- data/lib/elasticsearch/api/actions/searchable_snapshots/mount.rb +62 -0
- data/lib/elasticsearch/api/actions/searchable_snapshots/stats.rb +56 -0
- data/lib/elasticsearch/api/actions/security/activate_user_profile.rb +51 -0
- data/lib/elasticsearch/api/actions/security/authenticate.rb +48 -0
- data/lib/elasticsearch/api/actions/security/bulk_update_api_keys.rb +51 -0
- data/lib/elasticsearch/api/actions/security/change_password.rb +59 -0
- data/lib/elasticsearch/api/actions/security/clear_api_key_cache.rb +53 -0
- data/lib/elasticsearch/api/actions/security/clear_cached_privileges.rb +53 -0
- data/lib/elasticsearch/api/actions/security/clear_cached_realms.rb +54 -0
- data/lib/elasticsearch/api/actions/security/clear_cached_roles.rb +53 -0
- data/lib/elasticsearch/api/actions/security/clear_cached_service_tokens.rb +61 -0
- data/lib/elasticsearch/api/actions/security/create_api_key.rb +52 -0
- data/lib/elasticsearch/api/actions/security/create_service_token.rb +65 -0
- data/lib/elasticsearch/api/actions/security/delete_privileges.rb +58 -0
- data/lib/elasticsearch/api/actions/security/delete_role.rb +54 -0
- data/lib/elasticsearch/api/actions/security/delete_role_mapping.rb +54 -0
- data/lib/elasticsearch/api/actions/security/delete_service_token.rb +62 -0
- data/lib/elasticsearch/api/actions/security/delete_user.rb +54 -0
- data/lib/elasticsearch/api/actions/security/disable_user.rb +54 -0
- data/lib/elasticsearch/api/actions/security/disable_user_profile.rb +54 -0
- data/lib/elasticsearch/api/actions/security/enable_user.rb +54 -0
- data/lib/elasticsearch/api/actions/security/enable_user_profile.rb +54 -0
- data/lib/elasticsearch/api/actions/security/enroll_kibana.rb +48 -0
- data/lib/elasticsearch/api/actions/security/enroll_node.rb +48 -0
- data/lib/elasticsearch/api/actions/security/get_api_key.rb +54 -0
- data/lib/elasticsearch/api/actions/security/get_builtin_privileges.rb +48 -0
- data/lib/elasticsearch/api/actions/security/get_privileges.rb +60 -0
- data/lib/elasticsearch/api/actions/security/get_role.rb +63 -0
- data/lib/elasticsearch/api/actions/security/get_role_mapping.rb +55 -0
- data/lib/elasticsearch/api/actions/security/get_service_accounts.rb +60 -0
- data/lib/elasticsearch/api/actions/security/get_service_credentials.rb +57 -0
- data/lib/elasticsearch/api/actions/security/get_token.rb +51 -0
- data/lib/elasticsearch/api/actions/security/get_user.rb +64 -0
- data/lib/elasticsearch/api/actions/security/get_user_privileges.rb +48 -0
- data/lib/elasticsearch/api/actions/security/get_user_profile.rb +54 -0
- data/lib/elasticsearch/api/actions/security/grant_api_key.rb +52 -0
- data/lib/elasticsearch/api/actions/security/has_privileges.rb +58 -0
- data/lib/elasticsearch/api/actions/security/has_privileges_user_profile.rb +51 -0
- data/lib/elasticsearch/api/actions/security/invalidate_api_key.rb +51 -0
- data/lib/elasticsearch/api/actions/security/invalidate_token.rb +51 -0
- data/lib/elasticsearch/api/actions/security/oidc_authenticate.rb +51 -0
- data/lib/elasticsearch/api/actions/security/oidc_logout.rb +51 -0
- data/lib/elasticsearch/api/actions/security/oidc_prepare_authentication.rb +51 -0
- data/lib/elasticsearch/api/actions/security/put_privileges.rb +52 -0
- data/lib/elasticsearch/api/actions/security/put_role.rb +56 -0
- data/lib/elasticsearch/api/actions/security/put_role_mapping.rb +56 -0
- data/lib/elasticsearch/api/actions/security/put_user.rb +56 -0
- data/lib/elasticsearch/api/actions/security/query_api_keys.rb +55 -0
- data/lib/elasticsearch/api/actions/security/saml_authenticate.rb +51 -0
- data/lib/elasticsearch/api/actions/security/saml_complete_logout.rb +51 -0
- data/lib/elasticsearch/api/actions/security/saml_invalidate.rb +51 -0
- data/lib/elasticsearch/api/actions/security/saml_logout.rb +51 -0
- data/lib/elasticsearch/api/actions/security/saml_prepare_authentication.rb +51 -0
- data/lib/elasticsearch/api/actions/security/saml_service_provider_metadata.rb +53 -0
- data/lib/elasticsearch/api/actions/security/suggest_user_profiles.rb +55 -0
- data/lib/elasticsearch/api/actions/security/update_api_key.rb +54 -0
- data/lib/elasticsearch/api/actions/security/update_user_profile_data.rb +58 -0
- data/lib/elasticsearch/api/actions/shutdown/delete_node.rb +53 -0
- data/lib/elasticsearch/api/actions/shutdown/get_node.rb +55 -0
- data/lib/elasticsearch/api/actions/shutdown/put_node.rb +55 -0
- data/lib/elasticsearch/api/actions/snapshot/cleanup_repository.rb +11 -14
- data/lib/elasticsearch/api/actions/snapshot/clone.rb +11 -13
- data/lib/elasticsearch/api/actions/snapshot/create.rb +11 -14
- data/lib/elasticsearch/api/actions/snapshot/create_repository.rb +11 -15
- data/lib/elasticsearch/api/actions/snapshot/delete.rb +18 -16
- data/lib/elasticsearch/api/actions/snapshot/delete_repository.rb +16 -15
- data/lib/elasticsearch/api/actions/snapshot/get.rb +26 -16
- data/lib/elasticsearch/api/actions/snapshot/get_repository.rb +16 -15
- data/lib/elasticsearch/api/actions/snapshot/repository_analyze.rb +64 -0
- data/lib/elasticsearch/api/actions/snapshot/restore.rb +11 -14
- data/lib/elasticsearch/api/actions/snapshot/status.rb +16 -15
- data/lib/elasticsearch/api/actions/snapshot/verify_repository.rb +11 -14
- data/lib/elasticsearch/api/actions/snapshot_lifecycle_management/delete_lifecycle.rb +53 -0
- data/lib/elasticsearch/api/actions/snapshot_lifecycle_management/execute_lifecycle.rb +53 -0
- data/lib/elasticsearch/api/actions/snapshot_lifecycle_management/execute_retention.rb +48 -0
- data/lib/elasticsearch/api/actions/snapshot_lifecycle_management/get_lifecycle.rb +55 -0
- data/lib/elasticsearch/api/actions/snapshot_lifecycle_management/get_stats.rb +48 -0
- data/lib/elasticsearch/api/actions/snapshot_lifecycle_management/get_status.rb +48 -0
- data/lib/elasticsearch/api/actions/snapshot_lifecycle_management/put_lifecycle.rb +54 -0
- data/lib/elasticsearch/api/actions/snapshot_lifecycle_management/start.rb +48 -0
- data/lib/elasticsearch/api/actions/snapshot_lifecycle_management/stop.rb +48 -0
- data/lib/elasticsearch/api/actions/sql/clear_cursor.rb +51 -0
- data/lib/elasticsearch/api/actions/sql/delete_async.rb +53 -0
- data/lib/elasticsearch/api/actions/sql/get_async.rb +57 -0
- data/lib/elasticsearch/api/actions/sql/get_async_status.rb +53 -0
- data/lib/elasticsearch/api/actions/sql/query.rb +52 -0
- data/lib/elasticsearch/api/actions/sql/translate.rb +51 -0
- data/lib/elasticsearch/api/actions/ssl/certificates.rb +48 -0
- data/lib/elasticsearch/api/actions/tasks/cancel.rb +11 -16
- data/lib/elasticsearch/api/actions/tasks/get.rb +11 -14
- data/lib/elasticsearch/api/actions/tasks/list.rb +11 -19
- data/lib/elasticsearch/api/actions/terms_enum.rb +57 -0
- data/lib/elasticsearch/api/actions/termvectors.rb +19 -43
- data/lib/elasticsearch/api/actions/text_structure/find_structure.rb +73 -0
- data/lib/elasticsearch/api/actions/transform/delete_transform.rb +55 -0
- data/lib/elasticsearch/api/actions/transform/get_transform.rb +59 -0
- data/lib/elasticsearch/api/actions/transform/get_transform_stats.rb +56 -0
- data/lib/elasticsearch/api/actions/transform/preview_transform.rb +62 -0
- data/lib/elasticsearch/api/actions/transform/put_transform.rb +57 -0
- data/lib/elasticsearch/api/actions/transform/reset_transform.rb +55 -0
- data/lib/elasticsearch/api/actions/transform/start_transform.rb +54 -0
- data/lib/elasticsearch/api/actions/transform/stop_transform.rb +58 -0
- data/lib/elasticsearch/api/actions/transform/update_transform.rb +57 -0
- data/lib/elasticsearch/api/actions/transform/upgrade_transforms.rb +50 -0
- data/lib/elasticsearch/api/actions/update.rb +17 -38
- data/lib/elasticsearch/api/actions/update_by_query.rb +13 -65
- data/lib/elasticsearch/api/actions/update_by_query_rethrottle.rb +11 -13
- data/lib/elasticsearch/api/actions/watcher/ack_watch.rb +60 -0
- data/lib/elasticsearch/api/actions/watcher/activate_watch.rb +53 -0
- data/lib/elasticsearch/api/actions/watcher/deactivate_watch.rb +53 -0
- data/lib/elasticsearch/api/actions/watcher/delete_watch.rb +61 -0
- data/lib/elasticsearch/api/actions/watcher/execute_watch.rb +57 -0
- data/lib/elasticsearch/api/actions/watcher/get_watch.rb +53 -0
- data/lib/elasticsearch/api/actions/watcher/put_watch.rb +58 -0
- data/lib/elasticsearch/api/actions/watcher/query_watches.rb +54 -0
- data/lib/elasticsearch/api/actions/watcher/start.rb +48 -0
- data/lib/elasticsearch/api/actions/watcher/stats.rb +56 -0
- data/lib/elasticsearch/api/actions/watcher/stop.rb +48 -0
- data/lib/elasticsearch/api/actions/xpack/info.rb +50 -0
- data/lib/elasticsearch/api/actions/xpack/usage.rb +49 -0
- data/lib/elasticsearch/api/namespace/async_search.rb +36 -0
- data/lib/elasticsearch/api/{actions/remote/info.rb → namespace/autoscaling.rb} +12 -13
- data/lib/elasticsearch/api/namespace/cross_cluster_replication.rb +38 -0
- data/lib/elasticsearch/api/namespace/data_frame_transform_deprecated.rb +36 -0
- data/lib/elasticsearch/api/namespace/enrich.rb +36 -0
- data/lib/elasticsearch/api/namespace/eql.rb +36 -0
- data/lib/elasticsearch/api/namespace/features.rb +36 -0
- data/lib/elasticsearch/api/namespace/fleet.rb +36 -0
- data/lib/elasticsearch/api/namespace/graph.rb +36 -0
- data/lib/elasticsearch/api/namespace/index_lifecycle_management.rb +38 -0
- data/lib/elasticsearch/api/namespace/ingest.rb +0 -1
- data/lib/elasticsearch/api/namespace/license.rb +36 -0
- data/lib/elasticsearch/api/namespace/logstash.rb +36 -0
- data/lib/elasticsearch/api/{actions/abort_benchmark.rb → namespace/machine_learning.rb} +13 -16
- data/lib/elasticsearch/api/namespace/migration.rb +36 -0
- data/lib/elasticsearch/api/namespace/monitoring.rb +36 -0
- data/lib/elasticsearch/api/namespace/rollup.rb +36 -0
- data/lib/elasticsearch/api/namespace/searchable_snapshots.rb +36 -0
- data/lib/elasticsearch/api/namespace/security.rb +36 -0
- data/lib/elasticsearch/api/namespace/shutdown.rb +37 -0
- data/lib/elasticsearch/api/namespace/snapshot_lifecycle_management.rb +38 -0
- data/lib/elasticsearch/api/namespace/sql.rb +36 -0
- data/lib/elasticsearch/api/namespace/ssl.rb +36 -0
- data/lib/elasticsearch/api/namespace/text_structure.rb +36 -0
- data/lib/elasticsearch/api/namespace/transform.rb +36 -0
- data/lib/elasticsearch/api/namespace/watcher.rb +36 -0
- data/lib/elasticsearch/api/namespace/xpack.rb +36 -0
- data/lib/elasticsearch/api/response.rb +48 -0
- data/lib/elasticsearch/api/utils.rb +6 -56
- data/lib/elasticsearch/api/version.rb +1 -1
- data/lib/elasticsearch/api.rb +28 -21
- data/spec/elasticsearch/api/actions/bulk_spec.rb +17 -36
- data/spec/elasticsearch/api/actions/cat/aliases_spec.rb +1 -1
- data/spec/elasticsearch/api/actions/cat/allocation_spec.rb +1 -1
- data/spec/elasticsearch/api/actions/cat/component_templates_spec.rb +46 -0
- data/spec/elasticsearch/api/actions/cat/count_spec.rb +1 -1
- data/spec/elasticsearch/api/actions/cat/fielddata_spec.rb +2 -2
- data/spec/elasticsearch/api/actions/cat/health_spec.rb +1 -1
- data/spec/elasticsearch/api/actions/cat/help_spec.rb +1 -1
- data/spec/elasticsearch/api/actions/cat/indices_spec.rb +1 -1
- data/spec/elasticsearch/api/actions/cat/master_spec.rb +1 -1
- data/spec/elasticsearch/api/actions/cat/nodeattrs_spec.rb +1 -1
- data/spec/elasticsearch/api/actions/cat/nodes_spec.rb +1 -1
- data/spec/elasticsearch/api/actions/cat/pending_tasks_spec.rb +1 -1
- data/spec/elasticsearch/api/actions/cat/plugins_spec.rb +1 -1
- data/spec/elasticsearch/api/actions/cat/recovery_spec.rb +1 -1
- data/spec/elasticsearch/api/actions/cat/repositories_spec.rb +1 -1
- data/spec/elasticsearch/api/actions/cat/segments_spec.rb +2 -2
- data/spec/elasticsearch/api/actions/cat/shards_spec.rb +1 -1
- data/spec/elasticsearch/api/actions/cat/snapshot_spec.rb +1 -1
- data/spec/elasticsearch/api/actions/cat/tasks_spec.rb +1 -1
- data/spec/elasticsearch/api/actions/cat/templates_spec.rb +1 -1
- data/spec/elasticsearch/api/actions/cat/thread_pool_spec.rb +1 -1
- data/spec/elasticsearch/api/actions/clear_scroll_spec.rb +2 -2
- data/spec/elasticsearch/api/actions/{benchmark_spec.rb → close_point_in_time_spec.rb} +6 -6
- data/spec/elasticsearch/api/actions/cluster/allocation_explain_spec.rb +1 -1
- data/spec/elasticsearch/api/actions/cluster/get_settings_spec.rb +1 -1
- data/spec/elasticsearch/api/actions/cluster/health_spec.rb +3 -3
- data/spec/elasticsearch/api/actions/cluster/pending_tasks_spec.rb +1 -1
- data/spec/elasticsearch/api/actions/cluster/put_settings_spec.rb +1 -1
- data/spec/elasticsearch/api/actions/cluster/remote_info_spec.rb +1 -1
- data/spec/elasticsearch/api/actions/cluster/reroute_spec.rb +2 -2
- data/spec/elasticsearch/api/actions/cluster/state_spec.rb +2 -2
- data/spec/elasticsearch/api/actions/cluster/stats_spec.rb +1 -1
- data/spec/elasticsearch/api/actions/count_spec.rb +6 -9
- data/spec/elasticsearch/api/actions/create_document_spec.rb +8 -8
- data/spec/elasticsearch/api/actions/dangling_indices/delete_dangling_indices_spec.rb +1 -1
- data/spec/elasticsearch/api/actions/dangling_indices/import_dangling_indices_spec.rb +1 -1
- data/spec/elasticsearch/api/actions/dangling_indices/list_dangling_indices_spec.rb +1 -1
- data/spec/elasticsearch/api/actions/{indices/freeze_spec.rb → data_frame/update_data_frame_transform_spec.rb} +26 -30
- data/spec/elasticsearch/api/actions/delete_by_query_spec.rb +2 -19
- data/spec/elasticsearch/api/actions/delete_document_spec.rb +9 -22
- data/spec/elasticsearch/api/actions/delete_script_spec.rb +1 -1
- data/spec/elasticsearch/api/actions/exists_document_spec.rb +10 -21
- data/spec/elasticsearch/api/actions/explain_document_spec.rb +9 -9
- data/spec/elasticsearch/api/actions/features/get_features_spec.rb +38 -0
- data/spec/elasticsearch/api/actions/features/reset_features_spec.rb +38 -0
- data/spec/elasticsearch/api/actions/field_caps_spec.rb +1 -1
- data/spec/elasticsearch/api/actions/fleet/global_checkpoints_spec.rb +44 -0
- data/spec/elasticsearch/api/actions/fleet/msearch_spec.rb +44 -0
- data/spec/elasticsearch/api/actions/fleet/search_spec.rb +44 -0
- data/spec/elasticsearch/api/actions/get_document_source_spec.rb +6 -18
- data/spec/elasticsearch/api/actions/get_document_spec.rb +6 -31
- data/spec/elasticsearch/api/actions/get_script_spec.rb +1 -1
- data/spec/elasticsearch/api/actions/index_document_spec.rb +10 -28
- data/spec/elasticsearch/api/actions/index_lifecycle_management/migrate_to_data_tiers_spec.rb +36 -0
- data/spec/elasticsearch/api/actions/indices/add_block_spec.rb +1 -1
- data/spec/elasticsearch/api/actions/indices/analyze_spec.rb +3 -3
- data/spec/elasticsearch/api/actions/indices/clear_cache_spec.rb +20 -7
- data/spec/elasticsearch/api/actions/indices/clone_spec.rb +6 -6
- data/spec/elasticsearch/api/actions/indices/close_spec.rb +3 -3
- data/spec/elasticsearch/api/actions/indices/create_spec.rb +3 -3
- data/spec/elasticsearch/api/actions/{nodes/shutdown_spec.rb → indices/data_streams_stats_spec.rb} +14 -32
- data/spec/elasticsearch/api/actions/indices/delete_alias_spec.rb +2 -2
- data/spec/elasticsearch/api/actions/indices/delete_spec.rb +4 -4
- data/spec/elasticsearch/api/actions/indices/delete_template_spec.rb +2 -2
- data/spec/elasticsearch/api/actions/indices/disk_usage_spec.rb +48 -0
- data/spec/elasticsearch/api/actions/indices/field_usage_stats_spec.rb +46 -0
- data/spec/elasticsearch/api/actions/indices/flush_spec.rb +5 -5
- data/spec/elasticsearch/api/actions/indices/forcemerge_spec.rb +1 -1
- data/spec/elasticsearch/api/actions/indices/get_alias_spec.rb +3 -3
- data/spec/elasticsearch/api/actions/indices/get_field_mapping_spec.rb +2 -13
- data/spec/elasticsearch/api/actions/indices/get_mapping_spec.rb +7 -22
- data/spec/elasticsearch/api/actions/indices/get_settings_spec.rb +4 -4
- data/spec/elasticsearch/api/actions/indices/get_spec.rb +2 -2
- data/spec/elasticsearch/api/actions/indices/open_spec.rb +3 -3
- data/spec/elasticsearch/api/actions/indices/put_alias_spec.rb +4 -4
- data/spec/elasticsearch/api/actions/indices/put_mapping_spec.rb +8 -14
- data/spec/elasticsearch/api/actions/indices/put_settings_spec.rb +5 -5
- data/spec/elasticsearch/api/actions/indices/put_template_spec.rb +3 -3
- data/spec/elasticsearch/api/actions/indices/recovery_spec.rb +1 -1
- data/spec/elasticsearch/api/actions/indices/refresh_spec.rb +5 -5
- data/spec/elasticsearch/api/actions/indices/rollover_spec.rb +2 -2
- data/spec/elasticsearch/api/actions/indices/segments_spec.rb +5 -5
- data/spec/elasticsearch/api/actions/indices/shard_stores_spec.rb +1 -1
- data/spec/elasticsearch/api/actions/indices/shrink_spec.rb +1 -1
- data/spec/elasticsearch/api/actions/indices/split_spec.rb +1 -1
- data/spec/elasticsearch/api/actions/indices/stats_spec.rb +7 -12
- data/spec/elasticsearch/api/actions/indices/unfreeze_spec.rb +4 -4
- data/spec/elasticsearch/api/actions/indices/update_aliases_spec.rb +2 -2
- data/spec/elasticsearch/api/actions/indices/validate_query_spec.rb +7 -17
- data/spec/elasticsearch/api/actions/info_spec.rb +1 -1
- data/spec/elasticsearch/api/actions/ingest/delete_pipeline_spec.rb +2 -2
- data/spec/elasticsearch/api/actions/ingest/geo_ip_stats_spec.rb +38 -0
- data/spec/elasticsearch/api/actions/ingest/get_pipeline_spec.rb +2 -2
- data/spec/elasticsearch/api/actions/ingest/put_pipeline_spec.rb +2 -2
- data/spec/elasticsearch/api/actions/ingest/simulate_spec.rb +2 -2
- data/spec/elasticsearch/api/actions/json_builders_spec.rb +2 -2
- data/spec/elasticsearch/api/actions/machine_learning/get_memory_stats_spec.rb +47 -0
- data/spec/elasticsearch/api/actions/machine_learning/get_model_snapshot_upgrade_stats_spec.rb +56 -0
- data/spec/elasticsearch/api/actions/machine_learning/infer_trained_model_deployment_spec.rb +46 -0
- data/spec/elasticsearch/api/actions/machine_learning/put_trained_model_definition_part_spec.rb +62 -0
- data/spec/elasticsearch/api/actions/machine_learning/put_trained_model_vocabulary_spec.rb +54 -0
- data/spec/elasticsearch/api/actions/machine_learning/reset_job_spec.rb +46 -0
- data/spec/elasticsearch/api/actions/machine_learning/set_upgrade_mode_spec.rb +51 -0
- data/spec/elasticsearch/api/actions/machine_learning/start_trained_model_deployment_spec.rb +46 -0
- data/spec/elasticsearch/api/actions/machine_learning/stop_trained_model_deployment_spec.rb +46 -0
- data/spec/elasticsearch/api/actions/machine_learning/update_trained_model_deployment_spec.rb +34 -0
- data/spec/elasticsearch/api/actions/mget_spec.rb +5 -20
- data/spec/elasticsearch/api/actions/migration/get_feature_upgrade_status_spec.rb +34 -0
- data/spec/elasticsearch/api/actions/migration/post_feature_upgrade_spec.rb +34 -0
- data/spec/elasticsearch/api/actions/msearch_spec.rb +16 -14
- data/spec/elasticsearch/api/actions/msearch_template_spec.rb +2 -2
- data/spec/elasticsearch/api/actions/mtermvectors_spec.rb +4 -6
- data/spec/elasticsearch/api/actions/nodes/clear_repositories_metering_archive_spec.rb +51 -0
- data/spec/elasticsearch/api/actions/nodes/get_repositories_metering_info_spec.rb +44 -0
- data/spec/elasticsearch/api/actions/nodes/hot_threads_spec.rb +6 -6
- data/spec/elasticsearch/api/actions/nodes/info_spec.rb +6 -6
- data/spec/elasticsearch/api/actions/nodes/reload_secure_settings_spec.rb +5 -5
- data/spec/elasticsearch/api/actions/nodes/stats_spec.rb +4 -4
- data/spec/elasticsearch/api/actions/{abort_benchmark_spec.rb → open_point_in_time_spec.rb} +5 -5
- data/spec/elasticsearch/api/actions/put_script_spec.rb +2 -2
- data/spec/elasticsearch/api/actions/rank_eval_spec.rb +127 -0
- data/spec/elasticsearch/api/actions/reindex_spec.rb +1 -1
- data/spec/elasticsearch/api/actions/render_search_template_spec.rb +2 -2
- data/spec/elasticsearch/api/actions/scroll_spec.rb +2 -2
- data/spec/elasticsearch/api/actions/search_mvt_spec.rb +53 -0
- data/spec/elasticsearch/api/actions/search_shards_spec.rb +1 -1
- data/spec/elasticsearch/api/actions/search_spec.rb +2 -40
- data/spec/elasticsearch/api/actions/search_template_spec.rb +1 -1
- data/spec/elasticsearch/api/actions/searchable_snapshots/cache_stats_spec.rb +44 -0
- data/spec/elasticsearch/api/actions/searchable_snapshots/clear_cache_spec.rb +44 -0
- data/spec/elasticsearch/api/actions/searchable_snapshots/mount_spec.rb +56 -0
- data/spec/elasticsearch/api/actions/searchable_snapshots/stats_spec.rb +43 -0
- data/spec/elasticsearch/api/actions/security/clear_cached_service_tokens_spec.rb +58 -0
- data/spec/elasticsearch/api/actions/security/create_api_key_spec.rb +79 -0
- data/spec/elasticsearch/api/actions/security/create_service_token_spec.rb +69 -0
- data/spec/elasticsearch/api/actions/security/delete_service_token_spec.rb +60 -0
- data/spec/elasticsearch/api/actions/security/disable_user_profile_spec.rb +34 -0
- data/spec/elasticsearch/api/actions/security/enable_user_profile_spec.rb +34 -0
- data/spec/elasticsearch/api/actions/{indices/upgrade_spec.rb → security/enroll_kibana_spec.rb} +7 -8
- data/spec/elasticsearch/api/actions/security/get_api_key_spec.rb +56 -0
- data/spec/elasticsearch/api/actions/{remote/info_spec.rb → security/get_builtin_privileges_spec.rb} +4 -4
- data/spec/elasticsearch/api/actions/security/get_service_accounts_spec.rb +58 -0
- data/spec/elasticsearch/api/actions/security/get_service_credentials_spec.rb +53 -0
- data/spec/elasticsearch/api/actions/security/has_privileges_user_profile_spec.rb +34 -0
- data/spec/elasticsearch/api/actions/security/invalidate_api_key_spec.rb +38 -0
- data/spec/elasticsearch/api/actions/security/query_api_keys_spec.rb +48 -0
- data/spec/elasticsearch/api/actions/security/saml_authenticate_spec.rb +44 -0
- data/spec/elasticsearch/api/actions/security/saml_complete_logout_spec.rb +44 -0
- data/spec/elasticsearch/api/actions/security/saml_invalidate_spec.rb +44 -0
- data/spec/elasticsearch/api/actions/security/saml_logout_spec.rb +44 -0
- data/spec/elasticsearch/api/actions/security/saml_prepare_authentication_spec.rb +44 -0
- data/spec/elasticsearch/api/actions/security/saml_service_provider_metadata_spec.rb +46 -0
- data/spec/elasticsearch/api/actions/security/suggest_user_profiles_spec.rb +45 -0
- data/spec/elasticsearch/api/actions/security/update_api_key_spec.rb +34 -0
- data/spec/elasticsearch/api/actions/shutdown/delete_node_spec.rb +44 -0
- data/spec/elasticsearch/api/actions/shutdown/get_node_spec.rb +46 -0
- data/spec/elasticsearch/api/actions/shutdown/put_node_spec.rb +50 -0
- data/spec/elasticsearch/api/actions/snapshot/clone_spec.rb +1 -1
- data/spec/elasticsearch/api/actions/snapshot/create_repository_spec.rb +1 -1
- data/spec/elasticsearch/api/actions/snapshot/create_spec.rb +1 -1
- data/spec/elasticsearch/api/actions/snapshot/delete_repository_spec.rb +2 -2
- data/spec/elasticsearch/api/actions/snapshot/delete_spec.rb +1 -1
- data/spec/elasticsearch/api/actions/snapshot/get_repository_spec.rb +1 -1
- data/spec/elasticsearch/api/actions/snapshot/get_spec.rb +1 -1
- data/spec/elasticsearch/api/actions/snapshot/repository_analize_spec.rb +46 -0
- data/spec/elasticsearch/api/actions/snapshot/restore_spec.rb +7 -10
- data/spec/elasticsearch/api/actions/snapshot/status_spec.rb +2 -3
- data/spec/elasticsearch/api/actions/snapshot/verify_repository_spec.rb +6 -7
- data/spec/elasticsearch/api/actions/sql/delete_async_spec.rb +46 -0
- data/spec/elasticsearch/api/actions/sql/get_async_spec.rb +46 -0
- data/spec/elasticsearch/api/actions/sql/get_async_stats_spec.rb +46 -0
- data/spec/elasticsearch/api/actions/tasks/cancel_spec.rb +7 -8
- data/spec/elasticsearch/api/actions/tasks/get_spec.rb +1 -1
- data/spec/elasticsearch/api/actions/tasks/list_spec.rb +6 -7
- data/spec/elasticsearch/api/actions/terms_enum_spec.rb +52 -0
- data/spec/elasticsearch/api/actions/termvectors_spec.rb +5 -5
- data/spec/elasticsearch/api/actions/update_by_query_spec.rb +6 -7
- data/spec/elasticsearch/api/actions/update_document_spec.rb +15 -29
- data/spec/elasticsearch/api/api_response_spec.rb +65 -0
- data/spec/elasticsearch/api/api_spec.rb +0 -3
- data/spec/elasticsearch/api/client_spec.rb +0 -4
- data/spec/elasticsearch/api/rest_api_yaml_spec.rb +44 -114
- data/spec/elasticsearch/api/run_rspec_matchers.rb +111 -0
- data/spec/elasticsearch/api/utils_spec.rb +14 -89
- data/spec/rest_api_tests_helper.rb +93 -0
- data/spec/skipped_tests_free.yml +34 -0
- data/spec/skipped_tests_platinum.yml +54 -0
- data/spec/spec_helper.rb +18 -19
- data/spec/unit_tests_platinum/test_helper.rb +72 -0
- data/spec/unit_tests_platinum/unit/async_search/delete_test.rb +39 -0
- data/spec/unit_tests_platinum/unit/async_search/get_test.rb +39 -0
- data/spec/unit_tests_platinum/unit/async_search/status_test.rb +39 -0
- data/spec/unit_tests_platinum/unit/async_search/submit_test.rb +50 -0
- data/spec/unit_tests_platinum/unit/autoscaling/delete_autoscaling_policy_test.rb +46 -0
- data/spec/unit_tests_platinum/unit/autoscaling/get_autoscaling_capacity_test.rb +40 -0
- data/spec/unit_tests_platinum/unit/autoscaling/get_autoscaling_policy_test.rb +46 -0
- data/spec/unit_tests_platinum/unit/autoscaling/put_autoscaling_policy_test.rb +52 -0
- data/spec/unit_tests_platinum/unit/enrich/delete_policy_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/eql/delete_test.rb +46 -0
- data/spec/unit_tests_platinum/unit/eql/get_status_test.rb +46 -0
- data/spec/unit_tests_platinum/unit/eql/get_test.rb +46 -0
- data/spec/unit_tests_platinum/unit/eql/search_test.rb +52 -0
- data/spec/unit_tests_platinum/unit/graph/explore_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/index_lifecycle_management/explain_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/index_lifecycle_management/get_status_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/index_lifecycle_management/move_to_step.rb +43 -0
- data/spec/unit_tests_platinum/unit/index_lifecycle_management/remove_policy_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/index_lifecycle_management/retry_policy_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/index_lifecycle_management/start_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/index_lifecycle_management/stop_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/indices/create_data_stream_test.rb +46 -0
- data/spec/unit_tests_platinum/unit/indices/data_stream_stats_test.rb +54 -0
- data/spec/unit_tests_platinum/unit/indices/delete_data_stream_test.rb +46 -0
- data/spec/unit_tests_platinum/unit/indices/downsample_test.rb +58 -0
- data/spec/unit_tests_platinum/unit/indices/get_data_stream_test.rb +50 -0
- data/spec/unit_tests_platinum/unit/indices/migrate_to_data_stream_test.rb +46 -0
- data/spec/unit_tests_platinum/unit/indices/modify_data_stream_test.rb +46 -0
- data/spec/unit_tests_platinum/unit/indices/promote_data_stream_test.rb +46 -0
- data/spec/unit_tests_platinum/unit/info_test.rb +40 -0
- data/spec/unit_tests_platinum/unit/knn_search_test.rb +40 -0
- data/spec/unit_tests_platinum/unit/license/delete_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/license/get_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/license/post_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/logstash/delete_pipeline_test.rb +46 -0
- data/spec/unit_tests_platinum/unit/logstash/get_pipeline_test.rb +46 -0
- data/spec/unit_tests_platinum/unit/logstash/put_pipeline_test.rb +46 -0
- data/spec/unit_tests_platinum/unit/machine_learning/clear_trained_model_deployment_cache_test.rb +40 -0
- data/spec/unit_tests_platinum/unit/machine_learning/close_job_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/machine_learning/delete_datafeed_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/machine_learning/delete_expired_data_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/machine_learning/delete_filter_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/machine_learning/delete_forecast_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/machine_learning/delete_job_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/machine_learning/delete_model_alias_test.rb +40 -0
- data/spec/unit_tests_platinum/unit/machine_learning/delete_model_snapshot_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/machine_learning/flush_job_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/machine_learning/forecast_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/machine_learning/get_buckets_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/machine_learning/get_categories_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/machine_learning/get_datafeed_stats_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/machine_learning/get_datafeeds_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/machine_learning/get_filters_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/machine_learning/get_influencers_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/machine_learning/get_job_stats_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/machine_learning/get_jobs_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/machine_learning/get_model_snapshots_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/machine_learning/get_overall_buckets_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/machine_learning/get_records_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/machine_learning/open_job_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/machine_learning/post_data_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/machine_learning/preview_data_frame_analytics_test.rb +64 -0
- data/spec/unit_tests_platinum/unit/machine_learning/preview_datafeed_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/machine_learning/put_datafeed_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/machine_learning/put_filter_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/machine_learning/put_job_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/machine_learning/put_trained_model_alias_test.rb +40 -0
- data/spec/unit_tests_platinum/unit/machine_learning/revert_model_snapshot_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/machine_learning/start_datafeed_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/machine_learning/stop_datafeed_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/machine_learning/update_data_frame_analytics_test.rb +40 -0
- data/spec/unit_tests_platinum/unit/machine_learning/update_datafeed_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/machine_learning/update_filter_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/machine_learning/update_job_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/machine_learning/update_model_snapshot_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/machine_learning/upgrade_job_snapshot_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/machine_learning/validate_detector_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/machine_learning/validate_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/migration/deprecations_test.rb +42 -0
- data/spec/unit_tests_platinum/unit/monitoring/bulk_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/rollup/get_rollup_index_caps_test.rb +40 -0
- data/spec/unit_tests_platinum/unit/security/activate_user_profile_test.rb +40 -0
- data/spec/unit_tests_platinum/unit/security/authenticate_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/security/bulk_update_api_key_test.rb +40 -0
- data/spec/unit_tests_platinum/unit/security/change_password_test.rb +55 -0
- data/spec/unit_tests_platinum/unit/security/clear_api_key_cache_test.rb +40 -0
- data/spec/unit_tests_platinum/unit/security/clear_cached_privileges_test.rb +40 -0
- data/spec/unit_tests_platinum/unit/security/clear_cached_realms_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/security/clear_cached_roles_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/security/delete_privileges_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/security/delete_role_mapping_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/security/delete_role_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/security/delete_user_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/security/disable_user_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/security/enable_user_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/security/get_privileges_test.rb +78 -0
- data/spec/unit_tests_platinum/unit/security/get_role_mapping_test.rb +54 -0
- data/spec/unit_tests_platinum/unit/security/get_role_test.rb +62 -0
- data/spec/unit_tests_platinum/unit/security/get_token_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/security/get_user_privileges_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/security/get_user_profile_test.rb +40 -0
- data/spec/unit_tests_platinum/unit/security/get_user_test.rb +61 -0
- data/spec/unit_tests_platinum/unit/security/grant_api_key_test.rb +41 -0
- data/spec/unit_tests_platinum/unit/security/has_privileges_test.rb +55 -0
- data/spec/unit_tests_platinum/unit/security/invalidate_token_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/security/oidc_authenticate_test.rb +40 -0
- data/spec/unit_tests_platinum/unit/security/oidc_logout_test.rb +40 -0
- data/spec/unit_tests_platinum/unit/security/oidc_prepare_authentication_test.rb +40 -0
- data/spec/unit_tests_platinum/unit/security/put_privileges_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/security/put_role_mapping_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/security/put_role_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/security/put_user_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/security/update_user_profile_data_test.rb +40 -0
- data/spec/unit_tests_platinum/unit/ssl/certificates_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/text_structure/find_structure_test.rb +40 -0
- data/spec/unit_tests_platinum/unit/transform/reset_transform_spec.rb +34 -0
- data/spec/unit_tests_platinum/unit/transform/upgrade_transforms_spec.rb +34 -0
- data/spec/unit_tests_platinum/unit/usage_test.rb +40 -0
- data/spec/unit_tests_platinum/unit/watcher/ack_watch_test.rb +55 -0
- data/spec/unit_tests_platinum/unit/watcher/activate_watch_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/watcher/deactivate_watch_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/watcher/delete_watch_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/watcher/execute_watch_test.rb +55 -0
- data/spec/unit_tests_platinum/unit/watcher/get_watch_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/watcher/put_watch_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/watcher/query_watches_test.rb +52 -0
- data/spec/unit_tests_platinum/unit/watcher/start_test.rb +41 -0
- data/spec/unit_tests_platinum/unit/watcher/stats_test.rb +43 -0
- data/spec/unit_tests_platinum/unit/watcher/stop_test.rb +43 -0
- data/utils/Gemfile +3 -4
- data/utils/README.md +15 -8
- data/utils/thor/generate_source.rb +78 -46
- data/utils/thor/generator/endpoint_specifics.rb +5 -27
- data/utils/thor/generator/files_helper.rb +30 -25
- data/utils/thor/templates/_body.erb +34 -0
- data/utils/thor/templates/_documentation_top.erb +19 -1
- data/utils/thor/templates/_method_setup.erb +37 -32
- data/utils/thor/templates/_perform_request.erb +34 -22
- data/utils/thor/templates/method.erb +5 -8
- data/utils/thor/templates/test.erb +16 -3
- data/utils/thor/templates/test_helper.rb +0 -4
- metadata +732 -99
- data/lib/elasticsearch/api/actions/benchmark.rb +0 -81
- data/lib/elasticsearch/api/actions/cat/params_registry.rb +0 -60
- data/lib/elasticsearch/api/actions/cluster/params_registry.rb +0 -60
- data/lib/elasticsearch/api/actions/dangling_indices/params_registry.rb +0 -60
- data/lib/elasticsearch/api/actions/delete_by_rethrottle.rb +0 -47
- data/lib/elasticsearch/api/actions/indices/params_registry.rb +0 -60
- data/lib/elasticsearch/api/actions/ingest/params_registry.rb +0 -60
- data/lib/elasticsearch/api/actions/nodes/params_registry.rb +0 -60
- data/lib/elasticsearch/api/actions/nodes/shutdown.rb +0 -56
- data/lib/elasticsearch/api/actions/params_registry.rb +0 -58
- data/lib/elasticsearch/api/actions/snapshot/params_registry.rb +0 -60
- data/lib/elasticsearch/api/actions/tasks/params_registry.rb +0 -60
- data/spec/elasticsearch/api/actions/indices/exists_type_spec.rb +0 -108
- data/spec/elasticsearch/api/actions/indices/flush_synced_spec.rb +0 -90
- data/spec/rest_yaml_tests_helper.rb +0 -117
- data/utils/thor/templates/_params_registry.erb +0 -12
- /data/{LICENSE → LICENSE.txt} +0 -0
@@ -0,0 +1,179 @@
|
|
1
|
+
# Licensed to Elasticsearch B.V. under one or more contributor
|
2
|
+
# license agreements. See the NOTICE file distributed with
|
3
|
+
# this work for additional information regarding copyright
|
4
|
+
# ownership. Elasticsearch B.V. licenses this file to you under
|
5
|
+
# the Apache License, Version 2.0 (the "License"); you may
|
6
|
+
# not use this file except in compliance with the License.
|
7
|
+
# You may obtain a copy of the License at
|
8
|
+
#
|
9
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
10
|
+
#
|
11
|
+
# Unless required by applicable law or agreed to in writing,
|
12
|
+
# software distributed under the License is distributed on an
|
13
|
+
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
14
|
+
# KIND, either express or implied. See the License for the
|
15
|
+
# specific language governing permissions and limitations
|
16
|
+
# under the License.
|
17
|
+
|
18
|
+
require_relative 'test_file/action'
|
19
|
+
require_relative 'test_file/test'
|
20
|
+
require_relative 'test_file/task_group'
|
21
|
+
require_relative 'logging'
|
22
|
+
|
23
|
+
module Elasticsearch
|
24
|
+
module RestAPIYAMLTests
|
25
|
+
# Custom exception to raise when a test file needs to be skipped. This is
|
26
|
+
# captured as soon as possible so the test runners can move on to the next test.
|
27
|
+
class SkipTestsException < StandardError
|
28
|
+
end
|
29
|
+
|
30
|
+
# Class representing a single test file, containing a setup, teardown, and multiple tests.
|
31
|
+
#
|
32
|
+
# @since 6.2.0
|
33
|
+
class TestFile
|
34
|
+
include Elasticsearch::RestAPIYAMLTests::Logging
|
35
|
+
attr_reader :features_to_skip, :name, :client
|
36
|
+
|
37
|
+
# Initialize a single test file.
|
38
|
+
#
|
39
|
+
# @example Create a test file object.
|
40
|
+
# TestFile.new(file_name)
|
41
|
+
#
|
42
|
+
# @param [ String ] file_name The name of the test file.
|
43
|
+
# @param [ Client] An instance of the client
|
44
|
+
# @param [ Array<Symbol> ] skip_features The names of features to skip.
|
45
|
+
#
|
46
|
+
# @since 6.1.0
|
47
|
+
def initialize(file_name, client, features_to_skip = [])
|
48
|
+
@name = file_name
|
49
|
+
@client = client
|
50
|
+
begin
|
51
|
+
documents = YAML.load_stream(File.new(file_name))
|
52
|
+
rescue Psych::SyntaxError => e
|
53
|
+
raise e unless e.message.include?('found unexpected \':\'')
|
54
|
+
|
55
|
+
message = "Exception found when parsing YAML in #{file_name}: #{e.message}"
|
56
|
+
logger.error message
|
57
|
+
raise SkipTestsException, message
|
58
|
+
rescue StandardError => e
|
59
|
+
logger.error e
|
60
|
+
logger.error "Filename : #{@name}"
|
61
|
+
end
|
62
|
+
@test_definitions = documents.reject { |doc| doc['setup'] || doc['teardown'] }
|
63
|
+
@setup = documents.find { |doc| doc['setup'] }
|
64
|
+
skip_entire_test_file?(file_name) if @setup
|
65
|
+
@teardown = documents.find { |doc| doc['teardown'] }
|
66
|
+
@features_to_skip = REST_API_YAML_SKIP_FEATURES + features_to_skip
|
67
|
+
end
|
68
|
+
|
69
|
+
def skip_entire_test_file?(file_name)
|
70
|
+
@skip = @setup['setup']&.select { |a| a['skip'] }
|
71
|
+
return false if @skip.empty?
|
72
|
+
|
73
|
+
raise SkipTestsException, "Skipping #{file_name} due to 'skip all'." if skip_version?(@client, @skip.first['skip'])
|
74
|
+
end
|
75
|
+
|
76
|
+
def skip_version?(client, skip_definition)
|
77
|
+
return true if skip_definition['version'] == 'all'
|
78
|
+
|
79
|
+
range_partition = /\s*-\s*/
|
80
|
+
return unless (versions = skip_definition['version'])
|
81
|
+
|
82
|
+
low, high = __parse_versions(versions.partition(range_partition))
|
83
|
+
range = low..high
|
84
|
+
begin
|
85
|
+
server_version = client.info['version']['number']
|
86
|
+
rescue
|
87
|
+
warn('Could not determine Elasticsearch version when checking if test should be skipped.')
|
88
|
+
end
|
89
|
+
range.cover?(Gem::Version.new(server_version))
|
90
|
+
end
|
91
|
+
|
92
|
+
def __parse_versions(versions)
|
93
|
+
versions = versions.split('-') if versions.is_a? String
|
94
|
+
|
95
|
+
low = (['', nil].include? versions[0]) ? '0' : versions[0]
|
96
|
+
high = (['', nil].include? versions[2]) ? '9999' : versions[2]
|
97
|
+
[Gem::Version.new(low), Gem::Version.new(high)]
|
98
|
+
end
|
99
|
+
|
100
|
+
# Get a list of tests in the test file.
|
101
|
+
#
|
102
|
+
# @example Get the list of tests
|
103
|
+
# test_file.tests
|
104
|
+
#
|
105
|
+
# @return [ Array<Test> ] A list of Test objects.
|
106
|
+
#
|
107
|
+
# @since 6.2.0
|
108
|
+
def tests
|
109
|
+
@test_definitions.collect do |test_definition|
|
110
|
+
Test.new(self, test_definition)
|
111
|
+
end
|
112
|
+
end
|
113
|
+
|
114
|
+
# Run the setup tasks defined for a single test file.
|
115
|
+
#
|
116
|
+
# @example Run the setup tasks.
|
117
|
+
# test_file.setup
|
118
|
+
#
|
119
|
+
# @param [ Elasticsearch::Client ] client The client to use to perform the setup tasks.
|
120
|
+
#
|
121
|
+
# @return [ self ]
|
122
|
+
#
|
123
|
+
# @since 6.2.0
|
124
|
+
def setup
|
125
|
+
return unless @setup
|
126
|
+
|
127
|
+
actions = @setup['setup'].select { |action| action['do'] }.map { |action| Action.new(action['do']) }
|
128
|
+
run_actions_and_retry(actions)
|
129
|
+
self
|
130
|
+
end
|
131
|
+
|
132
|
+
# Run the teardown tasks defined for a single test file.
|
133
|
+
#
|
134
|
+
# @example Run the teardown tasks.
|
135
|
+
# test_file.teardown
|
136
|
+
#
|
137
|
+
# @param [ Elasticsearch::Client ] client The client to use to perform the teardown tasks.
|
138
|
+
#
|
139
|
+
# @return [ self ]
|
140
|
+
#
|
141
|
+
# @since 6.2.0
|
142
|
+
def teardown
|
143
|
+
return unless @teardown
|
144
|
+
|
145
|
+
actions = @teardown['teardown'].select { |action| action['do'] }.map { |action| Action.new(action['do']) }
|
146
|
+
run_actions_and_retry(actions)
|
147
|
+
self
|
148
|
+
end
|
149
|
+
|
150
|
+
# Helper function to run actions. If the server returns an error, give it some time and retry
|
151
|
+
# for a few times.
|
152
|
+
def run_actions_and_retry(actions)
|
153
|
+
count = 0
|
154
|
+
loop do
|
155
|
+
actions.delete_if do |action|
|
156
|
+
begin
|
157
|
+
action.execute(client)
|
158
|
+
true
|
159
|
+
rescue Elastic::Transport::Transport::Errors::RequestTimeout,
|
160
|
+
Elastic::Transport::Transport::Errors::ServiceUnavailable => e
|
161
|
+
# The action sometimes gets the cluster in a recovering state, so we
|
162
|
+
# retry a few times and then raise an exception if it's still
|
163
|
+
# happening
|
164
|
+
count += 1
|
165
|
+
sleep 10
|
166
|
+
logger.debug(
|
167
|
+
"The server responded with an #{e.class} error. Retrying action - (#{count})"
|
168
|
+
)
|
169
|
+
raise e if count > 11
|
170
|
+
|
171
|
+
false
|
172
|
+
end
|
173
|
+
end
|
174
|
+
break if actions.empty?
|
175
|
+
end
|
176
|
+
end
|
177
|
+
end
|
178
|
+
end
|
179
|
+
end
|
@@ -0,0 +1,424 @@
|
|
1
|
+
# Licensed to Elasticsearch B.V. under one or more contributor
|
2
|
+
# license agreements. See the NOTICE file distributed with
|
3
|
+
# this work for additional information regarding copyright
|
4
|
+
# ownership. Elasticsearch B.V. licenses this file to you under
|
5
|
+
# the Apache License, Version 2.0 (the "License"); you may
|
6
|
+
# not use this file except in compliance with the License.
|
7
|
+
# You may obtain a copy of the License at
|
8
|
+
#
|
9
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
10
|
+
#
|
11
|
+
# Unless required by applicable law or agreed to in writing,
|
12
|
+
# software distributed under the License is distributed on an
|
13
|
+
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
14
|
+
# KIND, either express or implied. See the License for the
|
15
|
+
# specific language governing permissions and limitations
|
16
|
+
# under the License.
|
17
|
+
|
18
|
+
require_relative 'logging'
|
19
|
+
require_relative 'custom_cleanup'
|
20
|
+
include Elasticsearch::RestAPIYAMLTests::Logging
|
21
|
+
|
22
|
+
module Elasticsearch
|
23
|
+
module RestAPIYAMLTests
|
24
|
+
module WipeCluster
|
25
|
+
PRESERVE_ILM_POLICY_IDS = [
|
26
|
+
'ilm-history-ilm-policy', 'slm-history-ilm-policy', 'watch-history-ilm-policy',
|
27
|
+
'ml-size-based-ilm-policy', 'logs', 'metrics', 'synthetics', '7-days-default',
|
28
|
+
'30-days-default', '90-days-default', '180-days-default', '365-days-default',
|
29
|
+
'.fleet-actions-results-ilm-policy', '.deprecation-indexing-ilm-policy',
|
30
|
+
'watch-history-ilm-policy-16', '.monitoring-8-ilm-policy'
|
31
|
+
].freeze
|
32
|
+
|
33
|
+
PLATINUM_TEMPLATES = [
|
34
|
+
'.watches', 'logstash-index-template', '.logstash-management',
|
35
|
+
'security_audit_log', '.slm-history', '.async-search',
|
36
|
+
'saml-service-provider', 'ilm-history', 'logs', 'logs-settings',
|
37
|
+
'logs-mappings', 'metrics', 'metrics-settings', 'metrics-mappings',
|
38
|
+
'synthetics', 'synthetics-settings', 'synthetics-mappings',
|
39
|
+
'.snapshot-blob-cache', '.deprecation-indexing-template',
|
40
|
+
'.deprecation-indexing-mappings', '.deprecation-indexing-settings',
|
41
|
+
'security-index-template', 'data-streams-mappings'
|
42
|
+
].freeze
|
43
|
+
|
44
|
+
# Wipe Cluster, based on PHP's implementation of ESRestTestCase.java:wipeCluster()
|
45
|
+
# https://github.com/elastic/elasticsearch-php/blob/7.10/tests/Elasticsearch/Tests/Utility.php#L97
|
46
|
+
def self.run(client)
|
47
|
+
ensure_no_initializing_shards(client)
|
48
|
+
wipe_cluster(client)
|
49
|
+
wait_for_cluster_tasks(client)
|
50
|
+
check_for_unexpectedly_recreated_objects(client)
|
51
|
+
end
|
52
|
+
|
53
|
+
def self.create_xpack_rest_user(client)
|
54
|
+
client.security.put_user(
|
55
|
+
username: 'x_pack_rest_user',
|
56
|
+
body: { password: 'x-pack-test-password', roles: ['superuser'] }
|
57
|
+
)
|
58
|
+
end
|
59
|
+
|
60
|
+
class << self
|
61
|
+
private
|
62
|
+
|
63
|
+
def wipe_cluster(client)
|
64
|
+
read_plugins(client)
|
65
|
+
if @has_rollups
|
66
|
+
wipe_rollup_jobs(client)
|
67
|
+
wait_for_pending_rollup_tasks(client)
|
68
|
+
end
|
69
|
+
delete_all_slm_policies(client)
|
70
|
+
wipe_searchable_snapshot_indices(client) if @has_xpack
|
71
|
+
wipe_snapshots(client)
|
72
|
+
wipe_datastreams(client)
|
73
|
+
wipe_all_indices(client)
|
74
|
+
if platinum?
|
75
|
+
wipe_templates_for_xpack(client)
|
76
|
+
else
|
77
|
+
wipe_all_templates(client)
|
78
|
+
end
|
79
|
+
wipe_cluster_settings(client)
|
80
|
+
if platinum?
|
81
|
+
clear_ml_jobs(client)
|
82
|
+
clear_datafeeds(client)
|
83
|
+
delete_data_frame_analytics(client)
|
84
|
+
clear_ml_filters(client)
|
85
|
+
delete_trained_models(client)
|
86
|
+
end
|
87
|
+
delete_all_ilm_policies(client) if @has_ilm
|
88
|
+
delete_all_follow_patterns(client) if @has_ccr
|
89
|
+
delete_all_node_shutdown_metadata(client)
|
90
|
+
# clear_tasks(client)
|
91
|
+
# clear_transforms(client)
|
92
|
+
|
93
|
+
# Custom implementations
|
94
|
+
CustomCleanup::wipe_calendars(client)
|
95
|
+
end
|
96
|
+
|
97
|
+
def ensure_no_initializing_shards(client)
|
98
|
+
client.cluster.health(wait_for_no_initializing_shards: true, timeout: '70s', level: 'shards')
|
99
|
+
end
|
100
|
+
|
101
|
+
def check_for_unexpectedly_recreated_objects(client)
|
102
|
+
unexpected_ilm_policies = client.index_lifecycle_management.get_lifecycle
|
103
|
+
unexpected_ilm_policies.reject! { |k, _| PRESERVE_ILM_POLICY_IDS.include? k }
|
104
|
+
unless unexpected_ilm_policies.empty?
|
105
|
+
logger.info(
|
106
|
+
"Expected no ILM policies after deletions, but found #{unexpected_ilm_policies.keys.join(',')}"
|
107
|
+
)
|
108
|
+
end
|
109
|
+
return unless platinum?
|
110
|
+
|
111
|
+
templates = client.indices.get_index_template
|
112
|
+
unexpected_templates = templates['index_templates'].reject do |t|
|
113
|
+
# reject platinum templates
|
114
|
+
PLATINUM_TEMPLATES.include? t['name']
|
115
|
+
end.map { |t| t['name'] } # only keep the names
|
116
|
+
legacy_templates = client.indices.get_template
|
117
|
+
unexpected_templates << legacy_templates.keys.reject { |t| PLATINUM_TEMPLATES.include? t }
|
118
|
+
|
119
|
+
unless unexpected_templates.empty?
|
120
|
+
logger.info(
|
121
|
+
"Expected no templates after deletions, but found #{unexpected_templates.join(',')}"
|
122
|
+
)
|
123
|
+
end
|
124
|
+
end
|
125
|
+
|
126
|
+
def platinum?
|
127
|
+
ENV['TEST_SUITE'] == 'platinum'
|
128
|
+
end
|
129
|
+
|
130
|
+
def read_plugins(client)
|
131
|
+
response = client.perform_request('GET', '_nodes/plugins').body
|
132
|
+
|
133
|
+
response['nodes'].each do |node|
|
134
|
+
node[1]['modules'].each do |mod|
|
135
|
+
@has_xpack = true if mod['name'].include?('x-pack')
|
136
|
+
@has_ilm = true if mod['name'].include?('x-pack-ilm')
|
137
|
+
@has_rollups = true if mod['name'].include?('x-pack-rollup')
|
138
|
+
@has_ccr = true if mod['name'].include?('x-pack-ccr')
|
139
|
+
@has_shutdown = true if mod['name'].include?('x-pack-shutdown')
|
140
|
+
end
|
141
|
+
end
|
142
|
+
end
|
143
|
+
|
144
|
+
def wipe_rollup_jobs(client)
|
145
|
+
client.rollup.get_jobs(id: '_all')['jobs'].each do |d|
|
146
|
+
client.rollup.stop_job(id: d['config']['id'], wait_for_completion: true, timeout: '10s', ignore: 404)
|
147
|
+
client.rollup.delete_job(id: d['config']['id'], ignore: 404)
|
148
|
+
end
|
149
|
+
end
|
150
|
+
|
151
|
+
def wait_for_pending_rollup_tasks(client)
|
152
|
+
filter = 'xpack/rollup/job'
|
153
|
+
loop do
|
154
|
+
results = client.cat.tasks(detailed: true).split("\n")
|
155
|
+
count = 0
|
156
|
+
|
157
|
+
time = Time.now.to_i
|
158
|
+
results.each do |task|
|
159
|
+
next if task.empty? || skippable_task?(task)
|
160
|
+
|
161
|
+
logger.debug("Pending task: #{task}")
|
162
|
+
count += 1 if task.include?(filter)
|
163
|
+
end
|
164
|
+
break unless count.positive? && Time.now.to_i < (time + 30)
|
165
|
+
end
|
166
|
+
end
|
167
|
+
|
168
|
+
def delete_all_slm_policies(client)
|
169
|
+
policies = client.snapshot_lifecycle_management.get_lifecycle
|
170
|
+
|
171
|
+
policies.each do |name, _|
|
172
|
+
client.snapshot_lifecycle_management.delete_lifecycle(policy_id: name)
|
173
|
+
end
|
174
|
+
end
|
175
|
+
|
176
|
+
def wipe_searchable_snapshot_indices(client)
|
177
|
+
indices = client.cluster.state(metric: 'metadata', filter_path: 'metadata.indices.*.settings.index.store.snapshot')
|
178
|
+
return unless indices.dig('metadata', 'indices')
|
179
|
+
|
180
|
+
indices['metadata']['indices'].each do |index|
|
181
|
+
index_name = if index.is_a?(Array)
|
182
|
+
index[0]
|
183
|
+
elsif index.is_a?(Hash)
|
184
|
+
index.keys.first
|
185
|
+
end
|
186
|
+
client.indices.delete(index: index_name, ignore: 404)
|
187
|
+
end
|
188
|
+
end
|
189
|
+
|
190
|
+
def wipe_snapshots(client)
|
191
|
+
# Repeatedly delete the snapshots until there aren't any
|
192
|
+
loop do
|
193
|
+
repositories = client.snapshot.get_repository(repository: '_all')
|
194
|
+
break if repositories.empty?
|
195
|
+
|
196
|
+
repositories.each_key do |repository|
|
197
|
+
if ['fs', 'source'].include? repositories[repository]['type']
|
198
|
+
response = client.snapshot.get(repository: repository, snapshot: '_all', ignore_unavailable: true)
|
199
|
+
response['snapshots'].each do |snapshot|
|
200
|
+
if snapshot['state'] != 'SUCCESS'
|
201
|
+
logger.debug("Found snapshot that did not succeed #{snapshot}")
|
202
|
+
end
|
203
|
+
client.snapshot.delete(repository: repository, snapshot: snapshot['snapshot'], ignore: 404)
|
204
|
+
end
|
205
|
+
end
|
206
|
+
client.snapshot.delete_repository(repository: repository, ignore: 404)
|
207
|
+
end
|
208
|
+
end
|
209
|
+
end
|
210
|
+
|
211
|
+
def wipe_datastreams(client)
|
212
|
+
begin
|
213
|
+
client.indices.delete_data_stream(name: '*', expand_wildcards: 'all')
|
214
|
+
rescue StandardError => e
|
215
|
+
logger.error "Caught exception attempting to delete data streams: #{e}"
|
216
|
+
client.indices.delete_data_stream(name: '*')
|
217
|
+
end
|
218
|
+
end
|
219
|
+
|
220
|
+
def wipe_all_indices(client)
|
221
|
+
client.indices.delete(index: '*,-.ds-ilm-history-*', expand_wildcards: 'open,closed,hidden', ignore: 404)
|
222
|
+
end
|
223
|
+
|
224
|
+
def wipe_templates_for_xpack(client)
|
225
|
+
templates = client.indices.get_index_template
|
226
|
+
|
227
|
+
templates['index_templates'].each do |template|
|
228
|
+
next if platinum_template? template['name']
|
229
|
+
|
230
|
+
begin
|
231
|
+
client.indices.delete_index_template(name: template['name'], ignore: 404)
|
232
|
+
end
|
233
|
+
end
|
234
|
+
# Delete component template
|
235
|
+
result = client.cluster.get_component_template
|
236
|
+
|
237
|
+
result['component_templates'].each do |template|
|
238
|
+
next if platinum_template? template['name']
|
239
|
+
|
240
|
+
client.cluster.delete_component_template(name: template['name'], ignore: 404)
|
241
|
+
end
|
242
|
+
|
243
|
+
# Always check for legacy templates
|
244
|
+
templates = client.indices.get_template
|
245
|
+
templates.each do |name, _|
|
246
|
+
next if platinum_template? name
|
247
|
+
|
248
|
+
begin
|
249
|
+
client.indices.delete_template(name: name)
|
250
|
+
rescue StandardError => e
|
251
|
+
logger.info("Unable to remove index template #{name}")
|
252
|
+
end
|
253
|
+
end
|
254
|
+
end
|
255
|
+
|
256
|
+
def wipe_all_templates(client)
|
257
|
+
client.indices.delete_template(name: '*')
|
258
|
+
begin
|
259
|
+
client.indices.delete_index_template(name: '*')
|
260
|
+
client.cluster.delete_component_template(name: '*')
|
261
|
+
rescue StandardError => e
|
262
|
+
logger.info('Using a version of ES that doesn\'t support index templates v2 yet, so it\'s safe to ignore')
|
263
|
+
end
|
264
|
+
end
|
265
|
+
|
266
|
+
def platinum_template?(template)
|
267
|
+
platinum_prefixes = ['.monitoring', '.watch', '.triggered-watches', '.data-frame', '.ml-', '.transform', 'deprecation', 'data-streams-mappings'].freeze
|
268
|
+
platinum_prefixes.map { |a| return true if a.include? template }
|
269
|
+
|
270
|
+
PLATINUM_TEMPLATES.include? template
|
271
|
+
end
|
272
|
+
|
273
|
+
def wait_for_cluster_tasks(client)
|
274
|
+
time = Time.now.to_i
|
275
|
+
count = 0
|
276
|
+
|
277
|
+
loop do
|
278
|
+
results = client.cluster.pending_tasks
|
279
|
+
results['tasks'].each do |task|
|
280
|
+
|
281
|
+
next if task.empty? || skippable_task?(task)
|
282
|
+
|
283
|
+
logger.debug "Pending cluster task: #{task}"
|
284
|
+
count += 1
|
285
|
+
end
|
286
|
+
break unless count.positive? && Time.now.to_i < (time + 30)
|
287
|
+
end
|
288
|
+
end
|
289
|
+
|
290
|
+
def skippable_task?(task)
|
291
|
+
names = ['health-node', 'cluster:monitor/tasks/lists', 'create-index-template-v2',
|
292
|
+
'remove-component-template']
|
293
|
+
if task.is_a?(String)
|
294
|
+
names.select { |n| task.match? n }.any?
|
295
|
+
elsif task.is_a?(Hash)
|
296
|
+
names.select { |n| task['source'].match? n }.any?
|
297
|
+
end
|
298
|
+
end
|
299
|
+
|
300
|
+
def delete_all_ilm_policies(client)
|
301
|
+
policies = client.ilm.get_lifecycle
|
302
|
+
policies.each do |policy|
|
303
|
+
client.ilm.delete_lifecycle(policy: policy[0]) unless PRESERVE_ILM_POLICY_IDS.include? policy[0]
|
304
|
+
end
|
305
|
+
end
|
306
|
+
|
307
|
+
def wipe_cluster_settings(client)
|
308
|
+
settings = client.cluster.get_settings
|
309
|
+
new_settings = []
|
310
|
+
settings.each do |name, value|
|
311
|
+
next unless !value.empty? && value.is_a?(Array)
|
312
|
+
|
313
|
+
new_settings[name] = [] if new_settings[name].empty?
|
314
|
+
value.each do |key, _v|
|
315
|
+
new_settings[name]["#{key}.*"] = nil
|
316
|
+
end
|
317
|
+
end
|
318
|
+
client.cluster.put_settings(body: new_settings) unless new_settings.empty?
|
319
|
+
end
|
320
|
+
|
321
|
+
def delete_all_follow_patterns(client)
|
322
|
+
patterns = client.cross_cluster_replication.get_auto_follow_pattern
|
323
|
+
|
324
|
+
patterns['patterns'].each do |pattern|
|
325
|
+
client.cross_cluster_replication.delete_auto_follow_pattern(name: pattern)
|
326
|
+
end
|
327
|
+
end
|
328
|
+
|
329
|
+
def clear_roles(client)
|
330
|
+
client.security.get_role.each do |role, _|
|
331
|
+
begin; client.security.delete_role(name: role); rescue; end
|
332
|
+
end
|
333
|
+
end
|
334
|
+
|
335
|
+
def clear_users(client)
|
336
|
+
client.security.get_user.each do |user, _|
|
337
|
+
begin; client.security.delete_user(username: user); rescue; end
|
338
|
+
end
|
339
|
+
end
|
340
|
+
|
341
|
+
def clear_privileges(client)
|
342
|
+
client.security.get_privileges.each do |privilege, _|
|
343
|
+
begin; client.security.delete_privileges(name: privilege); rescue; end
|
344
|
+
end
|
345
|
+
end
|
346
|
+
|
347
|
+
def clear_ml_jobs(client)
|
348
|
+
client.ml.close_job(job_id: '_all', force: true)
|
349
|
+
client.ml.get_jobs['jobs'].each do |d|
|
350
|
+
client.ml.delete_job(job_id: d['job_id'])
|
351
|
+
end
|
352
|
+
end
|
353
|
+
|
354
|
+
def clear_datafeeds(client)
|
355
|
+
client.ml.stop_datafeed(datafeed_id: '_all', force: true)
|
356
|
+
client.ml.get_datafeeds['datafeeds'].each do |d|
|
357
|
+
client.ml.delete_datafeed(datafeed_id: d['datafeed_id'])
|
358
|
+
end
|
359
|
+
end
|
360
|
+
|
361
|
+
def clear_tasks(client)
|
362
|
+
tasks = client.tasks.get['nodes'].values.first['tasks'].values.select do |d|
|
363
|
+
d['cancellable']
|
364
|
+
end.map do |d|
|
365
|
+
"#{d['node']}:#{d['id']}"
|
366
|
+
end
|
367
|
+
tasks.each { |t| client.tasks.cancel task_id: t }
|
368
|
+
end
|
369
|
+
|
370
|
+
def clear_machine_learning_indices(client)
|
371
|
+
client.indices.delete(index: '.ml-*', ignore: 404)
|
372
|
+
end
|
373
|
+
|
374
|
+
def clear_index_templates(client)
|
375
|
+
client.indices.delete_template(name: '*')
|
376
|
+
templates = client.indices.get_index_template
|
377
|
+
templates['index_templates'].each do |template|
|
378
|
+
client.indices.delete_index_template(name: template['name'])
|
379
|
+
end
|
380
|
+
end
|
381
|
+
|
382
|
+
def clear_transforms(client)
|
383
|
+
client.transform.get_transform(transform_id: '*')['transforms'].each do |transform|
|
384
|
+
client.transform.delete_transform(transform_id: transform[:id])
|
385
|
+
end
|
386
|
+
end
|
387
|
+
|
388
|
+
def clear_ml_filters(client)
|
389
|
+
filters = client.ml.get_filters['filters']
|
390
|
+
filters.each do |filter|
|
391
|
+
client.ml.delete_filter(filter_id: filter['filter_id'])
|
392
|
+
end
|
393
|
+
end
|
394
|
+
|
395
|
+
def delete_all_node_shutdown_metadata(client)
|
396
|
+
nodes = client.shutdown.get_node
|
397
|
+
return unless nodes['nodes']
|
398
|
+
|
399
|
+
nodes['nodes'].each do |node|
|
400
|
+
client.shutdown.delete_node(node['node_id'])
|
401
|
+
end
|
402
|
+
end
|
403
|
+
|
404
|
+
def delete_data_frame_analytics(client)
|
405
|
+
dfs = client.ml.get_data_frame_analytics
|
406
|
+
return unless dfs['data_frame_analytics']
|
407
|
+
|
408
|
+
dfs['data_frame_analytics'].each do |df|
|
409
|
+
client.ml.delete_data_frame_analytics(id: df['id'], force: true)
|
410
|
+
end
|
411
|
+
end
|
412
|
+
|
413
|
+
def delete_trained_models(client)
|
414
|
+
models = client.ml.get_trained_models
|
415
|
+
return unless models['trained_model_configs']
|
416
|
+
|
417
|
+
models['trained_model_configs'].each do |model|
|
418
|
+
client.ml.delete_trained_model(model_id: model['model_id'], force: true, ignore: 400)
|
419
|
+
end
|
420
|
+
end
|
421
|
+
end
|
422
|
+
end
|
423
|
+
end
|
424
|
+
end
|
data/elasticsearch-api.gemspec
CHANGED
@@ -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/
|
29
|
+
s.homepage = 'https://www.elastic.co/guide/en/elasticsearch/client/ruby-api/current/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/
|
33
|
-
'changelog_uri' => 'https://github.com/elastic/elasticsearch-ruby/blob/
|
34
|
-
'source_code_uri' => 'https://github.com/elastic/elasticsearch-ruby/tree/
|
32
|
+
'homepage_uri' => 'https://www.elastic.co/guide/en/elasticsearch/client/ruby-api/current/index.html',
|
33
|
+
'changelog_uri' => 'https://github.com/elastic/elasticsearch-ruby/blob/main/CHANGELOG.md',
|
34
|
+
'source_code_uri' => 'https://github.com/elastic/elasticsearch-ruby/tree/main/elasticsearch-api',
|
35
35
|
'bug_tracker_uri' => 'https://github.com/elastic/elasticsearch-ruby/issues'
|
36
36
|
}
|
37
37
|
s.files = `git ls-files`.split($/)
|
@@ -39,38 +39,43 @@ Gem::Specification.new do |s|
|
|
39
39
|
s.test_files = s.files.grep(%r{^(test|spec|features)/})
|
40
40
|
s.require_paths = ['lib']
|
41
41
|
|
42
|
-
s.extra_rdoc_files = [
|
43
|
-
s.rdoc_options = [
|
42
|
+
s.extra_rdoc_files = ['README.md', 'LICENSE.txt']
|
43
|
+
s.rdoc_options = ['--charset=UTF-8']
|
44
44
|
|
45
|
-
s.required_ruby_version = '>= 2.
|
45
|
+
s.required_ruby_version = '>= 2.5'
|
46
46
|
|
47
47
|
s.add_dependency 'multi_json'
|
48
48
|
|
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
|
-
s.add_development_dependency 'elasticsearch-transport'
|
54
52
|
s.add_development_dependency 'minitest'
|
55
53
|
s.add_development_dependency 'minitest-reporters'
|
56
54
|
s.add_development_dependency 'mocha'
|
57
55
|
s.add_development_dependency 'pry'
|
58
|
-
s.add_development_dependency 'rake'
|
56
|
+
s.add_development_dependency 'rake'
|
59
57
|
s.add_development_dependency 'shoulda-context'
|
60
58
|
s.add_development_dependency 'yard'
|
61
59
|
|
62
60
|
# Gems for testing integrations
|
63
61
|
s.add_development_dependency 'jsonify'
|
64
62
|
s.add_development_dependency 'hashie'
|
63
|
+
# Temporary support for Ruby 2.6, since it's EOL March 2022:
|
64
|
+
if RUBY_VERSION < '2.7.0'
|
65
|
+
s.add_development_dependency 'jbuilder', '< 7.0.0'
|
66
|
+
else
|
67
|
+
s.add_development_dependency 'activesupport'
|
68
|
+
s.add_development_dependency 'jbuilder'
|
69
|
+
end
|
65
70
|
|
66
71
|
s.add_development_dependency 'cane'
|
67
72
|
s.add_development_dependency 'escape_utils' unless defined? JRUBY_VERSION
|
68
|
-
|
73
|
+
|
69
74
|
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'
|
72
|
-
s.add_development_dependency 'test-unit', '~> 2'
|
73
75
|
s.add_development_dependency 'ruby-prof' unless defined?(JRUBY_VERSION) || defined?(Rubinius)
|
76
|
+
s.add_development_dependency 'simplecov'
|
77
|
+
|
78
|
+
s.add_development_dependency 'test-unit', '~> 2'
|
74
79
|
|
75
80
|
s.description = <<-DESC.gsub(/^ /, '')
|
76
81
|
Ruby API for Elasticsearch. See the `elasticsearch` gem for full integration.
|