elasticsearch-api 7.2.0 → 8.0.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/Gemfile +8 -12
- data/README.md +30 -43
- data/Rakefile +35 -107
- data/api-spec-testing/README.md +118 -0
- data/api-spec-testing/logging.rb +28 -0
- data/api-spec-testing/rspec_matchers.rb +312 -0
- data/api-spec-testing/test_file/action.rb +179 -0
- data/api-spec-testing/test_file/task_group.rb +340 -0
- data/api-spec-testing/test_file/test.rb +295 -0
- data/api-spec-testing/test_file.rb +173 -0
- data/api-spec-testing/wipe_cluster.rb +389 -0
- data/elasticsearch-api.gemspec +42 -53
- data/lib/elasticsearch/api/actions/async_search/delete.rb +51 -0
- data/lib/elasticsearch/api/actions/async_search/get.rb +54 -0
- data/lib/elasticsearch/api/actions/async_search/status.rb +51 -0
- data/lib/elasticsearch/api/actions/async_search/submit.rb +95 -0
- data/lib/elasticsearch/api/actions/autoscaling/delete_autoscaling_policy.rb +51 -0
- data/lib/elasticsearch/api/actions/autoscaling/get_autoscaling_capacity.rb +46 -0
- data/lib/elasticsearch/api/actions/autoscaling/get_autoscaling_policy.rb +51 -0
- data/lib/elasticsearch/api/actions/autoscaling/put_autoscaling_policy.rb +53 -0
- data/lib/elasticsearch/api/actions/bulk.rb +28 -76
- data/lib/elasticsearch/api/actions/cat/aliases.rb +30 -58
- data/lib/elasticsearch/api/actions/cat/allocation.rb +30 -55
- data/lib/elasticsearch/api/actions/cat/count.rb +23 -50
- data/lib/elasticsearch/api/actions/cat/fielddata.rb +25 -38
- data/lib/elasticsearch/api/actions/cat/health.rb +21 -41
- data/lib/elasticsearch/api/actions/cat/help.rb +16 -15
- data/lib/elasticsearch/api/actions/cat/indices.rb +31 -67
- data/lib/elasticsearch/api/actions/cat/master.rb +21 -39
- data/lib/elasticsearch/api/actions/cat/ml_data_frame_analytics.rb +61 -0
- data/lib/elasticsearch/api/actions/cat/ml_datafeeds.rb +61 -0
- data/lib/elasticsearch/api/actions/cat/ml_jobs.rb +62 -0
- data/lib/elasticsearch/api/actions/cat/ml_trained_models.rb +63 -0
- data/lib/elasticsearch/api/actions/cat/nodeattrs.rb +18 -22
- data/lib/elasticsearch/api/actions/cat/nodes.rb +23 -50
- data/lib/elasticsearch/api/actions/cat/pending_tasks.rb +22 -39
- data/lib/elasticsearch/api/actions/cat/plugins.rb +20 -24
- data/lib/elasticsearch/api/actions/cat/recovery.rb +29 -61
- data/lib/elasticsearch/api/actions/cat/repositories.rb +19 -30
- data/lib/elasticsearch/api/actions/cat/segments.rb +25 -27
- data/lib/elasticsearch/api/actions/cat/shards.rb +28 -64
- data/lib/elasticsearch/api/actions/cat/snapshots.rb +27 -33
- data/lib/elasticsearch/api/actions/cat/tasks.rb +24 -27
- data/lib/elasticsearch/api/actions/cat/templates.rb +24 -24
- data/lib/elasticsearch/api/actions/cat/thread_pool.rb +31 -52
- data/lib/elasticsearch/api/actions/cat/transforms.rb +62 -0
- data/lib/elasticsearch/api/actions/clear_scroll.rb +27 -9
- data/lib/elasticsearch/api/actions/close_point_in_time.rb +45 -0
- data/lib/elasticsearch/api/actions/cluster/allocation_explain.rb +23 -19
- data/lib/elasticsearch/api/actions/cluster/delete_component_template.rb +53 -0
- data/lib/elasticsearch/api/actions/cluster/delete_voting_config_exclusions.rb +47 -0
- data/lib/elasticsearch/api/actions/cluster/exists_component_template.rb +55 -0
- data/lib/elasticsearch/api/actions/cluster/get_component_template.rb +55 -0
- data/lib/elasticsearch/api/actions/cluster/get_settings.rb +19 -24
- data/lib/elasticsearch/api/actions/cluster/health.rb +31 -52
- data/lib/elasticsearch/api/actions/cluster/pending_tasks.rb +17 -22
- data/lib/elasticsearch/api/actions/cluster/post_voting_config_exclusions.rb +49 -0
- data/lib/elasticsearch/api/actions/cluster/put_component_template.rb +56 -0
- data/lib/elasticsearch/api/actions/cluster/put_settings.rb +22 -23
- data/lib/elasticsearch/api/actions/cluster/remote_info.rb +14 -7
- data/lib/elasticsearch/api/actions/cluster/reroute.rb +22 -43
- data/lib/elasticsearch/api/actions/cluster/state.rb +31 -47
- data/lib/elasticsearch/api/actions/cluster/stats.rb +23 -18
- data/lib/elasticsearch/api/actions/count.rb +29 -45
- data/lib/elasticsearch/api/actions/create.rb +17 -28
- data/lib/elasticsearch/api/actions/cross_cluster_replication/delete_auto_follow_pattern.rb +51 -0
- data/lib/elasticsearch/api/actions/cross_cluster_replication/follow.rb +54 -0
- data/lib/elasticsearch/api/actions/cross_cluster_replication/follow_info.rb +51 -0
- data/lib/elasticsearch/api/actions/cross_cluster_replication/follow_stats.rb +51 -0
- data/lib/elasticsearch/api/actions/cross_cluster_replication/forget_follower.rb +53 -0
- data/lib/elasticsearch/api/actions/cross_cluster_replication/get_auto_follow_pattern.rb +53 -0
- data/lib/elasticsearch/api/actions/cross_cluster_replication/pause_auto_follow_pattern.rb +51 -0
- data/lib/elasticsearch/api/actions/cross_cluster_replication/pause_follow.rb +51 -0
- data/lib/elasticsearch/api/actions/cross_cluster_replication/put_auto_follow_pattern.rb +53 -0
- data/lib/elasticsearch/api/actions/cross_cluster_replication/resume_auto_follow_pattern.rb +51 -0
- data/lib/elasticsearch/api/actions/cross_cluster_replication/resume_follow.rb +52 -0
- data/lib/elasticsearch/api/actions/cross_cluster_replication/stats.rb +46 -0
- data/lib/elasticsearch/api/actions/cross_cluster_replication/unfollow.rb +51 -0
- data/lib/elasticsearch/api/actions/dangling_indices/delete_dangling_index.rb +54 -0
- data/lib/elasticsearch/api/actions/dangling_indices/import_dangling_index.rb +54 -0
- data/lib/elasticsearch/api/actions/dangling_indices/list_dangling_indices.rb +46 -0
- data/lib/elasticsearch/api/actions/data_frame_transform_deprecated/delete_transform.rb +59 -0
- data/lib/elasticsearch/api/actions/data_frame_transform_deprecated/get_transform.rb +64 -0
- data/lib/elasticsearch/api/actions/data_frame_transform_deprecated/get_transform_stats.rb +61 -0
- data/lib/elasticsearch/api/actions/data_frame_transform_deprecated/preview_transform.rb +56 -0
- data/lib/elasticsearch/api/actions/data_frame_transform_deprecated/put_transform.rb +61 -0
- data/lib/elasticsearch/api/actions/data_frame_transform_deprecated/start_transform.rb +59 -0
- data/lib/elasticsearch/api/actions/data_frame_transform_deprecated/stop_transform.rb +61 -0
- data/lib/elasticsearch/api/actions/data_frame_transform_deprecated/update_transform.rb +61 -0
- data/lib/elasticsearch/api/actions/delete.rb +30 -43
- data/lib/elasticsearch/api/actions/delete_by_query.rb +25 -69
- data/lib/elasticsearch/api/actions/{delete_by_rethrottle.rb → delete_by_query_rethrottle.rb} +20 -16
- data/lib/elasticsearch/api/actions/delete_script.rb +21 -18
- data/lib/elasticsearch/api/actions/enrich/delete_policy.rb +51 -0
- data/lib/elasticsearch/api/actions/enrich/execute_policy.rb +52 -0
- data/lib/elasticsearch/api/actions/enrich/get_policy.rb +53 -0
- data/lib/elasticsearch/api/actions/enrich/put_policy.rb +53 -0
- data/lib/elasticsearch/api/actions/enrich/stats.rb +46 -0
- data/lib/elasticsearch/api/actions/eql/delete.rb +51 -0
- data/lib/elasticsearch/api/actions/eql/get.rb +53 -0
- data/lib/elasticsearch/api/actions/eql/get_status.rb +51 -0
- data/lib/elasticsearch/api/actions/eql/search.rb +57 -0
- data/lib/elasticsearch/api/actions/exists.rb +24 -40
- data/lib/elasticsearch/api/actions/exists_source.rb +26 -30
- data/lib/elasticsearch/api/actions/explain.rb +28 -55
- data/lib/elasticsearch/api/actions/features/get_features.rb +47 -0
- data/lib/elasticsearch/api/actions/features/reset_features.rb +50 -0
- data/lib/elasticsearch/api/actions/field_caps.rb +31 -26
- data/lib/elasticsearch/api/actions/fleet/global_checkpoints.rb +55 -0
- data/lib/elasticsearch/api/actions/get.rb +28 -47
- data/lib/elasticsearch/api/actions/get_script.rb +22 -19
- data/lib/elasticsearch/api/actions/get_script_context.rb +44 -0
- data/lib/elasticsearch/api/actions/{abort_benchmark.rb → get_script_languages.rb} +16 -14
- data/lib/elasticsearch/api/actions/get_source.rb +21 -50
- data/lib/elasticsearch/api/actions/graph/explore.rb +59 -0
- data/lib/elasticsearch/api/actions/index.rb +40 -97
- data/lib/elasticsearch/api/actions/index_lifecycle_management/delete_lifecycle.rb +51 -0
- data/lib/elasticsearch/api/actions/index_lifecycle_management/explain_lifecycle.rb +53 -0
- data/lib/elasticsearch/api/actions/index_lifecycle_management/get_lifecycle.rb +53 -0
- data/lib/elasticsearch/api/actions/index_lifecycle_management/get_status.rb +46 -0
- data/lib/elasticsearch/api/actions/index_lifecycle_management/migrate_to_data_tiers.rb +48 -0
- data/lib/elasticsearch/api/actions/index_lifecycle_management/move_to_step.rb +52 -0
- data/lib/elasticsearch/api/actions/index_lifecycle_management/put_lifecycle.rb +52 -0
- data/lib/elasticsearch/api/actions/index_lifecycle_management/remove_policy.rb +51 -0
- data/lib/elasticsearch/api/actions/index_lifecycle_management/retry.rb +51 -0
- data/lib/elasticsearch/api/actions/index_lifecycle_management/start.rb +46 -0
- data/lib/elasticsearch/api/actions/index_lifecycle_management/stop.rb +46 -0
- data/lib/elasticsearch/api/actions/indices/add_block.rb +60 -0
- data/lib/elasticsearch/api/actions/indices/analyze.rb +27 -54
- data/lib/elasticsearch/api/actions/indices/clear_cache.rb +23 -47
- data/lib/elasticsearch/api/actions/indices/clone.rb +59 -0
- data/lib/elasticsearch/api/actions/indices/close.rb +25 -38
- data/lib/elasticsearch/api/actions/indices/create.rb +23 -77
- data/lib/elasticsearch/api/actions/indices/create_data_stream.rb +51 -0
- data/lib/elasticsearch/api/actions/indices/data_streams_stats.rb +53 -0
- data/lib/elasticsearch/api/actions/indices/delete.rb +27 -42
- data/lib/elasticsearch/api/actions/indices/delete_alias.rb +27 -26
- data/lib/elasticsearch/api/actions/indices/delete_data_stream.rb +52 -0
- data/lib/elasticsearch/api/actions/indices/delete_index_template.rb +53 -0
- data/lib/elasticsearch/api/actions/indices/delete_template.rb +25 -26
- data/lib/elasticsearch/api/actions/indices/disk_usage.rb +60 -0
- data/lib/elasticsearch/api/actions/indices/exists.rb +26 -39
- data/lib/elasticsearch/api/actions/indices/exists_alias.rb +29 -34
- data/lib/elasticsearch/api/actions/indices/exists_index_template.rb +56 -0
- data/lib/elasticsearch/api/actions/indices/exists_template.rb +19 -20
- data/lib/elasticsearch/api/actions/indices/exists_type.rb +25 -34
- data/lib/elasticsearch/api/actions/indices/field_usage_stats.rb +59 -0
- data/lib/elasticsearch/api/actions/indices/flush.rb +26 -33
- data/lib/elasticsearch/api/actions/indices/forcemerge.rb +22 -46
- data/lib/elasticsearch/api/actions/indices/get.rb +18 -24
- data/lib/elasticsearch/api/actions/indices/get_alias.rb +30 -29
- data/lib/elasticsearch/api/actions/indices/get_data_stream.rb +54 -0
- data/lib/elasticsearch/api/actions/indices/get_field_mapping.rb +27 -45
- data/lib/elasticsearch/api/actions/indices/get_index_template.rb +56 -0
- data/lib/elasticsearch/api/actions/indices/get_mapping.rb +24 -38
- data/lib/elasticsearch/api/actions/indices/get_settings.rb +30 -43
- data/lib/elasticsearch/api/actions/indices/get_template.rb +22 -30
- data/lib/elasticsearch/api/actions/indices/migrate_to_data_stream.rb +51 -0
- data/lib/elasticsearch/api/actions/indices/modify_data_stream.rb +49 -0
- data/lib/elasticsearch/api/actions/indices/open.rb +20 -26
- data/lib/elasticsearch/api/actions/indices/promote_data_stream.rb +51 -0
- data/lib/elasticsearch/api/actions/indices/put_alias.rb +28 -33
- data/lib/elasticsearch/api/actions/indices/put_index_template.rb +56 -0
- data/lib/elasticsearch/api/actions/indices/put_mapping.rb +24 -46
- data/lib/elasticsearch/api/actions/indices/put_settings.rb +26 -43
- data/lib/elasticsearch/api/actions/indices/put_template.rb +22 -32
- data/lib/elasticsearch/api/actions/indices/recovery.rb +22 -28
- data/lib/elasticsearch/api/actions/indices/refresh.rb +23 -32
- data/lib/elasticsearch/api/actions/indices/{flush_synced.rb → reload_search_analyzers.rb} +23 -23
- data/lib/elasticsearch/api/actions/indices/resolve_index.rb +52 -0
- data/lib/elasticsearch/api/actions/indices/rollover.rb +29 -27
- data/lib/elasticsearch/api/actions/indices/segments.rb +23 -23
- data/lib/elasticsearch/api/actions/indices/shard_stores.rb +24 -20
- data/lib/elasticsearch/api/actions/indices/shrink.rb +23 -23
- data/lib/elasticsearch/api/actions/indices/simulate_index_template.rb +55 -0
- data/lib/elasticsearch/api/actions/indices/simulate_template.rb +57 -0
- data/lib/elasticsearch/api/actions/indices/split.rb +22 -22
- data/lib/elasticsearch/api/actions/indices/stats.rb +39 -117
- data/lib/elasticsearch/api/actions/indices/unfreeze.rb +41 -18
- data/lib/elasticsearch/api/actions/indices/update_aliases.rb +18 -38
- data/lib/elasticsearch/api/actions/indices/validate_query.rb +29 -64
- data/lib/elasticsearch/api/actions/info.rb +16 -8
- data/lib/elasticsearch/api/actions/ingest/delete_pipeline.rb +21 -18
- data/lib/elasticsearch/api/actions/ingest/geo_ip_stats.rb +46 -0
- data/lib/elasticsearch/api/actions/ingest/get_pipeline.rb +25 -16
- data/lib/elasticsearch/api/actions/ingest/processor_grok.rb +30 -13
- data/lib/elasticsearch/api/actions/ingest/put_pipeline.rb +22 -20
- data/lib/elasticsearch/api/actions/ingest/simulate.rb +25 -17
- data/lib/elasticsearch/api/actions/knn_search.rb +60 -0
- data/lib/elasticsearch/api/actions/license/delete.rb +46 -0
- data/lib/elasticsearch/api/actions/license/get.rb +48 -0
- data/lib/elasticsearch/api/actions/license/get_basic_status.rb +46 -0
- data/lib/elasticsearch/api/actions/license/get_trial_status.rb +46 -0
- data/lib/elasticsearch/api/actions/license/post.rb +48 -0
- data/lib/elasticsearch/api/actions/license/post_start_basic.rb +47 -0
- data/lib/elasticsearch/api/actions/license/post_start_trial.rb +48 -0
- data/lib/elasticsearch/api/actions/logstash/delete_pipeline.rb +51 -0
- data/lib/elasticsearch/api/actions/logstash/get_pipeline.rb +51 -0
- data/lib/elasticsearch/api/actions/logstash/put_pipeline.rb +53 -0
- data/lib/elasticsearch/api/actions/machine_learning/close_job.rb +56 -0
- data/lib/elasticsearch/api/actions/machine_learning/delete_calendar.rb +51 -0
- data/lib/elasticsearch/api/actions/machine_learning/delete_calendar_event.rb +55 -0
- data/lib/elasticsearch/api/actions/machine_learning/delete_calendar_job.rb +55 -0
- data/lib/elasticsearch/api/actions/machine_learning/delete_data_frame_analytics.rb +53 -0
- data/lib/elasticsearch/api/actions/machine_learning/delete_datafeed.rb +52 -0
- data/lib/elasticsearch/api/actions/machine_learning/delete_expired_data.rb +56 -0
- data/lib/elasticsearch/api/actions/machine_learning/delete_filter.rb +51 -0
- data/lib/elasticsearch/api/actions/machine_learning/delete_forecast.rb +60 -0
- data/lib/elasticsearch/api/actions/machine_learning/delete_job.rb +53 -0
- data/lib/elasticsearch/api/actions/machine_learning/delete_model_snapshot.rb +55 -0
- data/lib/elasticsearch/api/actions/machine_learning/delete_trained_model.rb +51 -0
- data/lib/elasticsearch/api/actions/machine_learning/delete_trained_model_alias.rb +55 -0
- data/lib/elasticsearch/api/actions/machine_learning/estimate_model_memory.rb +49 -0
- data/lib/elasticsearch/api/actions/machine_learning/evaluate_data_frame.rb +49 -0
- data/lib/elasticsearch/api/actions/machine_learning/explain_data_frame_analytics.rb +59 -0
- data/lib/elasticsearch/api/actions/machine_learning/flush_job.rb +57 -0
- data/lib/elasticsearch/api/actions/machine_learning/forecast.rb +55 -0
- data/lib/elasticsearch/api/actions/machine_learning/get_buckets.rb +73 -0
- data/lib/elasticsearch/api/actions/machine_learning/get_calendar_events.rb +56 -0
- data/lib/elasticsearch/api/actions/machine_learning/get_calendars.rb +61 -0
- data/lib/elasticsearch/api/actions/machine_learning/get_categories.rb +67 -0
- data/lib/elasticsearch/api/actions/machine_learning/get_data_frame_analytics.rb +57 -0
- data/lib/elasticsearch/api/actions/machine_learning/get_data_frame_analytics_stats.rb +57 -0
- data/lib/elasticsearch/api/actions/machine_learning/get_datafeed_stats.rb +55 -0
- data/lib/elasticsearch/api/actions/machine_learning/get_datafeeds.rb +56 -0
- data/lib/elasticsearch/api/actions/machine_learning/get_filters.rb +55 -0
- data/lib/elasticsearch/api/actions/machine_learning/get_influencers.rb +65 -0
- data/lib/elasticsearch/api/actions/machine_learning/get_job_stats.rb +55 -0
- data/lib/elasticsearch/api/actions/machine_learning/get_jobs.rb +56 -0
- data/lib/elasticsearch/api/actions/machine_learning/get_model_snapshot_upgrade_stats.rb +56 -0
- data/lib/elasticsearch/api/actions/machine_learning/get_model_snapshots.rb +70 -0
- data/lib/elasticsearch/api/actions/machine_learning/get_overall_buckets.rb +65 -0
- data/lib/elasticsearch/api/actions/machine_learning/get_records.rb +65 -0
- data/lib/elasticsearch/api/actions/machine_learning/get_trained_model_deployment_stats.rb +51 -0
- data/lib/elasticsearch/api/actions/machine_learning/get_trained_models.rb +61 -0
- data/lib/elasticsearch/api/actions/machine_learning/get_trained_models_stats.rb +56 -0
- data/lib/elasticsearch/api/actions/machine_learning/infer_trained_model_deployment.rb +58 -0
- data/lib/elasticsearch/api/actions/machine_learning/info.rb +46 -0
- data/lib/elasticsearch/api/actions/machine_learning/open_job.rb +52 -0
- data/lib/elasticsearch/api/actions/machine_learning/post_calendar_events.rb +53 -0
- data/lib/elasticsearch/api/actions/machine_learning/post_data.rb +55 -0
- data/lib/elasticsearch/api/actions/machine_learning/preview_data_frame_analytics.rb +59 -0
- data/lib/elasticsearch/api/actions/machine_learning/preview_datafeed.rb +59 -0
- data/lib/elasticsearch/api/actions/machine_learning/put_calendar.rb +52 -0
- data/lib/elasticsearch/api/actions/machine_learning/put_calendar_job.rb +55 -0
- data/lib/elasticsearch/api/actions/machine_learning/put_data_frame_analytics.rb +53 -0
- data/lib/elasticsearch/api/actions/machine_learning/put_datafeed.rb +57 -0
- data/lib/elasticsearch/api/actions/machine_learning/put_filter.rb +53 -0
- data/lib/elasticsearch/api/actions/machine_learning/put_job.rb +57 -0
- data/lib/elasticsearch/api/actions/machine_learning/put_trained_model.rb +54 -0
- data/lib/elasticsearch/api/actions/machine_learning/put_trained_model_alias.rb +56 -0
- data/lib/elasticsearch/api/actions/machine_learning/put_trained_model_definition_part.rb +61 -0
- data/lib/elasticsearch/api/actions/machine_learning/put_trained_model_vocabulary.rb +57 -0
- data/lib/elasticsearch/api/actions/machine_learning/reset_job.rb +52 -0
- data/lib/elasticsearch/api/actions/machine_learning/revert_model_snapshot.rb +57 -0
- data/lib/elasticsearch/api/actions/machine_learning/set_upgrade_mode.rb +48 -0
- data/lib/elasticsearch/api/actions/machine_learning/start_data_frame_analytics.rb +53 -0
- data/lib/elasticsearch/api/actions/machine_learning/start_datafeed.rb +55 -0
- data/lib/elasticsearch/api/actions/machine_learning/start_trained_model_deployment.rb +57 -0
- data/lib/elasticsearch/api/actions/machine_learning/stop_data_frame_analytics.rb +55 -0
- data/lib/elasticsearch/api/actions/machine_learning/stop_datafeed.rb +56 -0
- data/lib/elasticsearch/api/actions/machine_learning/stop_trained_model_deployment.rb +55 -0
- data/lib/elasticsearch/api/actions/machine_learning/update_data_frame_analytics.rb +53 -0
- data/lib/elasticsearch/api/actions/machine_learning/update_datafeed.rb +57 -0
- data/lib/elasticsearch/api/actions/machine_learning/update_filter.rb +53 -0
- data/lib/elasticsearch/api/actions/machine_learning/update_job.rb +53 -0
- data/lib/elasticsearch/api/actions/machine_learning/update_model_snapshot.rb +57 -0
- data/lib/elasticsearch/api/actions/machine_learning/upgrade_job_snapshot.rb +57 -0
- data/lib/elasticsearch/api/actions/machine_learning/validate.rb +49 -0
- data/lib/elasticsearch/api/actions/machine_learning/validate_detector.rb +49 -0
- data/lib/elasticsearch/api/actions/mget.rb +23 -49
- data/lib/elasticsearch/api/actions/migration/deprecations.rb +53 -0
- data/lib/elasticsearch/api/actions/migration/get_feature_upgrade_status.rb +46 -0
- data/lib/elasticsearch/api/actions/migration/post_feature_upgrade.rb +46 -0
- data/lib/elasticsearch/api/actions/monitoring/bulk.rb +72 -0
- data/lib/elasticsearch/api/actions/msearch.rb +37 -58
- data/lib/elasticsearch/api/actions/msearch_template.rb +34 -38
- data/lib/elasticsearch/api/actions/mtermvectors.rb +30 -46
- data/lib/elasticsearch/api/actions/nodes/clear_repositories_metering_archive.rb +61 -0
- data/lib/elasticsearch/api/actions/nodes/get_repositories_metering_info.rb +55 -0
- data/lib/elasticsearch/api/actions/nodes/hot_threads.rb +21 -30
- data/lib/elasticsearch/api/actions/nodes/info.rb +28 -67
- data/lib/elasticsearch/api/actions/nodes/reload_secure_settings.rb +24 -23
- data/lib/elasticsearch/api/actions/nodes/stats.rb +33 -40
- data/lib/elasticsearch/api/actions/nodes/usage.rb +45 -15
- data/lib/elasticsearch/api/actions/open_point_in_time.rb +54 -0
- data/lib/elasticsearch/api/actions/ping.rb +14 -12
- data/lib/elasticsearch/api/actions/put_script.rb +27 -36
- data/lib/elasticsearch/api/actions/rank_eval.rb +27 -22
- data/lib/elasticsearch/api/actions/reindex.rb +23 -55
- data/lib/elasticsearch/api/actions/reindex_rethrottle.rb +22 -18
- data/lib/elasticsearch/api/actions/render_search_template.rb +28 -16
- data/lib/elasticsearch/api/actions/rollup/delete_job.rb +55 -0
- data/lib/elasticsearch/api/actions/rollup/get_jobs.rb +57 -0
- data/lib/elasticsearch/api/actions/rollup/get_rollup_caps.rb +57 -0
- data/lib/elasticsearch/api/actions/rollup/get_rollup_index_caps.rb +55 -0
- data/lib/elasticsearch/api/actions/rollup/put_job.rb +57 -0
- data/lib/elasticsearch/api/actions/rollup/rollup.rb +61 -0
- data/lib/elasticsearch/api/actions/rollup/rollup_search.rb +59 -0
- data/lib/elasticsearch/api/actions/rollup/start_job.rb +55 -0
- data/lib/elasticsearch/api/actions/rollup/stop_job.rb +57 -0
- data/lib/elasticsearch/api/actions/scripts_painless_execute.rb +23 -7
- data/lib/elasticsearch/api/actions/scroll.rb +35 -58
- data/lib/elasticsearch/api/actions/search.rb +54 -170
- data/lib/elasticsearch/api/actions/search_mvt.rb +76 -0
- data/lib/elasticsearch/api/actions/search_shards.rb +28 -33
- data/lib/elasticsearch/api/actions/search_template.rb +27 -45
- data/lib/elasticsearch/api/actions/searchable_snapshots/cache_stats.rb +57 -0
- data/lib/elasticsearch/api/actions/{indices/upgrade.rb → searchable_snapshots/clear_cache.rb} +30 -26
- data/lib/elasticsearch/api/actions/searchable_snapshots/mount.rb +60 -0
- data/lib/elasticsearch/api/actions/searchable_snapshots/stats.rb +54 -0
- data/lib/elasticsearch/api/actions/security/authenticate.rb +46 -0
- data/lib/elasticsearch/api/actions/security/change_password.rb +57 -0
- data/lib/elasticsearch/api/actions/security/clear_api_key_cache.rb +51 -0
- data/lib/elasticsearch/api/actions/security/clear_cached_privileges.rb +51 -0
- data/lib/elasticsearch/api/actions/security/clear_cached_realms.rb +52 -0
- data/lib/elasticsearch/api/actions/security/clear_cached_roles.rb +51 -0
- data/lib/elasticsearch/api/actions/security/clear_cached_service_tokens.rb +59 -0
- data/lib/elasticsearch/api/actions/security/create_api_key.rb +50 -0
- data/lib/elasticsearch/api/actions/security/create_service_token.rb +63 -0
- data/lib/elasticsearch/api/actions/security/delete_privileges.rb +56 -0
- data/lib/elasticsearch/api/actions/security/delete_role.rb +52 -0
- data/lib/elasticsearch/api/actions/security/delete_role_mapping.rb +52 -0
- data/lib/elasticsearch/api/actions/security/delete_service_token.rb +60 -0
- data/lib/elasticsearch/api/actions/security/delete_user.rb +52 -0
- data/lib/elasticsearch/api/actions/security/disable_user.rb +52 -0
- data/lib/elasticsearch/api/actions/security/enable_user.rb +52 -0
- data/lib/elasticsearch/api/actions/security/enroll_kibana.rb +46 -0
- data/lib/elasticsearch/api/actions/security/enroll_node.rb +46 -0
- data/lib/elasticsearch/api/actions/security/get_api_key.rb +51 -0
- data/lib/elasticsearch/api/actions/security/get_builtin_privileges.rb +46 -0
- data/lib/elasticsearch/api/actions/security/get_privileges.rb +58 -0
- data/lib/elasticsearch/api/actions/security/get_role.rb +61 -0
- data/lib/elasticsearch/api/actions/security/get_role_mapping.rb +53 -0
- data/lib/elasticsearch/api/actions/security/get_service_accounts.rb +58 -0
- data/lib/elasticsearch/api/actions/security/get_service_credentials.rb +55 -0
- data/lib/elasticsearch/api/actions/security/get_token.rb +49 -0
- data/lib/elasticsearch/api/actions/security/get_user.rb +61 -0
- data/lib/elasticsearch/api/actions/security/get_user_privileges.rb +46 -0
- data/lib/elasticsearch/api/actions/security/grant_api_key.rb +50 -0
- data/lib/elasticsearch/api/actions/security/has_privileges.rb +56 -0
- data/lib/elasticsearch/api/actions/security/invalidate_api_key.rb +49 -0
- data/lib/elasticsearch/api/actions/security/invalidate_token.rb +49 -0
- data/lib/elasticsearch/api/actions/security/put_privileges.rb +50 -0
- data/lib/elasticsearch/api/actions/security/put_role.rb +54 -0
- data/lib/elasticsearch/api/actions/security/put_role_mapping.rb +54 -0
- data/lib/elasticsearch/api/actions/security/put_user.rb +54 -0
- data/lib/elasticsearch/api/actions/security/query_api_keys.rb +52 -0
- data/lib/elasticsearch/api/actions/security/saml_authenticate.rb +49 -0
- data/lib/elasticsearch/api/actions/security/saml_complete_logout.rb +49 -0
- data/lib/elasticsearch/api/actions/security/saml_invalidate.rb +49 -0
- data/lib/elasticsearch/api/actions/security/saml_logout.rb +49 -0
- data/lib/elasticsearch/api/actions/security/saml_prepare_authentication.rb +49 -0
- data/lib/elasticsearch/api/actions/security/saml_service_provider_metadata.rb +51 -0
- data/lib/elasticsearch/api/actions/shutdown/delete_node.rb +51 -0
- data/lib/elasticsearch/api/actions/shutdown/get_node.rb +53 -0
- data/lib/elasticsearch/api/actions/shutdown/put_node.rb +53 -0
- data/lib/elasticsearch/api/actions/snapshot/cleanup_repository.rb +53 -0
- data/lib/elasticsearch/api/actions/snapshot/clone.rb +62 -0
- data/lib/elasticsearch/api/actions/snapshot/create.rb +25 -35
- data/lib/elasticsearch/api/actions/snapshot/create_repository.rb +21 -30
- data/lib/elasticsearch/api/actions/snapshot/delete.rb +27 -27
- data/lib/elasticsearch/api/actions/snapshot/delete_repository.rb +23 -24
- data/lib/elasticsearch/api/actions/snapshot/get.rb +30 -37
- data/lib/elasticsearch/api/actions/snapshot/get_repository.rb +28 -31
- data/lib/elasticsearch/api/actions/snapshot/repository_analyze.rb +62 -0
- data/lib/elasticsearch/api/actions/snapshot/restore.rb +23 -37
- data/lib/elasticsearch/api/actions/snapshot/status.rb +31 -31
- data/lib/elasticsearch/api/actions/snapshot/verify_repository.rb +20 -18
- data/lib/elasticsearch/api/actions/snapshot_lifecycle_management/delete_lifecycle.rb +51 -0
- data/lib/elasticsearch/api/actions/snapshot_lifecycle_management/execute_lifecycle.rb +51 -0
- data/lib/elasticsearch/api/actions/snapshot_lifecycle_management/execute_retention.rb +46 -0
- data/lib/elasticsearch/api/actions/snapshot_lifecycle_management/get_lifecycle.rb +53 -0
- data/lib/elasticsearch/api/actions/snapshot_lifecycle_management/get_stats.rb +46 -0
- data/lib/elasticsearch/api/actions/snapshot_lifecycle_management/get_status.rb +46 -0
- data/lib/elasticsearch/api/actions/snapshot_lifecycle_management/put_lifecycle.rb +52 -0
- data/lib/elasticsearch/api/actions/snapshot_lifecycle_management/start.rb +46 -0
- data/lib/elasticsearch/api/actions/snapshot_lifecycle_management/stop.rb +46 -0
- data/lib/elasticsearch/api/actions/sql/clear_cursor.rb +49 -0
- data/lib/elasticsearch/api/actions/sql/delete_async.rb +51 -0
- data/lib/elasticsearch/api/actions/sql/get_async.rb +55 -0
- data/lib/elasticsearch/api/actions/sql/get_async_status.rb +51 -0
- data/lib/elasticsearch/api/actions/sql/query.rb +50 -0
- data/lib/elasticsearch/api/actions/sql/translate.rb +49 -0
- data/lib/elasticsearch/api/actions/ssl/certificates.rb +46 -0
- data/lib/elasticsearch/api/actions/tasks/cancel.rb +26 -19
- data/lib/elasticsearch/api/actions/tasks/get.rb +23 -19
- data/lib/elasticsearch/api/actions/tasks/list.rb +19 -23
- data/lib/elasticsearch/api/actions/terms_enum.rb +55 -0
- data/lib/elasticsearch/api/actions/termvectors.rb +35 -74
- data/lib/elasticsearch/api/actions/text_structure/find_structure.rb +70 -0
- data/lib/elasticsearch/api/actions/transform/delete_transform.rb +53 -0
- data/lib/elasticsearch/api/actions/transform/get_transform.rb +57 -0
- data/lib/elasticsearch/api/actions/transform/get_transform_stats.rb +54 -0
- data/lib/elasticsearch/api/actions/transform/preview_transform.rb +60 -0
- data/lib/elasticsearch/api/actions/transform/put_transform.rb +55 -0
- data/lib/elasticsearch/api/actions/transform/start_transform.rb +52 -0
- data/lib/elasticsearch/api/actions/transform/stop_transform.rb +56 -0
- data/lib/elasticsearch/api/actions/transform/update_transform.rb +55 -0
- data/lib/elasticsearch/api/actions/transform/upgrade_transforms.rb +48 -0
- data/lib/elasticsearch/api/actions/update.rb +41 -107
- data/lib/elasticsearch/api/actions/update_by_query.rb +23 -72
- data/lib/elasticsearch/api/actions/update_by_query_rethrottle.rb +20 -16
- data/lib/elasticsearch/api/actions/watcher/ack_watch.rb +58 -0
- data/lib/elasticsearch/api/actions/watcher/activate_watch.rb +51 -0
- data/lib/elasticsearch/api/actions/watcher/deactivate_watch.rb +51 -0
- data/lib/elasticsearch/api/actions/watcher/delete_watch.rb +59 -0
- data/lib/elasticsearch/api/actions/watcher/execute_watch.rb +55 -0
- data/lib/elasticsearch/api/actions/watcher/get_watch.rb +51 -0
- data/lib/elasticsearch/api/actions/watcher/put_watch.rb +56 -0
- data/lib/elasticsearch/api/actions/watcher/query_watches.rb +52 -0
- data/lib/elasticsearch/api/actions/watcher/start.rb +46 -0
- data/lib/elasticsearch/api/actions/watcher/stats.rb +54 -0
- data/lib/elasticsearch/api/actions/watcher/stop.rb +46 -0
- data/lib/elasticsearch/api/actions/xpack/info.rb +48 -0
- data/lib/elasticsearch/api/actions/xpack/usage.rb +47 -0
- data/lib/elasticsearch/api/namespace/async_search.rb +36 -0
- data/lib/elasticsearch/api/{actions/remote/info.rb → namespace/autoscaling.rb} +12 -14
- data/lib/elasticsearch/api/namespace/cat.rb +1 -2
- data/lib/elasticsearch/api/namespace/cluster.rb +1 -1
- data/lib/elasticsearch/api/namespace/common.rb +1 -1
- data/lib/elasticsearch/api/namespace/cross_cluster_replication.rb +38 -0
- data/lib/elasticsearch/api/namespace/dangling_indices.rb +35 -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/indices.rb +1 -1
- data/lib/elasticsearch/api/namespace/ingest.rb +1 -2
- data/lib/elasticsearch/api/namespace/license.rb +36 -0
- data/lib/elasticsearch/api/namespace/logstash.rb +36 -0
- data/lib/elasticsearch/api/namespace/machine_learning.rb +38 -0
- data/lib/elasticsearch/api/namespace/migration.rb +36 -0
- data/lib/elasticsearch/api/namespace/monitoring.rb +36 -0
- data/lib/elasticsearch/api/namespace/nodes.rb +1 -1
- data/lib/elasticsearch/api/namespace/remote.rb +1 -1
- 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.rb +1 -1
- 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/tasks.rb +1 -1
- 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 +7 -57
- data/lib/elasticsearch/api/version.rb +2 -2
- data/lib/elasticsearch/api.rb +30 -21
- data/lib/elasticsearch-api.rb +1 -1
- data/spec/elasticsearch/api/actions/bulk_spec.rb +18 -37
- data/spec/elasticsearch/api/actions/cat/aliases_spec.rb +3 -3
- data/spec/elasticsearch/api/actions/cat/allocation_spec.rb +3 -3
- data/spec/elasticsearch/api/actions/cat/count_spec.rb +3 -3
- data/spec/elasticsearch/api/actions/cat/fielddata_spec.rb +5 -5
- data/spec/elasticsearch/api/actions/cat/health_spec.rb +3 -3
- data/spec/elasticsearch/api/actions/cat/help_spec.rb +3 -3
- data/spec/elasticsearch/api/actions/cat/indices_spec.rb +3 -3
- data/spec/elasticsearch/api/actions/cat/master_spec.rb +3 -3
- data/spec/elasticsearch/api/actions/cat/nodeattrs_spec.rb +3 -3
- data/spec/elasticsearch/api/actions/cat/nodes_spec.rb +3 -3
- data/spec/elasticsearch/api/actions/cat/pending_tasks_spec.rb +3 -3
- data/spec/elasticsearch/api/actions/cat/plugins_spec.rb +3 -3
- data/spec/elasticsearch/api/actions/cat/recovery_spec.rb +3 -3
- data/spec/elasticsearch/api/actions/cat/repositories_spec.rb +3 -3
- data/spec/elasticsearch/api/actions/cat/segments_spec.rb +12 -14
- data/spec/elasticsearch/api/actions/cat/shards_spec.rb +3 -3
- data/spec/elasticsearch/api/actions/cat/snapshot_spec.rb +3 -3
- data/spec/elasticsearch/api/actions/cat/tasks_spec.rb +3 -3
- data/spec/elasticsearch/api/actions/cat/templates_spec.rb +3 -3
- data/spec/elasticsearch/api/actions/cat/thread_pool_spec.rb +3 -3
- data/spec/elasticsearch/api/actions/clear_scroll_spec.rb +7 -5
- data/spec/elasticsearch/api/actions/{benchmark_spec.rb → close_point_in_time_spec.rb} +7 -7
- data/spec/elasticsearch/api/actions/cluster/allocation_explain_spec.rb +3 -3
- data/spec/elasticsearch/api/actions/cluster/get_settings_spec.rb +3 -3
- data/spec/elasticsearch/api/actions/cluster/health_spec.rb +7 -7
- data/spec/elasticsearch/api/actions/cluster/pending_tasks_spec.rb +3 -3
- data/spec/elasticsearch/api/actions/cluster/put_settings_spec.rb +3 -3
- data/spec/elasticsearch/api/actions/cluster/remote_info_spec.rb +3 -3
- data/spec/elasticsearch/api/actions/cluster/reroute_spec.rb +5 -5
- data/spec/elasticsearch/api/actions/cluster/state_spec.rb +5 -5
- data/spec/elasticsearch/api/actions/cluster/stats_spec.rb +3 -3
- data/spec/elasticsearch/api/actions/count_spec.rb +16 -16
- data/spec/elasticsearch/api/actions/create_document_spec.rb +17 -13
- data/spec/elasticsearch/api/actions/dangling_indices/delete_dangling_indices_spec.rb +48 -0
- data/spec/elasticsearch/api/actions/dangling_indices/import_dangling_indices_spec.rb +48 -0
- data/spec/elasticsearch/api/actions/dangling_indices/list_dangling_indices_spec.rb +36 -0
- data/spec/elasticsearch/api/actions/data_frame/update_data_frame_transform_spec.rb +81 -0
- data/spec/elasticsearch/api/actions/delete_by_query_spec.rb +16 -25
- data/spec/elasticsearch/api/actions/delete_document_spec.rb +14 -25
- data/spec/elasticsearch/api/actions/delete_script_spec.rb +4 -17
- data/spec/elasticsearch/api/actions/exists_document_spec.rb +13 -23
- data/spec/elasticsearch/api/actions/explain_document_spec.rb +18 -18
- data/spec/elasticsearch/api/actions/{scoll_spec.rb → features/get_features_spec.rb} +11 -7
- data/spec/elasticsearch/api/actions/features/reset_features_spec.rb +38 -0
- data/spec/elasticsearch/api/actions/field_caps_spec.rb +4 -3
- data/spec/elasticsearch/api/actions/fleet/global_checkpoints_spec.rb +44 -0
- data/spec/elasticsearch/api/actions/get_document_source_spec.rb +9 -20
- data/spec/elasticsearch/api/actions/get_document_spec.rb +9 -33
- data/spec/elasticsearch/api/actions/get_script_spec.rb +4 -3
- data/spec/elasticsearch/api/actions/hashie_spec.rb +1 -1
- data/spec/elasticsearch/api/actions/index_document_spec.rb +14 -40
- 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 +63 -0
- data/spec/elasticsearch/api/actions/indices/analyze_spec.rb +11 -16
- data/spec/elasticsearch/api/actions/indices/clear_cache_spec.rb +8 -12
- data/spec/elasticsearch/api/actions/indices/clone_spec.rb +122 -0
- data/spec/elasticsearch/api/actions/indices/close_spec.rb +5 -5
- data/spec/elasticsearch/api/actions/indices/create_spec.rb +5 -5
- data/spec/elasticsearch/api/actions/{nodes/shutdown_spec.rb → indices/data_streams_stats_spec.rb} +15 -33
- data/spec/elasticsearch/api/actions/indices/delete_alias_spec.rb +6 -6
- data/spec/elasticsearch/api/actions/indices/delete_spec.rb +6 -6
- data/spec/elasticsearch/api/actions/indices/delete_template_spec.rb +4 -4
- data/spec/elasticsearch/api/actions/indices/disk_usage_spec.rb +48 -0
- data/spec/elasticsearch/api/actions/indices/exists_alias_spec.rb +2 -2
- data/spec/elasticsearch/api/actions/indices/exists_spec.rb +2 -2
- data/spec/elasticsearch/api/actions/indices/exists_template_spec.rb +2 -2
- data/spec/elasticsearch/api/actions/indices/exists_type_spec.rb +2 -2
- data/spec/elasticsearch/api/actions/indices/field_usage_stats_spec.rb +46 -0
- data/spec/elasticsearch/api/actions/indices/flush_spec.rb +7 -7
- data/spec/elasticsearch/api/actions/indices/forcemerge_spec.rb +3 -3
- data/spec/elasticsearch/api/actions/indices/get_alias_spec.rb +5 -5
- data/spec/elasticsearch/api/actions/indices/get_field_mapping_spec.rb +4 -15
- data/spec/elasticsearch/api/actions/indices/get_mapping_spec.rb +9 -24
- data/spec/elasticsearch/api/actions/indices/get_settings_spec.rb +6 -6
- data/spec/elasticsearch/api/actions/indices/get_spec.rb +4 -15
- data/spec/elasticsearch/api/actions/indices/open_spec.rb +5 -5
- data/spec/elasticsearch/api/actions/indices/put_alias_spec.rb +9 -9
- data/spec/elasticsearch/api/actions/indices/put_mapping_spec.rb +10 -16
- data/spec/elasticsearch/api/actions/indices/put_settings_spec.rb +7 -7
- data/spec/elasticsearch/api/actions/indices/put_template_spec.rb +5 -5
- data/spec/elasticsearch/api/actions/indices/recovery_spec.rb +3 -3
- data/spec/elasticsearch/api/actions/indices/refresh_spec.rb +7 -7
- data/spec/elasticsearch/api/actions/indices/rollover_spec.rb +4 -4
- data/spec/elasticsearch/api/actions/indices/segments_spec.rb +7 -7
- data/spec/elasticsearch/api/actions/indices/shard_stores_spec.rb +3 -3
- data/spec/elasticsearch/api/actions/indices/shrink_spec.rb +3 -3
- data/spec/elasticsearch/api/actions/indices/split_spec.rb +3 -3
- data/spec/elasticsearch/api/actions/indices/stats_spec.rb +9 -15
- data/spec/elasticsearch/api/actions/indices/unfreeze_spec.rb +21 -4
- data/spec/elasticsearch/api/actions/indices/update_aliases_spec.rb +4 -4
- data/spec/elasticsearch/api/actions/indices/validate_query_spec.rb +15 -31
- data/spec/elasticsearch/api/actions/info_spec.rb +4 -3
- data/spec/elasticsearch/api/actions/ingest/delete_pipeline_spec.rb +4 -4
- data/spec/elasticsearch/api/actions/ingest/geo_ip_stats_spec.rb +38 -0
- data/spec/elasticsearch/api/actions/ingest/get_pipeline_spec.rb +4 -4
- data/spec/elasticsearch/api/actions/ingest/put_pipeline_spec.rb +4 -4
- data/spec/elasticsearch/api/actions/ingest/simulate_spec.rb +9 -10
- data/spec/elasticsearch/api/actions/json_builders_spec.rb +13 -14
- data/spec/elasticsearch/api/actions/machine_learning/get_model_snapshot_upgrade_stats_spec.rb +56 -0
- data/spec/elasticsearch/api/actions/machine_learning/get_trained_model_deployment_stats_spec.rb +46 -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/mget_spec.rb +11 -26
- 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 +13 -29
- data/spec/elasticsearch/api/actions/msearch_template_spec.rb +8 -9
- data/spec/elasticsearch/api/actions/mtermvectors_spec.rb +8 -9
- 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 +5 -5
- data/spec/elasticsearch/api/actions/nodes/info_spec.rb +8 -8
- data/spec/elasticsearch/api/actions/nodes/reload_secure_settings_spec.rb +13 -16
- data/spec/elasticsearch/api/actions/nodes/stats_spec.rb +6 -6
- data/spec/elasticsearch/api/actions/{abort_benchmark_spec.rb → open_point_in_time_spec.rb} +6 -6
- data/spec/elasticsearch/api/actions/ping_spec.rb +4 -3
- data/spec/elasticsearch/api/actions/put_script_spec.rb +24 -17
- data/spec/elasticsearch/api/actions/rank_eval_spec.rb +127 -0
- data/spec/elasticsearch/api/actions/reindex_spec.rb +5 -4
- data/spec/elasticsearch/api/actions/render_search_template_spec.rb +28 -10
- data/spec/elasticsearch/api/actions/scroll_spec.rb +52 -0
- data/spec/elasticsearch/api/actions/search_mvt_spec.rb +53 -0
- data/spec/elasticsearch/api/actions/search_shards_spec.rb +5 -4
- data/spec/elasticsearch/api/actions/search_spec.rb +10 -62
- data/spec/elasticsearch/api/actions/search_template_spec.rb +7 -7
- 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 +54 -0
- data/spec/elasticsearch/api/actions/security/delete_service_token_spec.rb +60 -0
- data/spec/elasticsearch/api/actions/{indices/upgrade_spec.rb → security/enroll_kibana_spec.rb} +8 -9
- 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} +5 -5
- 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/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/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 +67 -0
- data/spec/elasticsearch/api/actions/snapshot/create_repository_spec.rb +3 -3
- data/spec/elasticsearch/api/actions/snapshot/create_spec.rb +3 -3
- data/spec/elasticsearch/api/actions/snapshot/delete_repository_spec.rb +4 -4
- data/spec/elasticsearch/api/actions/snapshot/delete_spec.rb +3 -3
- data/spec/elasticsearch/api/actions/snapshot/get_repository_spec.rb +3 -3
- data/spec/elasticsearch/api/actions/snapshot/get_spec.rb +3 -3
- data/spec/elasticsearch/api/actions/snapshot/repository_analize_spec.rb +46 -0
- data/spec/elasticsearch/api/actions/snapshot/restore_spec.rb +8 -11
- data/spec/elasticsearch/api/actions/snapshot/status_spec.rb +4 -5
- data/spec/elasticsearch/api/actions/snapshot/verify_repository_spec.rb +7 -8
- 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 +8 -9
- data/spec/elasticsearch/api/actions/tasks/get_spec.rb +3 -3
- data/spec/elasticsearch/api/actions/tasks/list_spec.rb +7 -19
- data/spec/elasticsearch/api/actions/terms_enum_spec.rb +52 -0
- data/spec/elasticsearch/api/actions/termvectors_spec.rb +11 -12
- data/spec/elasticsearch/api/actions/update_by_query_spec.rb +7 -7
- data/spec/elasticsearch/api/actions/update_document_spec.rb +16 -33
- data/spec/elasticsearch/api/api_response_spec.rb +64 -0
- data/spec/elasticsearch/api/api_spec.rb +1 -4
- data/spec/elasticsearch/api/client_spec.rb +1 -5
- data/spec/elasticsearch/api/rest_api_yaml_spec.rb +91 -101
- data/spec/elasticsearch/api/utils_spec.rb +15 -90
- data/spec/rest_api_tests_helper.rb +91 -0
- data/spec/skipped_tests_free.yml +32 -0
- data/spec/skipped_tests_platinum.yml +59 -0
- data/spec/spec_helper.rb +21 -17
- 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/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/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/rollup/rollup_test.rb +58 -0
- data/spec/unit_tests_platinum/unit/security/authenticate_test.rb +43 -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_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/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/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/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 +6 -4
- data/utils/README.md +38 -0
- data/utils/Thorfile +3 -17
- data/utils/thor/.rubocop.yml +2 -0
- data/utils/thor/generate_source.rb +223 -87
- data/utils/thor/generator/endpoint_specifics.rb +159 -0
- data/utils/thor/generator/files_helper.rb +65 -0
- data/utils/thor/lister.rb +4 -5
- data/utils/thor/templates/_body.erb +34 -0
- data/utils/thor/templates/_documentation_top.erb +57 -0
- data/utils/thor/templates/_method_setup.erb +41 -0
- data/utils/thor/templates/_perform_request.erb +50 -0
- data/utils/thor/templates/method.erb +68 -0
- data/utils/thor/templates/{ruby/test.erb → test.erb} +1 -1
- data/utils/thor/templates/{ruby/test_helper.rb → test_helper.rb} +1 -5
- metadata +727 -89
- data/lib/elasticsearch/api/actions/benchmark.rb +0 -82
- data/lib/elasticsearch/api/actions/cat/params_registry.rb +0 -61
- data/lib/elasticsearch/api/actions/cluster/params_registry.rb +0 -61
- data/lib/elasticsearch/api/actions/indices/freeze.rb +0 -40
- data/lib/elasticsearch/api/actions/indices/params_registry.rb +0 -61
- data/lib/elasticsearch/api/actions/ingest/params_registry.rb +0 -61
- data/lib/elasticsearch/api/actions/nodes/params_registry.rb +0 -61
- data/lib/elasticsearch/api/actions/nodes/shutdown.rb +0 -56
- data/lib/elasticsearch/api/actions/params_registry.rb +0 -59
- data/lib/elasticsearch/api/actions/snapshot/params_registry.rb +0 -61
- data/lib/elasticsearch/api/actions/tasks/params_registry.rb +0 -61
- data/spec/elasticsearch/api/actions/indices/flush_synced_spec.rb +0 -90
- data/spec/elasticsearch/api/actions/indices/freeze_spec.rb +0 -68
- data/spec/rest_yaml_tests_helper.rb +0 -94
- data/test/integration/yaml_test_runner.rb +0 -592
- data/test/test_helper.rb +0 -118
- data/utils/thor/generate_api.rb +0 -206
- data/utils/thor/templates/ruby/method.erb +0 -75
@@ -1,592 +0,0 @@
|
|
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
|
-
RUBY_1_8 = defined?(RUBY_VERSION) && RUBY_VERSION < '1.9'
|
19
|
-
JRUBY = defined?(JRUBY_VERSION)
|
20
|
-
|
21
|
-
require 'pathname'
|
22
|
-
require 'logger'
|
23
|
-
require 'yaml'
|
24
|
-
require 'active_support/inflector'
|
25
|
-
require 'ansi'
|
26
|
-
|
27
|
-
require 'elasticsearch'
|
28
|
-
require 'elasticsearch/extensions/test/cluster'
|
29
|
-
require 'elasticsearch/extensions/test/startup_shutdown'
|
30
|
-
require 'elasticsearch/extensions/test/profiling' unless JRUBY
|
31
|
-
|
32
|
-
# Skip features
|
33
|
-
skip_features = 'stash_in_path,requires_replica,headers,warnings,default_shards'
|
34
|
-
SKIP_FEATURES = ENV.fetch('TEST_SKIP_FEATURES', skip_features)
|
35
|
-
SKIPPED_TESTS = [ '/nodes.stats/30_discovery.yml' ]
|
36
|
-
|
37
|
-
# Launch test cluster
|
38
|
-
#
|
39
|
-
if ENV['SERVER'] and not Elasticsearch::Extensions::Test::Cluster.running?
|
40
|
-
Elasticsearch::Extensions::Test::Cluster.start
|
41
|
-
end
|
42
|
-
|
43
|
-
# Register `at_exit` handler for server shutdown.
|
44
|
-
# MUST be called before requiring `test/unit`.
|
45
|
-
#
|
46
|
-
at_exit { Elasticsearch::Extensions::Test::Cluster.stop if ENV['SERVER'] and Elasticsearch::Extensions::Test::Cluster.running? }
|
47
|
-
|
48
|
-
class String
|
49
|
-
# Reset the `ansi` method on CI
|
50
|
-
def ansi(*args)
|
51
|
-
self
|
52
|
-
end
|
53
|
-
end if ENV['CI']
|
54
|
-
|
55
|
-
module CapturedLogger
|
56
|
-
def self.included base
|
57
|
-
base.class_eval do
|
58
|
-
%w[ info error warn fatal debug ].each do |m|
|
59
|
-
alias_method "#{m}_without_capture", m
|
60
|
-
|
61
|
-
define_method m do |*args|
|
62
|
-
@logdev.__send__ :puts, *(args.join("\n") + "\n")
|
63
|
-
self.__send__ "#{m}_without_capture", *args
|
64
|
-
end
|
65
|
-
end
|
66
|
-
end
|
67
|
-
end
|
68
|
-
end
|
69
|
-
|
70
|
-
Logger.__send__ :include, CapturedLogger if ENV['CI']
|
71
|
-
|
72
|
-
logger = Logger.new($stderr)
|
73
|
-
logger.progname = 'elasticsearch'
|
74
|
-
logger.formatter = proc do |severity, datetime, progname, msg|
|
75
|
-
color = case severity
|
76
|
-
when /INFO/ then :green
|
77
|
-
when /ERROR|WARN|FATAL/ then :red
|
78
|
-
when /DEBUG/ then :cyan
|
79
|
-
else :white
|
80
|
-
end
|
81
|
-
"#{severity[0]} ".ansi(color, :faint) + msg.ansi(:white, :faint) + "\n"
|
82
|
-
end
|
83
|
-
|
84
|
-
tracer = Logger.new($stdout)
|
85
|
-
tracer.progname = 'elasticsearch.tracer'
|
86
|
-
tracer.formatter = proc { |severity, datetime, progname, msg| "#{msg}\n" }
|
87
|
-
|
88
|
-
# Set up the client for the test
|
89
|
-
#
|
90
|
-
# To set up your own client, just set the `$client` variable in a file, and then require it:
|
91
|
-
#
|
92
|
-
# ruby -I lib:test -r ./tmp/my_special_client.rb test/integration/yaml_test_runner.rb
|
93
|
-
#
|
94
|
-
url = ENV['TEST_CLUSTER_URL'] || ENV['TEST_ES_SERVER']
|
95
|
-
url = "http://localhost:#{ENV['TEST_CLUSTER_PORT'] || 9250}" unless url
|
96
|
-
$client ||= Elasticsearch::Client.new url: url
|
97
|
-
$helper_client ||= Elasticsearch::Client.new url: url
|
98
|
-
|
99
|
-
$client.transport.logger = logger unless ENV['QUIET'] || ENV['CI']
|
100
|
-
$client.transport.tracer = tracer if ENV['TRACE']
|
101
|
-
|
102
|
-
# Store Elasticsearch version
|
103
|
-
#
|
104
|
-
es_version_info = $client.info['version']
|
105
|
-
$es_version = es_version_info['number']
|
106
|
-
|
107
|
-
puts '-'*80,
|
108
|
-
"Elasticsearch #{$es_version.ansi(:bold)} [#{es_version_info['build_hash'].to_s[0...7]}]".center(80),
|
109
|
-
'-'*80
|
110
|
-
|
111
|
-
require 'test_helper'
|
112
|
-
|
113
|
-
class Elasticsearch::Test::YAMLTestReporter < ::MiniTest::Reporters::SpecReporter
|
114
|
-
def before_suite(suite)
|
115
|
-
puts ">>>>> #{suite.to_s} #{''.ljust(73-suite.to_s.size, '>')}" unless ENV['QUIET']
|
116
|
-
end
|
117
|
-
|
118
|
-
def after_suite(suite)
|
119
|
-
super unless ENV['QUIET']
|
120
|
-
end
|
121
|
-
|
122
|
-
def after_suites(suites, type)
|
123
|
-
time = Time.now - runner.suites_start_time
|
124
|
-
|
125
|
-
color = ( runner.errors > 0 || runner.failures > 0 ) ? :red : :green
|
126
|
-
status_line = "Finished in %.6fs, %.4f tests/s, %.4f assertions/s.\n".ansi(color) %
|
127
|
-
[time, runner.test_count / time, runner.assertion_count / time]
|
128
|
-
status_line += "#{runner.test_count} tests: #{runner.skips} skipped, #{runner.errors} errored, #{runner.failures} failed.".ansi(:bold, color)
|
129
|
-
|
130
|
-
puts '=' * 80
|
131
|
-
puts status_line
|
132
|
-
puts '-' * 80, ''
|
133
|
-
|
134
|
-
runner.test_results.each do |suite, tests|
|
135
|
-
tests.each do |test, test_runner|
|
136
|
-
next unless test_runner.result.to_s =~ /error|failure/
|
137
|
-
|
138
|
-
test_name = test_runner.test.to_s
|
139
|
-
.gsub(/^test_: /, '')
|
140
|
-
.gsub(/ should /, ' ')
|
141
|
-
.gsub(/\| .*$/, '')
|
142
|
-
.gsub(/\.\s*$/, '')
|
143
|
-
yaml_filename = test_runner.test.to_s.gsub(/.*\| (.*)\.\s*$/, '\1')
|
144
|
-
|
145
|
-
status = case test_runner.result
|
146
|
-
when :failure
|
147
|
-
"FAILURE"
|
148
|
-
when :error
|
149
|
-
"ERROR"
|
150
|
-
end
|
151
|
-
|
152
|
-
puts status.ansi(:red) +
|
153
|
-
" [#{test_runner.suite.to_s}] ".ansi(:red, :bold) +
|
154
|
-
test_name,
|
155
|
-
"<https://github.com/elastic/elasticsearch/blob/master/rest-api-spec/src/main/resources/rest-api-spec/test/#{yaml_filename}>".ansi(:underscore),
|
156
|
-
test_runner.exception.message.ansi(:faint), ''
|
157
|
-
end
|
158
|
-
end
|
159
|
-
end
|
160
|
-
end
|
161
|
-
|
162
|
-
Minitest::Reporters.use! Elasticsearch::Test::YAMLTestReporter.new
|
163
|
-
|
164
|
-
module Elasticsearch
|
165
|
-
module YamlTestSuite
|
166
|
-
$last_response = ''
|
167
|
-
$results = {}
|
168
|
-
$stash = {}
|
169
|
-
|
170
|
-
module Utils
|
171
|
-
def titleize(word)
|
172
|
-
word.to_s.gsub(/[^\w]+/, ' ').gsub(/\b('?[a-z])/) { $1.capitalize }.tr('_', ' ')
|
173
|
-
end
|
174
|
-
|
175
|
-
def symbolize_keys(object)
|
176
|
-
if object.is_a? Hash
|
177
|
-
object.reduce({}) { |memo,(k,v)| memo[k.to_s.to_sym] = symbolize_keys(v); memo }
|
178
|
-
else
|
179
|
-
object
|
180
|
-
end
|
181
|
-
end
|
182
|
-
|
183
|
-
extend self
|
184
|
-
end
|
185
|
-
|
186
|
-
module Runner
|
187
|
-
def perform_api_call(test, api, arguments=nil)
|
188
|
-
namespace = api.split('.')
|
189
|
-
|
190
|
-
replacer = lambda do |value|
|
191
|
-
case value
|
192
|
-
when Array
|
193
|
-
value.map { |v| replacer.call(v) }
|
194
|
-
when Hash
|
195
|
-
Hash[ value.map { |v| replacer.call(v) } ]
|
196
|
-
else
|
197
|
-
fetch_or_return value
|
198
|
-
end
|
199
|
-
end
|
200
|
-
|
201
|
-
timefixer = lambda do |value|
|
202
|
-
if value.is_a?(Time)
|
203
|
-
value.iso8601
|
204
|
-
else
|
205
|
-
value
|
206
|
-
end
|
207
|
-
end
|
208
|
-
|
209
|
-
arguments = Hash[
|
210
|
-
arguments.map do |key, value|
|
211
|
-
replacement = replacer.call(value)
|
212
|
-
replacement = timefixer.call(replacement)
|
213
|
-
[key, replacement]
|
214
|
-
end
|
215
|
-
]
|
216
|
-
|
217
|
-
$stderr.puts "ARGUMENTS: #{arguments.inspect}" if ENV['DEBUG']
|
218
|
-
|
219
|
-
$last_response = namespace.reduce($client) do |memo, current|
|
220
|
-
unless current == namespace.last
|
221
|
-
memo = memo.send(current)
|
222
|
-
else
|
223
|
-
arguments ? memo = memo.send(current, arguments) : memo = memo.send(current)
|
224
|
-
end
|
225
|
-
memo
|
226
|
-
end
|
227
|
-
|
228
|
-
$results[test.hash] = $last_response
|
229
|
-
end
|
230
|
-
|
231
|
-
def evaluate(test, property, response=nil)
|
232
|
-
response ||= $results[test.hash]
|
233
|
-
property.gsub(/\\\./, '_____').split('.').reduce(response) do |memo, attr|
|
234
|
-
if memo
|
235
|
-
if attr
|
236
|
-
attr = attr.gsub(/_____/, '.')
|
237
|
-
attr = $stash[attr] if attr.start_with? '$'
|
238
|
-
end
|
239
|
-
memo = memo.is_a?(Hash) ? memo[attr] : memo[attr.to_i]
|
240
|
-
end
|
241
|
-
memo
|
242
|
-
end
|
243
|
-
end
|
244
|
-
|
245
|
-
def in_context(name, &block)
|
246
|
-
klass = Class.new(YamlTestCase)
|
247
|
-
Object::const_set "%sTest" % name.split(/\s/).map { |d| d.capitalize }.join('').gsub(/[^\w]+/, ''), klass
|
248
|
-
klass.context "[#{name.ansi(:bold)}]", &block
|
249
|
-
end
|
250
|
-
|
251
|
-
def fetch_or_return(var)
|
252
|
-
if var.is_a?(String) && var =~ /^\$(.+)/
|
253
|
-
$stash[var]
|
254
|
-
else
|
255
|
-
var
|
256
|
-
end
|
257
|
-
end
|
258
|
-
|
259
|
-
def set(var, val)
|
260
|
-
$stash["$#{var}"] = val
|
261
|
-
end
|
262
|
-
|
263
|
-
def skip?(actions)
|
264
|
-
skip = actions.select { |a| a['skip'] }.first
|
265
|
-
$stderr.puts "SKIP: #{skip.inspect}" if ENV['DEBUG']
|
266
|
-
|
267
|
-
def skip_version(skip)
|
268
|
-
if skip && skip['skip']['version']
|
269
|
-
|
270
|
-
return skip['skip']['reason'] ? skip['skip']['reason'] : true if skip['skip']['version'] == 'all'
|
271
|
-
|
272
|
-
min, max = skip['skip']['version'].split('-').map(&:strip)
|
273
|
-
|
274
|
-
min_normalized = sprintf "%03d-%03d-%03d",
|
275
|
-
*min.split('.')
|
276
|
-
.map(&:to_i)
|
277
|
-
.fill(0, min.split('.').length, 3-min.split('.').length)
|
278
|
-
|
279
|
-
max_normalized = sprintf "%03d-%03d-%03d",
|
280
|
-
*max.split('.')
|
281
|
-
.map(&:to_i)
|
282
|
-
.map(&:to_i)
|
283
|
-
.fill(0, max.split('.').length, 3-max.split('.').length)
|
284
|
-
|
285
|
-
es_normalized = sprintf "%03d-%03d-%03d", *$es_version.split('.').map(&:to_i)
|
286
|
-
|
287
|
-
if ( min.empty? || min_normalized <= es_normalized ) && ( max.empty? || max_normalized >= es_normalized )
|
288
|
-
return skip['skip']['reason'] ? skip['skip']['reason'] : true
|
289
|
-
end
|
290
|
-
|
291
|
-
return false
|
292
|
-
end
|
293
|
-
end
|
294
|
-
|
295
|
-
def skip_features(skip)
|
296
|
-
if skip && skip['skip']['features']
|
297
|
-
skip_features = skip['skip']['features'].respond_to?(:split) ? skip['skip']['features'].split(',') : skip['skip']['features']
|
298
|
-
if ( skip_features & SKIP_FEATURES.split(',') ).size > 0
|
299
|
-
return skip['skip']['features']
|
300
|
-
end
|
301
|
-
end
|
302
|
-
end
|
303
|
-
|
304
|
-
return skip_version(skip) || skip_features(skip)
|
305
|
-
end
|
306
|
-
|
307
|
-
extend self
|
308
|
-
end
|
309
|
-
|
310
|
-
class YamlTestCase < ::Minitest::Test; end
|
311
|
-
end
|
312
|
-
end
|
313
|
-
|
314
|
-
include Elasticsearch::YamlTestSuite
|
315
|
-
|
316
|
-
rest_api_test_source = '../../../../tmp/elasticsearch/rest-api-spec/src/main/resources/rest-api-spec/test'
|
317
|
-
PATH = Pathname(ENV.fetch('TEST_REST_API_SPEC', File.expand_path(rest_api_test_source, __FILE__)))
|
318
|
-
|
319
|
-
suites = Dir.glob(PATH.join('*')).map { |d| Pathname(d) }
|
320
|
-
suites = suites.select { |s| s.to_s =~ Regexp.new(ENV['FILTER']) } if ENV['FILTER']
|
321
|
-
|
322
|
-
suites.each do |suite|
|
323
|
-
name = Elasticsearch::YamlTestSuite::Utils.titleize(suite.basename)
|
324
|
-
|
325
|
-
Elasticsearch::YamlTestSuite::Runner.in_context name do
|
326
|
-
|
327
|
-
# --- Register context setup -------------------------------------------
|
328
|
-
#
|
329
|
-
setup do
|
330
|
-
$helper_client.indices.delete index: '_all', ignore: 404
|
331
|
-
$helper_client.indices.delete index: 'test-weird-index*', ignore: 404
|
332
|
-
$helper_client.indices.delete_template name: 'nomatch', ignore: 404
|
333
|
-
$helper_client.indices.delete_template name: 'test_2', ignore: 404
|
334
|
-
$helper_client.indices.delete_template name: 'test2', ignore: 404
|
335
|
-
$helper_client.indices.delete_template name: 'test', ignore: 404
|
336
|
-
$helper_client.indices.delete_template name: 'index_template', ignore: 404
|
337
|
-
$helper_client.indices.delete_template name: 'test_no_mappings', ignore: 404
|
338
|
-
$helper_client.indices.delete_template name: 'test_template', ignore: 404
|
339
|
-
$helper_client.snapshot.delete repository: 'test_repo_create_1', snapshot: 'test_snapshot', ignore: 404
|
340
|
-
$helper_client.snapshot.delete repository: 'test_repo_restore_1', snapshot: 'test_snapshot', ignore: 404
|
341
|
-
$helper_client.snapshot.delete repository: 'test_cat_snapshots_1', snapshot: 'snap1', ignore: 404
|
342
|
-
$helper_client.snapshot.delete repository: 'test_cat_snapshots_1', snapshot: 'snap2', ignore: 404
|
343
|
-
$helper_client.snapshot.delete_repository repository: 'test_repo_create_1', ignore: 404
|
344
|
-
$helper_client.snapshot.delete_repository repository: 'test_repo_restore_1', ignore: 404
|
345
|
-
$helper_client.snapshot.delete_repository repository: 'test_repo_get_1', ignore: 404
|
346
|
-
$helper_client.snapshot.delete_repository repository: 'test_repo_get_2', ignore: 404
|
347
|
-
$helper_client.snapshot.delete_repository repository: 'test_repo_status_1', ignore: 404
|
348
|
-
$helper_client.snapshot.delete_repository repository: 'test_cat_repo_1', ignore: 404
|
349
|
-
$helper_client.snapshot.delete_repository repository: 'test_cat_repo_2', ignore: 404
|
350
|
-
$helper_client.snapshot.delete_repository repository: 'test_cat_snapshots_1', ignore: 404
|
351
|
-
# FIXME: This shouldn't be needed -------------
|
352
|
-
%w[
|
353
|
-
test_cat_repo_1_loc
|
354
|
-
test_cat_repo_2_loc
|
355
|
-
test_cat_snapshots_1_loc
|
356
|
-
test_repo_get_1_loc
|
357
|
-
test_repo_status_1_loc
|
358
|
-
].each do |d|
|
359
|
-
FileUtils.rm_rf("/tmp/#{d}")
|
360
|
-
end
|
361
|
-
# ---------------------------------------------
|
362
|
-
$results = {}
|
363
|
-
$stash = {}
|
364
|
-
end
|
365
|
-
|
366
|
-
# --- Register context teardown ----------------------------------------
|
367
|
-
#
|
368
|
-
teardown do
|
369
|
-
$helper_client.indices.delete index: '_all', ignore: 404
|
370
|
-
|
371
|
-
# Wipe out cluster "transient" settings
|
372
|
-
settings = $helper_client.cluster.get_settings(flat_settings: true)['transient'].keys.reduce({}) {|s,i| s[i] = nil; s}
|
373
|
-
$helper_client.cluster.put_settings body: { transient: settings } unless settings.empty?
|
374
|
-
end
|
375
|
-
|
376
|
-
files = Dir[suite.join('*.{yml,yaml}')]
|
377
|
-
files.each do |file|
|
378
|
-
next if SKIPPED_TESTS.any? { |test| file =~ /#{test}/ }
|
379
|
-
begin
|
380
|
-
tests = YAML.load_stream File.new(file)
|
381
|
-
rescue RuntimeError => e
|
382
|
-
$stderr.puts "ERROR [#{e.class}] while loading [#{file}] file".ansi(:red)
|
383
|
-
# raise e
|
384
|
-
next
|
385
|
-
end
|
386
|
-
|
387
|
-
# Extract setup actions
|
388
|
-
setup_actions = tests.select { |t| t['setup'] }.first['setup'] rescue []
|
389
|
-
|
390
|
-
# Skip all the tests when `skip` is part of the `setup` part
|
391
|
-
if features = Runner.skip?(setup_actions)
|
392
|
-
$stdout.puts "#{'SKIP'.ansi(:yellow)} [#{name}] #{file.gsub(PATH.to_s, '').ansi(:bold)} (Feature not implemented: #{features})"
|
393
|
-
next
|
394
|
-
end
|
395
|
-
|
396
|
-
# Remove setup actions from tests
|
397
|
-
tests = tests.reject { |t| t['setup'] }
|
398
|
-
|
399
|
-
# Add setup actions to each individual test
|
400
|
-
tests.each { |t| t[t.keys.first] << { 'setup' => setup_actions } }
|
401
|
-
|
402
|
-
tests.each do |test|
|
403
|
-
context '' do
|
404
|
-
yaml_file_line = File.read(file).force_encoding("UTF-8").split("\n").index {|l| l.include? test.keys.first.to_s }
|
405
|
-
|
406
|
-
l = yaml_file_line ? "#L#{yaml_file_line.to_i + 1}" : ''
|
407
|
-
test_name = test.keys.first.to_s + " | #{file.gsub(PATH.to_s, '').gsub(/^\//, '')}" + l
|
408
|
-
actions = test.values.first
|
409
|
-
|
410
|
-
if reason = Runner.skip?(actions)
|
411
|
-
$stdout.puts "#{'SKIP'.ansi(:yellow)} [#{name}] #{test_name} (Reason: #{reason})"
|
412
|
-
next
|
413
|
-
end
|
414
|
-
|
415
|
-
# --- Register test setup -------------------------------------------
|
416
|
-
setup do
|
417
|
-
setup_actions = actions.select { |a| a['setup'] }
|
418
|
-
setup_actions.first['setup'].each do |action|
|
419
|
-
if action['do']
|
420
|
-
api, arguments = action['do'].to_a.first
|
421
|
-
arguments = Utils.symbolize_keys(arguments)
|
422
|
-
Runner.perform_api_call((test.to_s + '___setup'), api, arguments)
|
423
|
-
end
|
424
|
-
if action['set']
|
425
|
-
stash = action['set']
|
426
|
-
property, variable = stash.to_a.first
|
427
|
-
result = Runner.evaluate(test, property, $last_response)
|
428
|
-
$stderr.puts "STASH: '$#{variable}' => #{result.inspect}" if ENV['DEBUG']
|
429
|
-
Runner.set variable, result
|
430
|
-
end
|
431
|
-
end unless setup_actions.empty?
|
432
|
-
end
|
433
|
-
|
434
|
-
teardown do
|
435
|
-
teardown_actions = actions.select { |a| a['teardown'] }
|
436
|
-
teardown_actions.first['teardown'].each do |action|
|
437
|
-
if action['do']
|
438
|
-
api, arguments = action['do'].to_a.first
|
439
|
-
arguments = Utils.symbolize_keys(arguments)
|
440
|
-
Runner.perform_api_call((test.to_s + '___teardown'), api, arguments)
|
441
|
-
end
|
442
|
-
if action['set']
|
443
|
-
stash = action['set']
|
444
|
-
property, variable = stash.to_a.first
|
445
|
-
result = Runner.evaluate(test, property, $last_response)
|
446
|
-
$stderr.puts "STASH: '$#{variable}' => #{result.inspect}" if ENV['DEBUG']
|
447
|
-
Runner.set variable, result
|
448
|
-
end
|
449
|
-
end unless teardown_actions.empty?
|
450
|
-
end
|
451
|
-
|
452
|
-
# --- Register test method ------------------------------------------
|
453
|
-
should test_name do
|
454
|
-
if ENV['CI']
|
455
|
-
ref = ENV['TEST_BUILD_REF'].to_s.gsub(/origin\//, '') || 'master'
|
456
|
-
$stderr.puts "https://github.com/elasticsearch/elasticsearch/blob/#{ref}/rest-api-spec/test/" \
|
457
|
-
+ file.gsub(PATH.to_s, ''), ""
|
458
|
-
$stderr.puts YAML.dump(test) if ENV['DEBUG']
|
459
|
-
end
|
460
|
-
actions.each do |action|
|
461
|
-
$stderr.puts "ACTION: #{action.inspect}" if ENV['DEBUG']
|
462
|
-
|
463
|
-
# This check verifies that the YAML has correct indentation.
|
464
|
-
# See https://github.com/elastic/elasticsearch/issues/21980
|
465
|
-
raise "INVALID YAML: #{action.inspect}" if action.keys.size != 1
|
466
|
-
|
467
|
-
case
|
468
|
-
|
469
|
-
# --- Perform action ------------------------------------------
|
470
|
-
#
|
471
|
-
when action['do']
|
472
|
-
catch_exception = action['do'].delete('catch') if action['do']
|
473
|
-
api, arguments = action['do'].to_a.first
|
474
|
-
arguments = Utils.symbolize_keys(arguments)
|
475
|
-
|
476
|
-
begin
|
477
|
-
$results[test.hash] = Runner.perform_api_call(test, api, arguments)
|
478
|
-
rescue StandardError => e
|
479
|
-
begin
|
480
|
-
$results[test.hash] = MultiJson.load(e.message.match(/{.+}/, 1).to_s)
|
481
|
-
rescue MultiJson::ParseError
|
482
|
-
$stderr.puts "RESPONSE: Cannot parse JSON from error message: '#{e.message}'" if ENV['DEBUG']
|
483
|
-
end
|
484
|
-
|
485
|
-
if catch_exception
|
486
|
-
$stderr.puts "CATCH: '#{catch_exception}': #{e.inspect}" if ENV['DEBUG']
|
487
|
-
|
488
|
-
if 'param' == catch_exception
|
489
|
-
assert_equal 'ArgumentError', e.class.to_s
|
490
|
-
else
|
491
|
-
if e.class.to_s =~ /Elasticsearch/
|
492
|
-
case catch_exception
|
493
|
-
when 'missing'
|
494
|
-
assert_match /\[404\]/, e.message
|
495
|
-
when 'conflict'
|
496
|
-
assert_match /\[409\]/, e.message
|
497
|
-
when 'request'
|
498
|
-
assert_match /\[4\d\d\]|\[5\d\d\]/, e.message
|
499
|
-
when /\/.+\//
|
500
|
-
assert_match Regexp.new(catch_exception.tr('/', '')), e.message
|
501
|
-
end
|
502
|
-
else
|
503
|
-
raise e
|
504
|
-
end
|
505
|
-
end
|
506
|
-
|
507
|
-
else
|
508
|
-
raise e
|
509
|
-
end
|
510
|
-
end
|
511
|
-
|
512
|
-
# --- Evaluate predicates -------------------------------------
|
513
|
-
#
|
514
|
-
when property = action['is_true']
|
515
|
-
result = Runner.evaluate(test, property)
|
516
|
-
$stderr.puts "CHECK: Expected '#{property}' to be true, is: #{result.inspect}" if ENV['DEBUG']
|
517
|
-
assert(result, "Property '#{property}' should be true, is: #{result.inspect}")
|
518
|
-
|
519
|
-
when property = action['is_false']
|
520
|
-
result = Runner.evaluate(test, property)
|
521
|
-
$stderr.puts "CHECK: Expected '#{property}' to be nil, false, 0 or empty string, is: #{result.inspect}" if ENV['DEBUG']
|
522
|
-
assert_block "Property '#{property}' should be nil, false, 0 or empty string, but is: #{result.inspect}" do
|
523
|
-
result.nil? || result == false || result == 0 || result == ''
|
524
|
-
end
|
525
|
-
|
526
|
-
when a = action['match']
|
527
|
-
property, value = a.to_a.first
|
528
|
-
|
529
|
-
if value.is_a?(String) && value =~ %r{\s*^/\s*.*\s*/$\s*}mx # Begins and ends with /
|
530
|
-
pattern = Regexp.new(value.strip[1..-2], Regexp::EXTENDED|Regexp::MULTILINE)
|
531
|
-
else
|
532
|
-
value = Runner.fetch_or_return(value)
|
533
|
-
end
|
534
|
-
|
535
|
-
if property == '$body'
|
536
|
-
result = $results[test.hash]
|
537
|
-
else
|
538
|
-
result = Runner.evaluate(test, property)
|
539
|
-
end
|
540
|
-
|
541
|
-
if pattern
|
542
|
-
$stderr.puts "CHECK: Expected '#{property}' to match #{pattern}, is: #{result.inspect}" if ENV['DEBUG']
|
543
|
-
assert_match(pattern, result)
|
544
|
-
else
|
545
|
-
value = value.reduce({}) { |memo, (k,v)| memo[k] = Runner.fetch_or_return(v); memo } if value.is_a? Hash
|
546
|
-
$stderr.puts "CHECK: Expected '#{property}' to be '#{value}', is: #{result.inspect}" if ENV['DEBUG']
|
547
|
-
|
548
|
-
assert_equal(value, result)
|
549
|
-
end
|
550
|
-
|
551
|
-
when a = action['length']
|
552
|
-
property, value = a.to_a.first
|
553
|
-
|
554
|
-
result = Runner.evaluate(test, property)
|
555
|
-
length = result.size
|
556
|
-
$stderr.puts "CHECK: Expected '#{property}' to be #{value}, is: #{length.inspect}" if ENV['DEBUG']
|
557
|
-
assert_equal(value, length)
|
558
|
-
|
559
|
-
when a = action['lt'] || action['gt'] || action['lte'] || action['gte']
|
560
|
-
property, value = a.to_a.first
|
561
|
-
operator = case
|
562
|
-
when action['lt']
|
563
|
-
'<'
|
564
|
-
when action['gt']
|
565
|
-
'>'
|
566
|
-
when action['lte']
|
567
|
-
'<='
|
568
|
-
when action['gte']
|
569
|
-
'>='
|
570
|
-
end
|
571
|
-
|
572
|
-
result = Runner.evaluate(test, property)
|
573
|
-
message = "Expected '#{property}' to be #{operator} #{value}, is: #{result.inspect}"
|
574
|
-
|
575
|
-
$stderr.puts "CHECK: #{message}" if ENV['DEBUG']
|
576
|
-
assert_operator result, operator.to_sym, Runner.fetch_or_return(value).to_i
|
577
|
-
|
578
|
-
when stash = action['set']
|
579
|
-
property, variable = stash.to_a.first
|
580
|
-
result = Runner.evaluate(test, property)
|
581
|
-
$stderr.puts "STASH: '$#{variable}' => #{result.inspect}" if ENV['DEBUG']
|
582
|
-
Runner.set variable, result
|
583
|
-
end
|
584
|
-
end
|
585
|
-
end
|
586
|
-
end
|
587
|
-
end
|
588
|
-
end
|
589
|
-
|
590
|
-
end
|
591
|
-
|
592
|
-
end
|