elasticsearch-api 6.1.0 → 6.2.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +5 -5
- data/Gemfile +6 -0
- data/Rakefile +14 -2
- data/elasticsearch-api.gemspec +2 -2
- data/lib/elasticsearch/api.rb +2 -0
- data/lib/elasticsearch/api/actions/benchmark.rb +6 -3
- data/lib/elasticsearch/api/actions/bulk.rb +21 -14
- data/lib/elasticsearch/api/actions/cat/aliases.rb +12 -14
- data/lib/elasticsearch/api/actions/cat/allocation.rb +13 -15
- data/lib/elasticsearch/api/actions/cat/count.rb +12 -9
- data/lib/elasticsearch/api/actions/cat/fielddata.rb +14 -11
- data/lib/elasticsearch/api/actions/cat/health.rb +13 -10
- data/lib/elasticsearch/api/actions/cat/help.rb +7 -3
- data/lib/elasticsearch/api/actions/cat/indices.rb +15 -13
- data/lib/elasticsearch/api/actions/cat/master.rb +12 -9
- data/lib/elasticsearch/api/actions/cat/nodeattrs.rb +12 -8
- data/lib/elasticsearch/api/actions/cat/nodes.rb +13 -10
- data/lib/elasticsearch/api/actions/cat/params_registry.rb +44 -0
- data/lib/elasticsearch/api/actions/cat/pending_tasks.rb +12 -9
- data/lib/elasticsearch/api/actions/cat/plugins.rb +12 -8
- data/lib/elasticsearch/api/actions/cat/recovery.rb +13 -10
- data/lib/elasticsearch/api/actions/cat/repositories.rb +11 -8
- data/lib/elasticsearch/api/actions/cat/segments.rb +12 -8
- data/lib/elasticsearch/api/actions/cat/shards.rb +13 -12
- data/lib/elasticsearch/api/actions/cat/snapshots.rb +11 -9
- data/lib/elasticsearch/api/actions/cat/tasks.rb +13 -9
- data/lib/elasticsearch/api/actions/cat/templates.rb +13 -9
- data/lib/elasticsearch/api/actions/cat/thread_pool.rb +14 -11
- data/lib/elasticsearch/api/actions/cluster/allocation_explain.rb +8 -4
- data/lib/elasticsearch/api/actions/cluster/get_settings.rb +8 -6
- data/lib/elasticsearch/api/actions/cluster/health.rb +13 -11
- data/lib/elasticsearch/api/actions/cluster/params_registry.rb +44 -0
- data/lib/elasticsearch/api/actions/cluster/pending_tasks.rb +8 -4
- data/lib/elasticsearch/api/actions/cluster/put_settings.rb +6 -3
- data/lib/elasticsearch/api/actions/cluster/reroute.rb +12 -3
- data/lib/elasticsearch/api/actions/cluster/state.rb +14 -14
- data/lib/elasticsearch/api/actions/cluster/stats.rb +9 -5
- data/lib/elasticsearch/api/actions/count.rb +14 -11
- data/lib/elasticsearch/api/actions/count_percolate.rb +15 -11
- data/lib/elasticsearch/api/actions/delete.rb +14 -11
- data/lib/elasticsearch/api/actions/delete_by_query.rb +17 -13
- data/lib/elasticsearch/api/actions/delete_script.rb +10 -9
- data/lib/elasticsearch/api/actions/exists.rb +19 -16
- data/lib/elasticsearch/api/actions/explain.rb +20 -16
- data/lib/elasticsearch/api/actions/field_caps.rb +10 -8
- data/lib/elasticsearch/api/actions/field_stats.rb +11 -7
- data/lib/elasticsearch/api/actions/get.rb +21 -17
- data/lib/elasticsearch/api/actions/get_script.rb +2 -3
- data/lib/elasticsearch/api/actions/get_source.rb +17 -13
- data/lib/elasticsearch/api/actions/get_template.rb +1 -1
- data/lib/elasticsearch/api/actions/index.rb +17 -13
- data/lib/elasticsearch/api/actions/indices/analyze.rb +22 -22
- data/lib/elasticsearch/api/actions/indices/clear_cache.rb +16 -13
- data/lib/elasticsearch/api/actions/indices/close.rb +11 -10
- data/lib/elasticsearch/api/actions/indices/create.rb +10 -8
- data/lib/elasticsearch/api/actions/indices/delete.rb +11 -9
- data/lib/elasticsearch/api/actions/indices/delete_alias.rb +6 -3
- data/lib/elasticsearch/api/actions/indices/delete_template.rb +6 -3
- data/lib/elasticsearch/api/actions/indices/exists.rb +11 -11
- data/lib/elasticsearch/api/actions/indices/exists_alias.rb +11 -10
- data/lib/elasticsearch/api/actions/indices/exists_template.rb +6 -4
- data/lib/elasticsearch/api/actions/indices/exists_type.rb +11 -10
- data/lib/elasticsearch/api/actions/indices/flush.rb +11 -8
- data/lib/elasticsearch/api/actions/indices/flush_synced.rb +9 -7
- data/lib/elasticsearch/api/actions/indices/forcemerge.rb +9 -7
- data/lib/elasticsearch/api/actions/indices/freeze.rb +40 -0
- data/lib/elasticsearch/api/actions/indices/get.rb +13 -11
- data/lib/elasticsearch/api/actions/indices/get_alias.rb +11 -9
- data/lib/elasticsearch/api/actions/indices/get_aliases.rb +6 -3
- data/lib/elasticsearch/api/actions/indices/get_field_mapping.rb +11 -11
- data/lib/elasticsearch/api/actions/indices/get_mapping.rb +11 -9
- data/lib/elasticsearch/api/actions/indices/get_settings.rb +14 -12
- data/lib/elasticsearch/api/actions/indices/get_template.rb +6 -3
- data/lib/elasticsearch/api/actions/indices/get_warmer.rb +11 -9
- data/lib/elasticsearch/api/actions/indices/open.rb +12 -11
- data/lib/elasticsearch/api/actions/indices/optimize.rb +14 -11
- data/lib/elasticsearch/api/actions/indices/params_registry.rb +44 -0
- data/lib/elasticsearch/api/actions/indices/put_alias.rb +6 -3
- data/lib/elasticsearch/api/actions/indices/put_mapping.rb +13 -12
- data/lib/elasticsearch/api/actions/indices/put_settings.rb +12 -11
- data/lib/elasticsearch/api/actions/indices/put_template.rb +6 -3
- data/lib/elasticsearch/api/actions/indices/put_warmer.rb +10 -9
- data/lib/elasticsearch/api/actions/indices/recovery.rb +9 -5
- data/lib/elasticsearch/api/actions/indices/refresh.rb +10 -8
- data/lib/elasticsearch/api/actions/indices/rollover.rb +10 -10
- data/lib/elasticsearch/api/actions/indices/segments.rb +11 -9
- data/lib/elasticsearch/api/actions/indices/shard_stores.rb +11 -7
- data/lib/elasticsearch/api/actions/indices/shrink.rb +10 -10
- data/lib/elasticsearch/api/actions/indices/snapshot_index.rb +10 -9
- data/lib/elasticsearch/api/actions/indices/split.rb +16 -7
- data/lib/elasticsearch/api/actions/indices/stats.rb +34 -29
- data/lib/elasticsearch/api/actions/indices/status.rb +12 -9
- data/lib/elasticsearch/api/actions/indices/unfreeze.rb +39 -0
- data/lib/elasticsearch/api/actions/indices/update_aliases.rb +6 -3
- data/lib/elasticsearch/api/actions/indices/upgrade.rb +10 -7
- data/lib/elasticsearch/api/actions/indices/validate_query.rb +16 -13
- data/lib/elasticsearch/api/actions/ingest/delete_pipeline.rb +8 -4
- data/lib/elasticsearch/api/actions/ingest/get_pipeline.rb +6 -3
- data/lib/elasticsearch/api/actions/ingest/params_registry.rb +44 -0
- data/lib/elasticsearch/api/actions/ingest/put_pipeline.rb +8 -4
- data/lib/elasticsearch/api/actions/ingest/simulate.rb +6 -3
- data/lib/elasticsearch/api/actions/mget.rb +18 -14
- data/lib/elasticsearch/api/actions/mlt.rb +21 -19
- data/lib/elasticsearch/api/actions/mpercolate.rb +10 -7
- data/lib/elasticsearch/api/actions/msearch.rb +13 -9
- data/lib/elasticsearch/api/actions/msearch_template.rb +6 -3
- data/lib/elasticsearch/api/actions/mtermvectors.rb +17 -14
- data/lib/elasticsearch/api/actions/nodes/hot_threads.rb +11 -8
- data/lib/elasticsearch/api/actions/nodes/info.rb +23 -19
- data/lib/elasticsearch/api/actions/nodes/params_registry.rb +44 -0
- data/lib/elasticsearch/api/actions/nodes/reload_secure_settings.rb +37 -0
- data/lib/elasticsearch/api/actions/nodes/shutdown.rb +8 -5
- data/lib/elasticsearch/api/actions/nodes/stats.rb +18 -16
- data/lib/elasticsearch/api/actions/params_registry.rb +42 -0
- data/lib/elasticsearch/api/actions/percolate.rb +16 -14
- data/lib/elasticsearch/api/actions/put_script.rb +11 -10
- data/lib/elasticsearch/api/actions/put_template.rb +2 -2
- data/lib/elasticsearch/api/actions/reindex.rb +12 -8
- data/lib/elasticsearch/api/actions/render_search_template.rb +7 -4
- data/lib/elasticsearch/api/actions/scroll.rb +9 -5
- data/lib/elasticsearch/api/actions/search.rb +24 -18
- data/lib/elasticsearch/api/actions/search_exists.rb +13 -9
- data/lib/elasticsearch/api/actions/search_shards.rb +12 -8
- data/lib/elasticsearch/api/actions/search_template.rb +13 -9
- data/lib/elasticsearch/api/actions/snapshot/create.rb +8 -5
- data/lib/elasticsearch/api/actions/snapshot/create_repository.rb +9 -6
- data/lib/elasticsearch/api/actions/snapshot/delete.rb +6 -5
- data/lib/elasticsearch/api/actions/snapshot/delete_repository.rb +8 -6
- data/lib/elasticsearch/api/actions/snapshot/get.rb +9 -7
- data/lib/elasticsearch/api/actions/snapshot/get_repository.rb +8 -6
- data/lib/elasticsearch/api/actions/snapshot/params_registry.rb +44 -0
- data/lib/elasticsearch/api/actions/snapshot/restore.rb +8 -6
- data/lib/elasticsearch/api/actions/snapshot/status.rb +8 -5
- data/lib/elasticsearch/api/actions/snapshot/verify_repository.rb +9 -7
- data/lib/elasticsearch/api/actions/suggest.rb +10 -7
- data/lib/elasticsearch/api/actions/tasks/cancel.rb +10 -8
- data/lib/elasticsearch/api/actions/tasks/get.rb +6 -5
- data/lib/elasticsearch/api/actions/tasks/list.rb +13 -11
- data/lib/elasticsearch/api/actions/tasks/params_registry.rb +44 -0
- data/lib/elasticsearch/api/actions/termvectors.rb +16 -14
- data/lib/elasticsearch/api/actions/update.rb +24 -20
- data/lib/elasticsearch/api/actions/update_by_query.rb +19 -15
- data/lib/elasticsearch/api/version.rb +1 -1
- data/spec/elasticsearch/api/actions/abort_benchmark_spec.rb +17 -0
- data/spec/elasticsearch/api/actions/benchmark_spec.rb +17 -0
- data/spec/elasticsearch/api/actions/bulk_spec.rb +122 -0
- data/spec/elasticsearch/api/actions/cat/aliases_spec.rb +18 -0
- data/spec/elasticsearch/api/actions/cat/allocation_spec.rb +18 -0
- data/spec/elasticsearch/api/actions/cat/count_spec.rb +18 -0
- data/spec/elasticsearch/api/actions/cat/fielddata_spec.rb +35 -0
- data/spec/elasticsearch/api/actions/cat/health_spec.rb +18 -0
- data/spec/elasticsearch/api/actions/cat/help_spec.rb +18 -0
- data/spec/elasticsearch/api/actions/cat/indices_spec.rb +18 -0
- data/spec/elasticsearch/api/actions/cat/master_spec.rb +18 -0
- data/spec/elasticsearch/api/actions/cat/nodeattrs_spec.rb +18 -0
- data/spec/elasticsearch/api/actions/cat/nodes_spec.rb +18 -0
- data/spec/elasticsearch/api/actions/cat/pending_tasks_spec.rb +18 -0
- data/spec/elasticsearch/api/actions/cat/plugins_spec.rb +18 -0
- data/spec/elasticsearch/api/actions/cat/recovery_spec.rb +18 -0
- data/spec/elasticsearch/api/actions/cat/repositories_spec.rb +18 -0
- data/spec/elasticsearch/api/actions/cat/segments_spec.rb +18 -0
- data/spec/elasticsearch/api/actions/cat/shards_spec.rb +18 -0
- data/spec/elasticsearch/api/actions/cat/snapshot_spec.rb +18 -0
- data/spec/elasticsearch/api/actions/cat/tasks_spec.rb +18 -0
- data/spec/elasticsearch/api/actions/cat/templates_spec.rb +18 -0
- data/spec/elasticsearch/api/actions/cat/thread_pool_spec.rb +18 -0
- data/spec/elasticsearch/api/actions/clear_scroll_spec.rb +33 -0
- data/spec/elasticsearch/api/actions/cluster/allocation_explain_spec.rb +18 -0
- data/spec/elasticsearch/api/actions/cluster/get_settings_spec.rb +18 -0
- data/spec/elasticsearch/api/actions/cluster/health_spec.rb +52 -0
- data/spec/elasticsearch/api/actions/cluster/pending_tasks_spec.rb +18 -0
- data/spec/elasticsearch/api/actions/cluster/put_settings_spec.rb +18 -0
- data/spec/elasticsearch/api/actions/cluster/remote_info_spec.rb +18 -0
- data/spec/elasticsearch/api/actions/cluster/reroute_spec.rb +35 -0
- data/spec/elasticsearch/api/actions/cluster/state_spec.rb +52 -0
- data/spec/elasticsearch/api/actions/cluster/stats_spec.rb +18 -0
- data/spec/elasticsearch/api/actions/count_percolate_spec.rb +17 -0
- data/spec/elasticsearch/api/actions/count_spec.rb +49 -0
- data/spec/elasticsearch/api/actions/create_document_spec.rb +65 -0
- data/spec/elasticsearch/api/actions/delete_by_query_spec.rb +55 -0
- data/spec/elasticsearch/api/actions/delete_document_spec.rb +99 -0
- data/spec/elasticsearch/api/actions/delete_script_spec.rb +33 -0
- data/spec/elasticsearch/api/actions/delete_template_spec.rb +17 -0
- data/spec/elasticsearch/api/actions/exists_document_spec.rb +109 -0
- data/spec/elasticsearch/api/actions/explain_document_spec.rb +88 -0
- data/spec/elasticsearch/api/actions/field_caps_spec.rb +17 -0
- data/spec/elasticsearch/api/actions/field_stats_spec.rb +17 -0
- data/spec/elasticsearch/api/actions/get_document_source_spec.rb +81 -0
- data/spec/elasticsearch/api/actions/get_document_spec.rb +106 -0
- data/spec/elasticsearch/api/actions/get_script_spec.rb +39 -0
- data/spec/elasticsearch/api/actions/get_template_spec.rb +52 -0
- data/{test/unit/hashie_test.rb → spec/elasticsearch/api/actions/hashie_spec.rb} +12 -18
- data/spec/elasticsearch/api/actions/index_document_spec.rb +134 -0
- data/spec/elasticsearch/api/actions/indices/analyze_spec.rb +93 -0
- data/spec/elasticsearch/api/actions/indices/clear_cache_spec.rb +67 -0
- data/spec/elasticsearch/api/actions/indices/close_spec.rb +68 -0
- data/spec/elasticsearch/api/actions/indices/create_spec.rb +68 -0
- data/spec/elasticsearch/api/actions/indices/delete_alias_spec.rb +66 -0
- data/spec/elasticsearch/api/actions/indices/delete_mapping_spec.rb +77 -0
- data/spec/elasticsearch/api/actions/indices/delete_spec.rb +91 -0
- data/spec/elasticsearch/api/actions/indices/delete_template_spec.rb +69 -0
- data/spec/elasticsearch/api/actions/indices/delete_warmer_spec.rb +86 -0
- data/spec/elasticsearch/api/actions/indices/exists_alias_spec.rb +91 -0
- data/spec/elasticsearch/api/actions/indices/exists_spec.rb +91 -0
- data/spec/elasticsearch/api/actions/indices/exists_template_spec.rb +76 -0
- data/spec/elasticsearch/api/actions/indices/exists_type_spec.rb +91 -0
- data/spec/elasticsearch/api/actions/indices/flush_spec.rb +74 -0
- data/spec/elasticsearch/api/actions/indices/flush_synced_spec.rb +73 -0
- data/spec/elasticsearch/api/actions/indices/forcemerge_spec.rb +18 -0
- data/spec/elasticsearch/api/actions/indices/freeze_spec.rb +68 -0
- data/spec/elasticsearch/api/actions/indices/get_alias_spec.rb +44 -0
- data/spec/elasticsearch/api/actions/indices/get_aliases_spec.rb +55 -0
- data/spec/elasticsearch/api/actions/indices/get_field_mapping_spec.rb +44 -0
- data/spec/elasticsearch/api/actions/indices/get_mapping_spec.rb +66 -0
- data/spec/elasticsearch/api/actions/indices/get_settings_spec.rb +55 -0
- data/spec/elasticsearch/api/actions/indices/get_spec.rb +48 -0
- data/spec/elasticsearch/api/actions/indices/get_template_spec.rb +59 -0
- data/spec/elasticsearch/api/actions/indices/get_warmer_spec.rb +48 -0
- data/spec/elasticsearch/api/actions/indices/open_spec.rb +48 -0
- data/spec/elasticsearch/api/actions/indices/optimize_spec.rb +63 -0
- data/spec/elasticsearch/api/actions/indices/put_alias_spec.rb +72 -0
- data/spec/elasticsearch/api/actions/indices/put_mapping_spec.rb +85 -0
- data/spec/elasticsearch/api/actions/indices/put_settings_spec.rb +91 -0
- data/spec/elasticsearch/api/actions/indices/put_template_spec.rb +90 -0
- data/spec/elasticsearch/api/actions/indices/put_warmer_spec.rb +101 -0
- data/spec/elasticsearch/api/actions/indices/recovery_spec.rb +18 -0
- data/spec/elasticsearch/api/actions/indices/refresh_spec.rb +89 -0
- data/spec/elasticsearch/api/actions/indices/rollover_spec.rb +41 -0
- data/spec/elasticsearch/api/actions/indices/seal_spec.rb +18 -0
- data/spec/elasticsearch/api/actions/indices/segments_spec.rb +89 -0
- data/spec/elasticsearch/api/actions/indices/shard_stores_spec.rb +18 -0
- data/spec/elasticsearch/api/actions/indices/shrink_spec.rb +25 -0
- data/spec/elasticsearch/api/actions/indices/snapshot_index_spec.rb +89 -0
- data/spec/elasticsearch/api/actions/indices/split_spec.rb +18 -0
- data/spec/elasticsearch/api/actions/indices/stats_spec.rb +108 -0
- data/spec/elasticsearch/api/actions/indices/status_spec.rb +92 -0
- data/spec/elasticsearch/api/actions/indices/unfreeze_spec.rb +68 -0
- data/spec/elasticsearch/api/actions/indices/update_aliases_spec.rb +50 -0
- data/spec/elasticsearch/api/actions/indices/upgrade_spec.rb +18 -0
- data/spec/elasticsearch/api/actions/indices/validate_query_spec.rb +111 -0
- data/spec/elasticsearch/api/actions/info_spec.rb +17 -0
- data/spec/elasticsearch/api/actions/ingest/delete_pipeline_spec.rb +43 -0
- data/spec/elasticsearch/api/actions/ingest/get_pipeline_spec.rb +33 -0
- data/spec/elasticsearch/api/actions/ingest/put_pipeline_spec.rb +43 -0
- data/spec/elasticsearch/api/actions/ingest/simulate_spec.rb +33 -0
- data/spec/elasticsearch/api/actions/json_builders_spec.rb +68 -0
- data/spec/elasticsearch/api/actions/list_benchmarks_spec.rb +17 -0
- data/spec/elasticsearch/api/actions/mget_spec.rb +100 -0
- data/spec/elasticsearch/api/actions/mlt_spec.rb +117 -0
- data/spec/elasticsearch/api/actions/mpercolate_spec.rb +49 -0
- data/spec/elasticsearch/api/actions/msearch_spec.rb +152 -0
- data/spec/elasticsearch/api/actions/msearch_template_spec.rb +77 -0
- data/spec/elasticsearch/api/actions/mtermvectors_spec.rb +28 -0
- data/spec/elasticsearch/api/actions/nodes/hot_threads_spec.rb +44 -0
- data/spec/elasticsearch/api/actions/nodes/info_spec.rb +85 -0
- data/spec/elasticsearch/api/actions/nodes/reload_secure_settings_spec.rb +70 -0
- data/spec/elasticsearch/api/actions/nodes/shutdown_spec.rb +59 -0
- data/spec/elasticsearch/api/actions/nodes/stats_spec.rb +59 -0
- data/spec/elasticsearch/api/actions/percolate_spec.rb +67 -0
- data/spec/elasticsearch/api/actions/ping_spec.rb +58 -0
- data/spec/elasticsearch/api/actions/put_script_spec.rb +32 -0
- data/spec/elasticsearch/api/actions/put_template_spec.rb +17 -0
- data/spec/elasticsearch/api/actions/reindex_spec.rb +17 -0
- data/spec/elasticsearch/api/actions/remote/info_spec.rb +18 -0
- data/spec/elasticsearch/api/actions/render_search_template_spec.rb +17 -0
- data/spec/elasticsearch/api/actions/scoll_spec.rb +17 -0
- data/spec/elasticsearch/api/actions/search_exists_spec.rb +17 -0
- data/spec/elasticsearch/api/actions/search_shards_spec.rb +17 -0
- data/spec/elasticsearch/api/actions/search_spec.rb +131 -0
- data/spec/elasticsearch/api/actions/search_template_spec.rb +17 -0
- data/spec/elasticsearch/api/actions/snapshot/create_repository_spec.rb +34 -0
- data/spec/elasticsearch/api/actions/snapshot/create_spec.rb +34 -0
- data/spec/elasticsearch/api/actions/snapshot/delete_repository_spec.rb +33 -0
- data/spec/elasticsearch/api/actions/snapshot/delete_spec.rb +34 -0
- data/spec/elasticsearch/api/actions/snapshot/get_repository_spec.rb +18 -0
- data/spec/elasticsearch/api/actions/snapshot/get_spec.rb +34 -0
- data/spec/elasticsearch/api/actions/snapshot/restore_spec.rb +34 -0
- data/spec/elasticsearch/api/actions/snapshot/status_spec.rb +33 -0
- data/spec/elasticsearch/api/actions/snapshot/verify_repository_spec.rb +18 -0
- data/spec/elasticsearch/api/actions/suggest_spec.rb +77 -0
- data/spec/elasticsearch/api/actions/tasks/cancel_spec.rb +33 -0
- data/spec/elasticsearch/api/actions/tasks/get_spec.rb +18 -0
- data/spec/elasticsearch/api/actions/tasks/list_spec.rb +33 -0
- data/spec/elasticsearch/api/actions/termvectors_spec.rb +56 -0
- data/spec/elasticsearch/api/actions/update_by_query_spec.rb +17 -0
- data/spec/elasticsearch/api/actions/update_document_spec.rb +114 -0
- data/spec/elasticsearch/api/api_spec.rb +26 -0
- data/spec/elasticsearch/api/client_spec.rb +29 -0
- data/spec/elasticsearch/api/utils_spec.rb +413 -0
- data/spec/spec_helper.rb +72 -0
- data/test/integration/yaml_test_runner.rb +8 -5
- data/test/test_helper.rb +0 -27
- metadata +313 -295
- data/test/unit/abort_benchmark_test.rb +0 -26
- data/test/unit/api_test.rb +0 -28
- data/test/unit/benchmark_test.rb +0 -26
- data/test/unit/bulk_test.rb +0 -134
- data/test/unit/cat/aliases_test.rb +0 -26
- data/test/unit/cat/allocation_test.rb +0 -26
- data/test/unit/cat/count_test.rb +0 -26
- data/test/unit/cat/fielddata_test.rb +0 -38
- data/test/unit/cat/health_test.rb +0 -26
- data/test/unit/cat/help_test.rb +0 -26
- data/test/unit/cat/indices_test.rb +0 -26
- data/test/unit/cat/master_test.rb +0 -26
- data/test/unit/cat/nodeattrs_test.rb +0 -26
- data/test/unit/cat/nodes_test.rb +0 -26
- data/test/unit/cat/pending_tasks_test.rb +0 -26
- data/test/unit/cat/plugins_test.rb +0 -26
- data/test/unit/cat/recovery_test.rb +0 -26
- data/test/unit/cat/repositories_test.rb +0 -26
- data/test/unit/cat/segments_test.rb +0 -26
- data/test/unit/cat/shards_test.rb +0 -26
- data/test/unit/cat/snapshots_test.rb +0 -26
- data/test/unit/cat/tasks_test.rb +0 -26
- data/test/unit/cat/templates_test.rb +0 -26
- data/test/unit/cat/thread_pool_test.rb +0 -26
- data/test/unit/clear_scroll_test.rb +0 -38
- data/test/unit/client_test.rb +0 -31
- data/test/unit/cluster/allocation_explain_test.rb +0 -26
- data/test/unit/cluster/get_settings_test.rb +0 -26
- data/test/unit/cluster/health_test.rb +0 -47
- data/test/unit/cluster/pending_tasks_test.rb +0 -26
- data/test/unit/cluster/put_settings_test.rb +0 -26
- data/test/unit/cluster/remote_info_test.rb +0 -26
- data/test/unit/cluster/reroute_test.rb +0 -38
- data/test/unit/cluster/state_test.rb +0 -46
- data/test/unit/cluster/stats_test.rb +0 -26
- data/test/unit/count_percolate_test.rb +0 -26
- data/test/unit/count_test.rb +0 -46
- data/test/unit/create_document_test.rb +0 -56
- data/test/unit/delete_by_query_test.rb +0 -51
- data/test/unit/delete_document_test.rb +0 -85
- data/test/unit/delete_script_test.rb +0 -26
- data/test/unit/delete_template_test.rb +0 -26
- data/test/unit/exists_document_test.rb +0 -90
- data/test/unit/explain_document_test.rb +0 -73
- data/test/unit/field_caps_test.rb +0 -26
- data/test/unit/field_stats_test.rb +0 -26
- data/test/unit/get_document_source_test.rb +0 -71
- data/test/unit/get_document_test.rb +0 -85
- data/test/unit/get_script_test.rb +0 -26
- data/test/unit/get_template_test.rb +0 -41
- data/test/unit/index_document_test.rb +0 -92
- data/test/unit/indices/analyze_test.rb +0 -76
- data/test/unit/indices/clear_cache_test.rb +0 -54
- data/test/unit/indices/close_test.rb +0 -51
- data/test/unit/indices/create_test.rb +0 -51
- data/test/unit/indices/delete_alias_test.rb +0 -47
- data/test/unit/indices/delete_mapping_test.rb +0 -56
- data/test/unit/indices/delete_template_test.rb +0 -51
- data/test/unit/indices/delete_test.rb +0 -69
- data/test/unit/indices/delete_warmer_test.rb +0 -68
- data/test/unit/indices/exists_alias_test.rb +0 -73
- data/test/unit/indices/exists_template_test.rb +0 -59
- data/test/unit/indices/exists_test.rb +0 -71
- data/test/unit/indices/exists_type_test.rb +0 -73
- data/test/unit/indices/flush_synced_test.rb +0 -41
- data/test/unit/indices/flush_test.rb +0 -54
- data/test/unit/indices/forcemerge_test.rb +0 -26
- data/test/unit/indices/get_alias_test.rb +0 -44
- data/test/unit/indices/get_aliases_test.rb +0 -54
- data/test/unit/indices/get_field_mapping_test.rb +0 -44
- data/test/unit/indices/get_mapping_test.rb +0 -62
- data/test/unit/indices/get_settings_test.rb +0 -54
- data/test/unit/indices/get_template_test.rb +0 -43
- data/test/unit/indices/get_test.rb +0 -45
- data/test/unit/indices/get_warmer_test.rb +0 -44
- data/test/unit/indices/open_test.rb +0 -51
- data/test/unit/indices/optimize_test.rb +0 -54
- data/test/unit/indices/put_alias_test.rb +0 -59
- data/test/unit/indices/put_mapping_test.rb +0 -60
- data/test/unit/indices/put_settings_test.rb +0 -68
- data/test/unit/indices/put_template_test.rb +0 -57
- data/test/unit/indices/put_warmer_test.rb +0 -65
- data/test/unit/indices/recovery_test.rb +0 -26
- data/test/unit/indices/refresh_test.rb +0 -64
- data/test/unit/indices/rollover_test.rb +0 -38
- data/test/unit/indices/seal_test.rb +0 -25
- data/test/unit/indices/segments_test.rb +0 -64
- data/test/unit/indices/shard_stores_test.rb +0 -26
- data/test/unit/indices/shrink_test.rb +0 -33
- data/test/unit/indices/snapshot_index_test.rb +0 -64
- data/test/unit/indices/split_test.rb +0 -26
- data/test/unit/indices/stats_test.rb +0 -76
- data/test/unit/indices/status_test.rb +0 -72
- data/test/unit/indices/update_aliases_test.rb +0 -42
- data/test/unit/indices/upgrade_test.rb +0 -26
- data/test/unit/indices/validate_query_test.rb +0 -84
- data/test/unit/info_test.rb +0 -26
- data/test/unit/ingest/delete_pipeline_test.rb +0 -41
- data/test/unit/ingest/get_pipeline_test.rb +0 -35
- data/test/unit/ingest/put_pipeline_test.rb +0 -46
- data/test/unit/ingest/simulate_test.rb +0 -35
- data/test/unit/json_builders_test.rb +0 -64
- data/test/unit/list_benchmarks_test.rb +0 -26
- data/test/unit/mget_test.rb +0 -79
- data/test/unit/mlt_test.rb +0 -89
- data/test/unit/mpercolate_test.rb +0 -51
- data/test/unit/msearch_template_test.rb +0 -61
- data/test/unit/msearch_test.rb +0 -130
- data/test/unit/mtermvectors_test.rb +0 -38
- data/test/unit/nodes/hot_threads_test.rb +0 -44
- data/test/unit/nodes/info_test.rb +0 -75
- data/test/unit/nodes/shutdown_test.rb +0 -45
- data/test/unit/nodes/stats_test.rb +0 -65
- data/test/unit/percolate_test.rb +0 -56
- data/test/unit/ping_test.rb +0 -53
- data/test/unit/put_script_test.rb +0 -26
- data/test/unit/put_template_test.rb +0 -26
- data/test/unit/reindex_test.rb +0 -26
- data/test/unit/remote/info_test.rb +0 -26
- data/test/unit/render_search_template_test.rb +0 -25
- data/test/unit/scroll_test.rb +0 -26
- data/test/unit/search_exists_test.rb +0 -26
- data/test/unit/search_shards_test.rb +0 -26
- data/test/unit/search_template_test.rb +0 -26
- data/test/unit/search_test.rb +0 -116
- data/test/unit/snapshot/create_repository_test.rb +0 -38
- data/test/unit/snapshot/create_test.rb +0 -38
- data/test/unit/snapshot/delete_repository_test.rb +0 -35
- data/test/unit/snapshot/delete_test.rb +0 -38
- data/test/unit/snapshot/get_repository_test.rb +0 -26
- data/test/unit/snapshot/get_test.rb +0 -38
- data/test/unit/snapshot/restore_test.rb +0 -38
- data/test/unit/snapshot/status_test.rb +0 -38
- data/test/unit/snapshot/verify_repository_test.rb +0 -26
- data/test/unit/suggest_test.rb +0 -64
- data/test/unit/tasks/cancel_test.rb +0 -38
- data/test/unit/tasks/get_test.rb +0 -26
- data/test/unit/tasks/list_test.rb +0 -38
- data/test/unit/termvectors_test.rb +0 -47
- data/test/unit/update_by_query_test.rb +0 -26
- data/test/unit/update_document_test.rb +0 -85
- data/test/unit/utils_test.rb +0 -310
@@ -0,0 +1,29 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
describe 'API Client' do
|
4
|
+
|
5
|
+
let(:client) do
|
6
|
+
Class.new { include Elasticsearch::API }.new
|
7
|
+
end
|
8
|
+
|
9
|
+
describe '#cluster' do
|
10
|
+
|
11
|
+
it 'responds to the method' do
|
12
|
+
expect(client.respond_to?(:cluster)).to be(true)
|
13
|
+
end
|
14
|
+
end
|
15
|
+
|
16
|
+
describe '#indices' do
|
17
|
+
|
18
|
+
it 'responds to the method' do
|
19
|
+
expect(client.respond_to?(:indices)).to be(true)
|
20
|
+
end
|
21
|
+
end
|
22
|
+
|
23
|
+
describe '#bulk' do
|
24
|
+
|
25
|
+
it 'responds to the method' do
|
26
|
+
expect(client.respond_to?(:bulk)).to be(true)
|
27
|
+
end
|
28
|
+
end
|
29
|
+
end
|
@@ -0,0 +1,413 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
describe Elasticsearch::API::Utils do
|
4
|
+
|
5
|
+
let(:utils) do
|
6
|
+
Class.new { include Elasticsearch::API::Utils }.new
|
7
|
+
end
|
8
|
+
|
9
|
+
describe '#__escape' do
|
10
|
+
|
11
|
+
it 'encodes Unicode characters' do
|
12
|
+
expect(utils.__escape('中文')).to eq('%E4%B8%AD%E6%96%87')
|
13
|
+
end
|
14
|
+
|
15
|
+
it 'encodes special characters' do
|
16
|
+
expect(utils.__escape('foo bar')).to eq('foo+bar')
|
17
|
+
expect(utils.__escape('foo/bar')).to eq('foo%2Fbar')
|
18
|
+
expect(utils.__escape('foo^bar')).to eq('foo%5Ebar')
|
19
|
+
end
|
20
|
+
|
21
|
+
it 'does not encode asterisks' do
|
22
|
+
expect(utils.__escape('*')).to eq('*')
|
23
|
+
end
|
24
|
+
|
25
|
+
it 'users CGI.escape by default' do
|
26
|
+
expect(CGI).to receive(:escape).and_call_original
|
27
|
+
expect(utils.__escape('foo bar')).to eq('foo+bar')
|
28
|
+
end
|
29
|
+
|
30
|
+
it 'uses the escape_utils gem when available', unless: JRUBY do
|
31
|
+
require 'escape_utils'
|
32
|
+
expect(CGI).not_to receive(:escape)
|
33
|
+
expect(EscapeUtils).to receive(:escape_url).and_call_original
|
34
|
+
expect(utils.__escape('foo bar')).to eq('foo+bar')
|
35
|
+
end
|
36
|
+
end
|
37
|
+
|
38
|
+
describe '#__listify' do
|
39
|
+
|
40
|
+
it 'creates a list from a single value' do
|
41
|
+
expect(utils.__listify('foo')).to eq('foo')
|
42
|
+
end
|
43
|
+
|
44
|
+
it 'creates a list from an array' do
|
45
|
+
expect(utils.__listify(['foo', 'bar'])).to eq('foo,bar')
|
46
|
+
end
|
47
|
+
|
48
|
+
it 'creates a list from multiple arguments' do
|
49
|
+
expect(utils.__listify('foo', 'bar')).to eq('foo,bar')
|
50
|
+
end
|
51
|
+
|
52
|
+
it 'ignores nil values' do
|
53
|
+
expect(utils.__listify(['foo', nil, 'bar'])).to eq('foo,bar')
|
54
|
+
end
|
55
|
+
|
56
|
+
it 'ignores special characters' do
|
57
|
+
expect(utils.__listify(['foo', 'bar^bam'])).to eq('foo,bar%5Ebam')
|
58
|
+
end
|
59
|
+
|
60
|
+
context 'when the escape option is set to false' do
|
61
|
+
|
62
|
+
it 'does not escape the characters' do
|
63
|
+
expect(utils.__listify(['foo', 'bar^bam'], :escape => false)).to eq('foo,bar^bam')
|
64
|
+
end
|
65
|
+
end
|
66
|
+
end
|
67
|
+
|
68
|
+
describe '#__pathify' do
|
69
|
+
|
70
|
+
it 'creates a path from a single value' do
|
71
|
+
expect(utils.__pathify('foo')).to eq('foo')
|
72
|
+
end
|
73
|
+
|
74
|
+
it 'creates a path from an array' do
|
75
|
+
expect(utils.__pathify(['foo', 'bar'])).to eq('foo/bar')
|
76
|
+
end
|
77
|
+
|
78
|
+
it 'ignores nil values' do
|
79
|
+
expect(utils.__pathify(['foo', nil, 'bar'])).to eq('foo/bar')
|
80
|
+
end
|
81
|
+
|
82
|
+
it 'ignores empty string values' do
|
83
|
+
expect(utils.__pathify(['foo', '', 'bar'])).to eq('foo/bar')
|
84
|
+
end
|
85
|
+
end
|
86
|
+
|
87
|
+
describe '#__bulkify' do
|
88
|
+
|
89
|
+
context 'when the input is an array of hashes' do
|
90
|
+
|
91
|
+
let(:result) do
|
92
|
+
utils.__bulkify [
|
93
|
+
{ :index => { :_index => 'myindexA', :_type => 'mytype', :_id => '1', :data => { :title => 'Test' } } },
|
94
|
+
{ :update => { :_index => 'myindexB', :_type => 'mytype', :_id => '2', :data => { :doc => { :title => 'Update' } } } },
|
95
|
+
{ :delete => { :_index => 'myindexC', :_type => 'mytypeC', :_id => '3' } }
|
96
|
+
]
|
97
|
+
end
|
98
|
+
|
99
|
+
let(:expected_string) do
|
100
|
+
<<-PAYLOAD.gsub(/^\s+/, '')
|
101
|
+
{"index":{"_index":"myindexA","_type":"mytype","_id":"1"}}
|
102
|
+
{"title":"Test"}
|
103
|
+
{"update":{"_index":"myindexB","_type":"mytype","_id":"2"}}
|
104
|
+
{"doc":{"title":"Update"}}
|
105
|
+
{"delete":{"_index":"myindexC","_type":"mytypeC","_id":"3"}}
|
106
|
+
PAYLOAD
|
107
|
+
end
|
108
|
+
|
109
|
+
it 'serializes the hashes' do
|
110
|
+
expect(result).to eq(expected_string)
|
111
|
+
end
|
112
|
+
end
|
113
|
+
|
114
|
+
context 'when the input is an array of strings' do
|
115
|
+
|
116
|
+
let(:result) do
|
117
|
+
utils.__bulkify(['{"foo":"bar"}','{"moo":"bam"}'])
|
118
|
+
end
|
119
|
+
|
120
|
+
let(:expected_string) do
|
121
|
+
<<-PAYLOAD.gsub(/^\s+/, '')
|
122
|
+
{"foo":"bar"}
|
123
|
+
{"moo":"bam"}
|
124
|
+
PAYLOAD
|
125
|
+
end
|
126
|
+
|
127
|
+
it 'serializes the array of strings' do
|
128
|
+
expect(result).to eq(expected_string)
|
129
|
+
end
|
130
|
+
end
|
131
|
+
|
132
|
+
context 'when the input is an array of header/data pairs' do
|
133
|
+
|
134
|
+
let(:result) do
|
135
|
+
utils.__bulkify([{ foo: 'bar' }, { moo: 'bam' },{ foo: 'baz' }])
|
136
|
+
end
|
137
|
+
|
138
|
+
let(:expected_string) do
|
139
|
+
<<-PAYLOAD.gsub(/^\s+/, '')
|
140
|
+
{"foo":"bar"}
|
141
|
+
{"moo":"bam"}
|
142
|
+
{"foo":"baz"}
|
143
|
+
PAYLOAD
|
144
|
+
end
|
145
|
+
|
146
|
+
it 'serializes the array of strings' do
|
147
|
+
expect(result).to eq(expected_string)
|
148
|
+
end
|
149
|
+
end
|
150
|
+
|
151
|
+
context 'when the payload has the :data option' do
|
152
|
+
|
153
|
+
let(:input) do
|
154
|
+
{ index: { foo: 'bar', data: { moo: 'bam' } } }
|
155
|
+
end
|
156
|
+
|
157
|
+
let(:result) do
|
158
|
+
utils.__bulkify([input])
|
159
|
+
end
|
160
|
+
|
161
|
+
let(:expected_string) do
|
162
|
+
<<-PAYLOAD.gsub(/^\s+/, '')
|
163
|
+
{"index":{"foo":"bar"}}
|
164
|
+
{"moo":"bam"}
|
165
|
+
PAYLOAD
|
166
|
+
end
|
167
|
+
|
168
|
+
it 'does not mutate the input' do
|
169
|
+
expect(input[:index][:data]).to eq(moo: 'bam')
|
170
|
+
end
|
171
|
+
|
172
|
+
it 'serializes the array of strings' do
|
173
|
+
expect(result).to eq(expected_string)
|
174
|
+
end
|
175
|
+
end
|
176
|
+
|
177
|
+
context 'when the payload has nested :data options' do
|
178
|
+
|
179
|
+
let(:data) do
|
180
|
+
{ data: { a: 'b', data: { c: 'd' } } }
|
181
|
+
end
|
182
|
+
|
183
|
+
let(:result) do
|
184
|
+
utils.__bulkify([{ index: { foo: 'bar'} } , data])
|
185
|
+
end
|
186
|
+
|
187
|
+
let(:lines) do
|
188
|
+
result.split("\n")
|
189
|
+
end
|
190
|
+
|
191
|
+
let(:header) do
|
192
|
+
MultiJson.load(lines.first)
|
193
|
+
end
|
194
|
+
|
195
|
+
let(:data_string) do
|
196
|
+
MultiJson.load(lines.last)
|
197
|
+
end
|
198
|
+
|
199
|
+
it 'does not mutate the input' do
|
200
|
+
expect(data[:data]).to eq(a: 'b', data: { c: 'd' })
|
201
|
+
end
|
202
|
+
|
203
|
+
it 'serializes the array of strings' do
|
204
|
+
expect(header['index']['foo']).to eq('bar')
|
205
|
+
expect(data_string['data']['a']).to eq('b')
|
206
|
+
expect(data_string['data']['data']['c']).to eq('d')
|
207
|
+
end
|
208
|
+
end
|
209
|
+
end
|
210
|
+
|
211
|
+
context '#__validate_and_extract_params' do
|
212
|
+
|
213
|
+
it 'listify Arrays' do
|
214
|
+
expect(utils.__validate_and_extract_params({ foo: ['a', 'b'] }, [:foo] )).to eq(foo: 'a,b')
|
215
|
+
end
|
216
|
+
|
217
|
+
it 'does not escape the parameters' do
|
218
|
+
expect(utils.__validate_and_extract_params({ foo: ['a.*', 'b.*'] }, [:foo] )).to eq(foo: 'a.*,b.*')
|
219
|
+
end
|
220
|
+
|
221
|
+
context 'when the params are valid' do
|
222
|
+
|
223
|
+
it 'extracts the valid params from the hash' do
|
224
|
+
expect(utils.__validate_and_extract_params({ foo: 'qux' }, [:foo, :bar]) ).to eq(foo: 'qux')
|
225
|
+
end
|
226
|
+
end
|
227
|
+
|
228
|
+
context 'when the params are invalid' do
|
229
|
+
|
230
|
+
it 'raises an ArgumentError' do
|
231
|
+
expect {
|
232
|
+
utils.__validate_and_extract_params({ foo: 'qux', bam: 'mux' }, [:foo, :bar])
|
233
|
+
}.to raise_exception(ArgumentError)
|
234
|
+
end
|
235
|
+
end
|
236
|
+
|
237
|
+
context 'when COMMON_PARAMS are provided' do
|
238
|
+
|
239
|
+
it 'extracts the params' do
|
240
|
+
expect(utils.__validate_and_extract_params({ index: 'foo'}, [:foo])).to eq({})
|
241
|
+
end
|
242
|
+
end
|
243
|
+
|
244
|
+
context 'when COMMON_QUERY_PARAMS are provided' do
|
245
|
+
|
246
|
+
it 'extracts the params' do
|
247
|
+
expect(utils.__validate_and_extract_params(format: 'yaml')).to eq(format: 'yaml')
|
248
|
+
end
|
249
|
+
end
|
250
|
+
|
251
|
+
context 'when the :skip_paramter_validation option is set' do
|
252
|
+
|
253
|
+
let(:result) do
|
254
|
+
utils.__validate_and_extract_params( { foo: 'q', bam: 'm' }, [:foo, :bar], { skip_parameter_validation: true } )
|
255
|
+
end
|
256
|
+
|
257
|
+
it 'skips parameter validation' do
|
258
|
+
expect(result).to eq(foo: 'q', bam: 'm')
|
259
|
+
end
|
260
|
+
end
|
261
|
+
|
262
|
+
context 'when the module has the setting to skip parameter validation' do
|
263
|
+
|
264
|
+
around do |example|
|
265
|
+
original_value = Elasticsearch::API.settings[:skip_parameter_validation]
|
266
|
+
Elasticsearch::API.settings[:skip_parameter_validation] = true
|
267
|
+
example.run
|
268
|
+
Elasticsearch::API.settings[:skip_parameter_validation] = original_value
|
269
|
+
end
|
270
|
+
|
271
|
+
let(:result) do
|
272
|
+
utils.__validate_and_extract_params( { foo: 'q', bam: 'm' }, [:foo, :bar])
|
273
|
+
end
|
274
|
+
|
275
|
+
it 'applies the module setting' do
|
276
|
+
expect(result).to eq(foo: 'q', bam: 'm')
|
277
|
+
end
|
278
|
+
end
|
279
|
+
end
|
280
|
+
|
281
|
+
describe '#__extract_parts' do
|
282
|
+
|
283
|
+
it 'extracts parts with true value from a Hash' do
|
284
|
+
expect(utils.__extract_parts({ foo: true, moo: 'blah' }, [:foo, :bar])).to eq(['foo'])
|
285
|
+
end
|
286
|
+
|
287
|
+
it 'extracts parts with string value from a Hash' do
|
288
|
+
expect(utils.__extract_parts({ foo: 'qux', moo: 'blah' }, [:foo, :bar])).to eq(['qux'])
|
289
|
+
end
|
290
|
+
end
|
291
|
+
|
292
|
+
context '#__rescue_from_not_found' do
|
293
|
+
|
294
|
+
it 'returns false if exception class name contains \'NotFound\'' do
|
295
|
+
expect(utils.__rescue_from_not_found { raise NotFound }).to be(false)
|
296
|
+
end
|
297
|
+
|
298
|
+
it 'returns false if exception message contains \'Not Found\'' do
|
299
|
+
expect(utils.__rescue_from_not_found { raise StandardError.new "Not Found" }).to be(false)
|
300
|
+
expect(utils.__rescue_from_not_found { raise StandardError.new "NotFound" }).to be(false)
|
301
|
+
end
|
302
|
+
|
303
|
+
it 'raises the exception if the class name and message do not include \'NotFound\'' do
|
304
|
+
expect {
|
305
|
+
utils.__rescue_from_not_found { raise StandardError.new "Any other exception" }
|
306
|
+
}.to raise_exception(StandardError)
|
307
|
+
end
|
308
|
+
end
|
309
|
+
|
310
|
+
context '#__report_unsupported_parameters' do
|
311
|
+
|
312
|
+
context 'when the parameters are passed as Symbols' do
|
313
|
+
|
314
|
+
let(:arguments) do
|
315
|
+
{ foo: 'bar', moo: 'bam', baz: 'qux' }
|
316
|
+
end
|
317
|
+
|
318
|
+
let(:unsupported_params) do
|
319
|
+
[ :foo, :moo]
|
320
|
+
end
|
321
|
+
|
322
|
+
let(:message) do
|
323
|
+
message = ''
|
324
|
+
expect(Kernel).to receive(:warn) { |msg| message = msg }
|
325
|
+
utils.__report_unsupported_parameters(arguments, unsupported_params)
|
326
|
+
message
|
327
|
+
end
|
328
|
+
|
329
|
+
it 'prints the unsupported parameters' do
|
330
|
+
expect(message).to match(/You are using unsupported parameter \[\:foo\]/)
|
331
|
+
expect(message).to match(/You are using unsupported parameter \[\:moo\]/)
|
332
|
+
end
|
333
|
+
end
|
334
|
+
|
335
|
+
context 'when the parameters are passed as Hashes' do
|
336
|
+
|
337
|
+
let(:arguments) do
|
338
|
+
{ foo: 'bar', moo: 'bam', baz: 'qux' }
|
339
|
+
end
|
340
|
+
|
341
|
+
let(:unsupported_params) do
|
342
|
+
[ :foo, :moo]
|
343
|
+
end
|
344
|
+
|
345
|
+
let(:message) do
|
346
|
+
message = ''
|
347
|
+
expect(Kernel).to receive(:warn) { |msg| message = msg }
|
348
|
+
utils.__report_unsupported_parameters(arguments, unsupported_params)
|
349
|
+
message
|
350
|
+
end
|
351
|
+
|
352
|
+
it 'prints the unsupported parameters' do
|
353
|
+
expect(message).to match(/You are using unsupported parameter \[\:foo\]/)
|
354
|
+
expect(message).to match(/You are using unsupported parameter \[\:moo\]/)
|
355
|
+
end
|
356
|
+
end
|
357
|
+
|
358
|
+
context 'when the parameters are passed as a mix of Hashes and Symbols' do
|
359
|
+
|
360
|
+
let(:arguments) do
|
361
|
+
{ foo: 'bar', moo: 'bam', baz: 'qux' }
|
362
|
+
end
|
363
|
+
|
364
|
+
let(:unsupported_params) do
|
365
|
+
[ { :foo => { :explanation => 'NOT_SUPPORTED'} }, :moo ]
|
366
|
+
end
|
367
|
+
|
368
|
+
|
369
|
+
let(:message) do
|
370
|
+
message = ''
|
371
|
+
expect(Kernel).to receive(:warn) { |msg| message = msg }
|
372
|
+
utils.__report_unsupported_parameters(arguments, unsupported_params)
|
373
|
+
message
|
374
|
+
end
|
375
|
+
|
376
|
+
it 'prints the unsupported parameters' do
|
377
|
+
expect(message).to match(/You are using unsupported parameter \[\:foo\]/)
|
378
|
+
expect(message).to match(/You are using unsupported parameter \[\:moo\]/)
|
379
|
+
expect(message).to match(/NOT_SUPPORTED/)
|
380
|
+
end
|
381
|
+
end
|
382
|
+
|
383
|
+
context 'when unsupported parameters are unused' do
|
384
|
+
|
385
|
+
let(:arguments) do
|
386
|
+
{ moo: 'bam', baz: 'qux' }
|
387
|
+
end
|
388
|
+
|
389
|
+
let(:unsupported_params) do
|
390
|
+
[ :foo ]
|
391
|
+
end
|
392
|
+
|
393
|
+
it 'prints the unsupported parameters' do
|
394
|
+
expect(Kernel).not_to receive(:warn)
|
395
|
+
utils.__report_unsupported_parameters(arguments, unsupported_params)
|
396
|
+
end
|
397
|
+
end
|
398
|
+
end
|
399
|
+
|
400
|
+
describe '#__report_unsupported_method' do
|
401
|
+
|
402
|
+
let(:message) do
|
403
|
+
message = ''
|
404
|
+
expect(Kernel).to receive(:warn) { |msg| message = msg }
|
405
|
+
utils.__report_unsupported_method(:foo)
|
406
|
+
message
|
407
|
+
end
|
408
|
+
|
409
|
+
it 'prints a warning' do
|
410
|
+
expect(message).to match(/foo/)
|
411
|
+
end
|
412
|
+
end
|
413
|
+
end
|
data/spec/spec_helper.rb
ADDED
@@ -0,0 +1,72 @@
|
|
1
|
+
require 'pry-nav'
|
2
|
+
require 'elasticsearch-transport'
|
3
|
+
require 'elasticsearch-api'
|
4
|
+
|
5
|
+
require 'jbuilder' if defined?(RUBY_VERSION) && RUBY_VERSION > '1.9'
|
6
|
+
require 'jsonify'
|
7
|
+
|
8
|
+
require 'ansi'
|
9
|
+
tracer = ::Logger.new(STDERR)
|
10
|
+
tracer.formatter = lambda { |s, d, p, m| "#{m.gsub(/^.*$/) { |n| ' ' + n }.ansi(:faint)}\n" }
|
11
|
+
|
12
|
+
RUBY_1_8 = defined?(RUBY_VERSION) && RUBY_VERSION < '1.9'
|
13
|
+
JRUBY = defined?(JRUBY_VERSION)
|
14
|
+
|
15
|
+
unless defined?(ELASTICSEARCH_URL)
|
16
|
+
ELASTICSEARCH_URL = ENV['ELASTICSEARCH_URL'] || ENV['TEST_ES_SERVER'] || "localhost:#{(ENV['TEST_CLUSTER_PORT'] || 9200)}"
|
17
|
+
end
|
18
|
+
|
19
|
+
DEFAULT_CLIENT = Elasticsearch::Client.new host: ELASTICSEARCH_URL,
|
20
|
+
tracer: (ENV['QUIET'] ? nil : tracer)
|
21
|
+
|
22
|
+
module HelperModule
|
23
|
+
def self.included(context)
|
24
|
+
|
25
|
+
context.let(:client_double) do
|
26
|
+
Class.new { include Elasticsearch::API }.new.tap do |client|
|
27
|
+
expect(client).to receive(:perform_request).with(*expected_args).and_return(response_double)
|
28
|
+
end
|
29
|
+
end
|
30
|
+
|
31
|
+
context.let(:client) do
|
32
|
+
Class.new { include Elasticsearch::API }.new.tap do |client|
|
33
|
+
expect(client).to receive(:perform_request).with(*expected_args).and_return(response_double)
|
34
|
+
end
|
35
|
+
end
|
36
|
+
|
37
|
+
context.let(:response_double) do
|
38
|
+
double('response', status: 200, body: {}, headers: {})
|
39
|
+
end
|
40
|
+
end
|
41
|
+
end
|
42
|
+
|
43
|
+
RSpec.configure do |config|
|
44
|
+
config.include(HelperModule)
|
45
|
+
config.formatter = 'documentation'
|
46
|
+
config.color = true
|
47
|
+
end
|
48
|
+
|
49
|
+
if ENV['COVERAGE'] && ENV['CI'].nil? && !RUBY_1_8
|
50
|
+
require 'simplecov'
|
51
|
+
SimpleCov.start { add_filter "/test|test_/" }
|
52
|
+
end
|
53
|
+
|
54
|
+
if ENV['CI'] && !RUBY_1_8
|
55
|
+
require 'simplecov'
|
56
|
+
require 'simplecov-rcov'
|
57
|
+
SimpleCov.formatter = SimpleCov::Formatter::RcovFormatter
|
58
|
+
SimpleCov.start { add_filter "/test|test_" }
|
59
|
+
end
|
60
|
+
|
61
|
+
|
62
|
+
unless ENV["NOTURN"] || RUBY_1_8
|
63
|
+
require 'turn'
|
64
|
+
|
65
|
+
if ENV['QUIET']
|
66
|
+
Turn.config.format = :outline
|
67
|
+
Turn.config.trace = 1
|
68
|
+
end
|
69
|
+
end
|
70
|
+
|
71
|
+
class NotFound < StandardError; end
|
72
|
+
|