elasticsearch-dsl 0.1.6 → 0.1.10
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +5 -5
- data/Gemfile +30 -8
- data/LICENSE.txt +199 -10
- data/README.md +62 -27
- data/Rakefile +29 -17
- data/elasticsearch-dsl.gemspec +40 -22
- data/lib/elasticsearch/dsl/search/aggregation.rb +21 -2
- data/lib/elasticsearch/dsl/search/aggregations/avg.rb +18 -1
- data/lib/elasticsearch/dsl/search/aggregations/cardinality.rb +18 -1
- data/lib/elasticsearch/dsl/search/aggregations/children.rb +18 -1
- data/lib/elasticsearch/dsl/search/aggregations/composite.rb +60 -0
- data/lib/elasticsearch/dsl/search/aggregations/date_histogram.rb +23 -5
- data/lib/elasticsearch/dsl/search/aggregations/date_range.rb +18 -1
- data/lib/elasticsearch/dsl/search/aggregations/extended_stats.rb +18 -1
- data/lib/elasticsearch/dsl/search/aggregations/filter.rb +18 -1
- data/lib/elasticsearch/dsl/search/aggregations/filters.rb +18 -1
- data/lib/elasticsearch/dsl/search/aggregations/geo_bounds.rb +18 -1
- data/lib/elasticsearch/dsl/search/aggregations/geo_distance.rb +18 -1
- data/lib/elasticsearch/dsl/search/aggregations/geohash_grid.rb +18 -1
- data/lib/elasticsearch/dsl/search/aggregations/global.rb +17 -0
- data/lib/elasticsearch/dsl/search/aggregations/histogram.rb +18 -1
- data/lib/elasticsearch/dsl/search/aggregations/ip_range.rb +18 -1
- data/lib/elasticsearch/dsl/search/aggregations/max.rb +18 -1
- data/lib/elasticsearch/dsl/search/aggregations/min.rb +18 -1
- data/lib/elasticsearch/dsl/search/aggregations/missing.rb +17 -0
- data/lib/elasticsearch/dsl/search/aggregations/nested.rb +18 -1
- data/lib/elasticsearch/dsl/search/aggregations/percentile_ranks.rb +18 -1
- data/lib/elasticsearch/dsl/search/aggregations/percentiles.rb +18 -1
- data/lib/elasticsearch/dsl/search/aggregations/pipeline/avg_bucket.rb +17 -0
- data/lib/elasticsearch/dsl/search/aggregations/pipeline/bucket_script.rb +17 -0
- data/lib/elasticsearch/dsl/search/aggregations/pipeline/bucket_selector.rb +17 -0
- data/lib/elasticsearch/dsl/search/aggregations/pipeline/bucket_sort.rb +106 -0
- data/lib/elasticsearch/dsl/search/aggregations/pipeline/cumulative_sum.rb +17 -0
- data/lib/elasticsearch/dsl/search/aggregations/pipeline/derivative.rb +17 -0
- data/lib/elasticsearch/dsl/search/aggregations/pipeline/extended_stats_bucket.rb +17 -0
- data/lib/elasticsearch/dsl/search/aggregations/pipeline/max_bucket.rb +17 -0
- data/lib/elasticsearch/dsl/search/aggregations/pipeline/min_bucket.rb +17 -0
- data/lib/elasticsearch/dsl/search/aggregations/pipeline/moving_avg.rb +17 -0
- data/lib/elasticsearch/dsl/search/aggregations/pipeline/percentiles_bucket.rb +17 -0
- data/lib/elasticsearch/dsl/search/aggregations/pipeline/serial_diff.rb +17 -0
- data/lib/elasticsearch/dsl/search/aggregations/pipeline/stats_bucket.rb +17 -0
- data/lib/elasticsearch/dsl/search/aggregations/pipeline/sum_bucket.rb +17 -0
- data/lib/elasticsearch/dsl/search/aggregations/range.rb +18 -1
- data/lib/elasticsearch/dsl/search/aggregations/reverse_nested.rb +18 -1
- data/lib/elasticsearch/dsl/search/aggregations/scripted_metric.rb +18 -1
- data/lib/elasticsearch/dsl/search/aggregations/significant_terms.rb +18 -1
- data/lib/elasticsearch/dsl/search/aggregations/significant_text.rb +62 -0
- data/lib/elasticsearch/dsl/search/aggregations/stats.rb +17 -0
- data/lib/elasticsearch/dsl/search/aggregations/sum.rb +18 -1
- data/lib/elasticsearch/dsl/search/aggregations/terms.rb +17 -0
- data/lib/elasticsearch/dsl/search/aggregations/top_hits.rb +18 -1
- data/lib/elasticsearch/dsl/search/aggregations/value_count.rb +18 -1
- data/lib/elasticsearch/dsl/search/base_aggregation_component.rb +20 -1
- data/lib/elasticsearch/dsl/search/base_component.rb +30 -1
- data/lib/elasticsearch/dsl/search/base_compound_filter_component.rb +20 -1
- data/lib/elasticsearch/dsl/search/collapse.rb +95 -0
- data/lib/elasticsearch/dsl/search/filter.rb +21 -2
- data/lib/elasticsearch/dsl/search/filters/and.rb +18 -1
- data/lib/elasticsearch/dsl/search/filters/bool.rb +23 -4
- data/lib/elasticsearch/dsl/search/filters/exists.rb +18 -1
- data/lib/elasticsearch/dsl/search/filters/geo_bounding_box.rb +18 -1
- data/lib/elasticsearch/dsl/search/filters/geo_distance.rb +18 -1
- data/lib/elasticsearch/dsl/search/filters/geo_distance_range.rb +18 -1
- data/lib/elasticsearch/dsl/search/filters/geo_polygon.rb +18 -1
- data/lib/elasticsearch/dsl/search/filters/geo_shape.rb +18 -1
- data/lib/elasticsearch/dsl/search/filters/geohash_cell.rb +18 -1
- data/lib/elasticsearch/dsl/search/filters/has_child.rb +18 -1
- data/lib/elasticsearch/dsl/search/filters/has_parent.rb +18 -1
- data/lib/elasticsearch/dsl/search/filters/ids.rb +18 -1
- data/lib/elasticsearch/dsl/search/filters/indices.rb +19 -2
- data/lib/elasticsearch/dsl/search/filters/limit.rb +18 -1
- data/lib/elasticsearch/dsl/search/filters/match_all.rb +18 -1
- data/lib/elasticsearch/dsl/search/filters/missing.rb +18 -1
- data/lib/elasticsearch/dsl/search/filters/nested.rb +27 -1
- data/lib/elasticsearch/dsl/search/filters/not.rb +21 -2
- data/lib/elasticsearch/dsl/search/filters/or.rb +18 -1
- data/lib/elasticsearch/dsl/search/filters/prefix.rb +18 -1
- data/lib/elasticsearch/dsl/search/filters/query.rb +18 -1
- data/lib/elasticsearch/dsl/search/filters/range.rb +18 -1
- data/lib/elasticsearch/dsl/search/filters/regexp.rb +18 -1
- data/lib/elasticsearch/dsl/search/filters/script.rb +18 -1
- data/lib/elasticsearch/dsl/search/filters/term.rb +18 -1
- data/lib/elasticsearch/dsl/search/filters/terms.rb +18 -1
- data/lib/elasticsearch/dsl/search/filters/type.rb +18 -1
- data/lib/elasticsearch/dsl/search/highlight.rb +18 -1
- data/lib/elasticsearch/dsl/search/options.rb +20 -2
- data/lib/elasticsearch/dsl/search/queries/bool.rb +24 -7
- data/lib/elasticsearch/dsl/search/queries/boosting.rb +18 -1
- data/lib/elasticsearch/dsl/search/queries/common.rb +18 -1
- data/lib/elasticsearch/dsl/search/queries/constant_score.rb +18 -1
- data/lib/elasticsearch/dsl/search/queries/dis_max.rb +18 -1
- data/lib/elasticsearch/dsl/search/queries/exists.rb +17 -0
- data/lib/elasticsearch/dsl/search/queries/filtered.rb +18 -1
- data/lib/elasticsearch/dsl/search/queries/function_score.rb +19 -1
- data/lib/elasticsearch/dsl/search/queries/fuzzy.rb +18 -1
- data/lib/elasticsearch/dsl/search/queries/fuzzy_like_this.rb +18 -1
- data/lib/elasticsearch/dsl/search/queries/fuzzy_like_this_field.rb +18 -1
- data/lib/elasticsearch/dsl/search/queries/geo_shape.rb +18 -1
- data/lib/elasticsearch/dsl/search/queries/has_child.rb +18 -1
- data/lib/elasticsearch/dsl/search/queries/has_parent.rb +18 -1
- data/lib/elasticsearch/dsl/search/queries/ids.rb +18 -1
- data/lib/elasticsearch/dsl/search/queries/indices.rb +18 -1
- data/lib/elasticsearch/dsl/search/queries/inner_hits.rb +133 -0
- data/lib/elasticsearch/dsl/search/queries/match.rb +18 -1
- data/lib/elasticsearch/dsl/search/queries/match_all.rb +18 -1
- data/lib/elasticsearch/dsl/search/queries/match_phrase.rb +17 -0
- data/lib/elasticsearch/dsl/search/queries/match_phrase_prefix.rb +17 -0
- data/lib/elasticsearch/dsl/search/queries/more_like_this.rb +18 -1
- data/lib/elasticsearch/dsl/search/queries/multi_match.rb +18 -1
- data/lib/elasticsearch/dsl/search/queries/nested.rb +18 -1
- data/lib/elasticsearch/dsl/search/queries/prefix.rb +18 -1
- data/lib/elasticsearch/dsl/search/queries/query_string.rb +20 -4
- data/lib/elasticsearch/dsl/search/queries/range.rb +18 -1
- data/lib/elasticsearch/dsl/search/queries/regexp.rb +18 -1
- data/lib/elasticsearch/dsl/search/queries/simple_query_string.rb +18 -1
- data/lib/elasticsearch/dsl/search/queries/span_first.rb +18 -1
- data/lib/elasticsearch/dsl/search/queries/span_multi.rb +18 -1
- data/lib/elasticsearch/dsl/search/queries/span_near.rb +18 -1
- data/lib/elasticsearch/dsl/search/queries/span_not.rb +18 -1
- data/lib/elasticsearch/dsl/search/queries/span_or.rb +18 -1
- data/lib/elasticsearch/dsl/search/queries/span_term.rb +18 -1
- data/lib/elasticsearch/dsl/search/queries/template.rb +18 -1
- data/lib/elasticsearch/dsl/search/queries/term.rb +18 -1
- data/lib/elasticsearch/dsl/search/queries/terms.rb +18 -1
- data/lib/elasticsearch/dsl/search/queries/top_children.rb +18 -1
- data/lib/elasticsearch/dsl/search/queries/wildcard.rb +18 -1
- data/lib/elasticsearch/dsl/search/query.rb +21 -2
- data/lib/elasticsearch/dsl/search/sort.rb +18 -1
- data/lib/elasticsearch/dsl/search/suggest.rb +18 -1
- data/lib/elasticsearch/dsl/search.rb +46 -4
- data/lib/elasticsearch/dsl/utils.rb +17 -0
- data/lib/elasticsearch/dsl/version.rb +18 -1
- data/lib/elasticsearch/dsl.rb +19 -1
- data/lib/elasticsearch-dsl.rb +17 -0
- data/spec/elasticsearch/dsl/search/aggregations/avg_spec.rb +43 -0
- data/spec/elasticsearch/dsl/search/aggregations/cardinality_spec.rb +110 -0
- data/spec/elasticsearch/dsl/search/aggregations/children_spec.rb +66 -0
- data/spec/elasticsearch/dsl/search/aggregations/composite_spec.rb +99 -0
- data/spec/elasticsearch/dsl/search/aggregations/date_histogram_spec.rb +182 -0
- data/spec/elasticsearch/dsl/search/aggregations/date_range_spec.rb +89 -0
- data/spec/elasticsearch/dsl/search/aggregations/extended_stats_spec.rb +43 -0
- data/spec/elasticsearch/dsl/search/aggregations/filter_spec.rb +48 -0
- data/spec/elasticsearch/dsl/search/aggregations/filters_spec.rb +89 -0
- data/spec/elasticsearch/dsl/search/aggregations/geo_bounds_spec.rb +77 -0
- data/spec/elasticsearch/dsl/search/aggregations/geo_distance_spec.rb +113 -0
- data/spec/elasticsearch/dsl/search/aggregations/geo_grid_spec.rb +100 -0
- data/spec/elasticsearch/dsl/search/aggregations/global_spec.rb +62 -0
- data/spec/elasticsearch/dsl/search/aggregations/historgram_spec.rb +122 -0
- data/spec/elasticsearch/dsl/search/aggregations/ip_range_spec.rb +93 -0
- data/spec/elasticsearch/dsl/search/aggregations/max_spec.rb +43 -0
- data/spec/elasticsearch/dsl/search/aggregations/min_spec.rb +43 -0
- data/spec/elasticsearch/dsl/search/aggregations/missing_spec.rb +81 -0
- data/spec/elasticsearch/dsl/search/aggregations/nested_spec.rb +86 -0
- data/spec/elasticsearch/dsl/search/aggregations/percentile_ranks_spec.rb +126 -0
- data/spec/elasticsearch/dsl/search/aggregations/percentiles_spec.rb +125 -0
- data/spec/elasticsearch/dsl/search/aggregations/pipeline/avg_bucket_spec.rb +88 -0
- data/spec/elasticsearch/dsl/search/aggregations/pipeline/bucket_script_spec.rb +99 -0
- data/spec/elasticsearch/dsl/search/aggregations/pipeline/bucket_selector_spec.rb +88 -0
- data/spec/elasticsearch/dsl/search/aggregations/pipeline/bucket_sort_spec.rb +104 -0
- data/spec/elasticsearch/dsl/search/aggregations/pipeline/cumulative_sum_spec.rb +77 -0
- data/spec/elasticsearch/dsl/search/aggregations/pipeline/derivative_spec.rb +88 -0
- data/spec/elasticsearch/dsl/search/aggregations/pipeline/extended_stats_bucket_spec.rb +88 -0
- data/spec/elasticsearch/dsl/search/aggregations/pipeline/max_bucket_spec.rb +88 -0
- data/spec/elasticsearch/dsl/search/aggregations/pipeline/min_bucket_spec.rb +88 -0
- data/spec/elasticsearch/dsl/search/aggregations/pipeline/moving_avg_test_spec.rb +132 -0
- data/spec/elasticsearch/dsl/search/aggregations/pipeline/percentiles_bucket_spec.rb +99 -0
- data/spec/elasticsearch/dsl/search/aggregations/pipeline/serial_diff_spec.rb +99 -0
- data/spec/elasticsearch/dsl/search/aggregations/pipeline/stats_bucket_spec.rb +88 -0
- data/spec/elasticsearch/dsl/search/aggregations/pipeline/sum_bucket_spec.rb +88 -0
- data/spec/elasticsearch/dsl/search/aggregations/range_spec.rb +119 -0
- data/spec/elasticsearch/dsl/search/aggregations/reverse_nested_spec.rb +32 -0
- data/spec/elasticsearch/dsl/search/aggregations/scripted_metric_spec.rb +121 -0
- data/spec/elasticsearch/dsl/search/aggregations/significant_terms_spec.rb +176 -0
- data/spec/elasticsearch/dsl/search/aggregations/significant_text_spec.rb +176 -0
- data/spec/elasticsearch/dsl/search/aggregations/stats_spec.rb +56 -0
- data/spec/elasticsearch/dsl/search/aggregations/sum_spec.rb +43 -0
- data/spec/elasticsearch/dsl/search/aggregations/terms_spec.rb +165 -0
- data/spec/elasticsearch/dsl/search/aggregations/top_hits_spec.rb +88 -0
- data/spec/elasticsearch/dsl/search/aggregations/value_count_spec.rb +43 -0
- data/spec/elasticsearch/dsl/search/collapse_spec.rb +93 -0
- data/spec/elasticsearch/dsl/search/filters/and_spec.rb +74 -0
- data/spec/elasticsearch/dsl/search/filters/bool_spec.rb +213 -0
- data/spec/elasticsearch/dsl/search/filters/exists_spec.rb +66 -0
- data/spec/elasticsearch/dsl/search/filters/geo_bounding_box_spec.rb +144 -0
- data/spec/elasticsearch/dsl/search/filters/geo_distance_range_spec.rb +103 -0
- data/spec/elasticsearch/dsl/search/filters/geo_distance_spec.rb +126 -0
- data/spec/elasticsearch/dsl/search/filters/geo_polygon_spec.rb +66 -0
- data/spec/elasticsearch/dsl/search/filters/geo_shape_spec.rb +77 -0
- data/spec/elasticsearch/dsl/search/filters/geohash_cell_spec.rb +99 -0
- data/spec/elasticsearch/dsl/search/filters/has_child_spec.rb +139 -0
- data/spec/elasticsearch/dsl/search/filters/has_parent_spec.rb +128 -0
- data/spec/elasticsearch/dsl/search/filters/ids_spec.rb +78 -0
- data/spec/elasticsearch/dsl/search/filters/indices_spec.rb +109 -0
- data/spec/elasticsearch/dsl/search/filters/limit_spec.rb +66 -0
- data/spec/elasticsearch/dsl/search/filters/match_all_spec.rb +32 -0
- data/spec/elasticsearch/dsl/search/filters/missing_spec.rb +66 -0
- data/spec/elasticsearch/dsl/search/filters/nested_spec.rb +91 -0
- data/spec/elasticsearch/dsl/search/filters/not_spec.rb +59 -0
- data/spec/elasticsearch/dsl/search/filters/or_spec.rb +75 -0
- data/spec/elasticsearch/dsl/search/filters/prefix_spec.rb +46 -0
- data/spec/elasticsearch/dsl/search/filters/query_spec.rb +59 -0
- data/spec/elasticsearch/dsl/search/filters/range_spec.rb +111 -0
- data/spec/elasticsearch/dsl/search/filters/regexp_spec.rb +88 -0
- data/spec/elasticsearch/dsl/search/filters/script_spec.rb +77 -0
- data/spec/elasticsearch/dsl/search/filters/term_spec.rb +57 -0
- data/spec/elasticsearch/dsl/search/filters/terms_spec.rb +46 -0
- data/spec/elasticsearch/dsl/search/filters/type_spec.rb +66 -0
- data/spec/elasticsearch/dsl/search/queries/bool_spec.rb +267 -0
- data/spec/elasticsearch/dsl/search/queries/boosting_spec.rb +90 -0
- data/spec/elasticsearch/dsl/search/queries/common_spec.rb +132 -0
- data/spec/elasticsearch/dsl/search/queries/constant_score_spec.rb +90 -0
- data/spec/elasticsearch/dsl/search/queries/dis_max_spec.rb +88 -0
- data/spec/elasticsearch/dsl/search/queries/exists_spec.rb +66 -0
- data/spec/elasticsearch/dsl/search/queries/filtered_spec.rb +93 -0
- data/spec/elasticsearch/dsl/search/queries/function_score_spec.rb +175 -0
- data/spec/elasticsearch/dsl/search/queries/fuzzy_like_this_field_spec.rb +132 -0
- data/spec/elasticsearch/dsl/search/queries/fuzzy_like_this_spec.rb +134 -0
- data/spec/elasticsearch/dsl/search/queries/fuzzy_spec.rb +110 -0
- data/spec/elasticsearch/dsl/search/queries/geo_shape_spec.rb +77 -0
- data/spec/elasticsearch/dsl/search/queries/has_child_spec.rb +126 -0
- data/spec/elasticsearch/dsl/search/queries/has_parent_spec.rb +100 -0
- data/spec/elasticsearch/dsl/search/queries/ids_spec.rb +78 -0
- data/spec/elasticsearch/dsl/search/queries/indices_spec.rb +89 -0
- data/spec/elasticsearch/dsl/search/queries/inner_hits_spec.rb +144 -0
- data/spec/elasticsearch/dsl/search/queries/match_all_spec.rb +66 -0
- data/spec/elasticsearch/dsl/search/queries/match_phrase_prefix_spec.rb +103 -0
- data/spec/elasticsearch/dsl/search/queries/match_phrase_spec.rb +114 -0
- data/spec/elasticsearch/dsl/search/queries/match_spec.rb +107 -0
- data/spec/elasticsearch/dsl/search/queries/more_like_this_spec.rb +87 -0
- data/spec/elasticsearch/dsl/search/queries/multi_match_spec.rb +74 -0
- data/spec/elasticsearch/dsl/search/queries/nested_spec.rb +98 -0
- data/spec/elasticsearch/dsl/search/queries/prefix_spec.rb +70 -0
- data/spec/elasticsearch/dsl/search/queries/query_string_spec.rb +85 -0
- data/spec/elasticsearch/dsl/search/queries/range_spec.rb +78 -0
- data/spec/elasticsearch/dsl/search/queries/regexp_spec.rb +82 -0
- data/spec/elasticsearch/dsl/search/queries/simple_query_string_spec.rb +74 -0
- data/spec/elasticsearch/dsl/search/queries/span_first_spec.rb +69 -0
- data/spec/elasticsearch/dsl/search/queries/span_multi_spec.rb +69 -0
- data/spec/elasticsearch/dsl/search/queries/span_near_spec.rb +72 -0
- data/spec/elasticsearch/dsl/search/queries/span_not_spec.rb +73 -0
- data/spec/elasticsearch/dsl/search/queries/span_or_spec.rb +69 -0
- data/spec/elasticsearch/dsl/search/queries/span_term_spec.rb +46 -0
- data/spec/elasticsearch/dsl/search/queries/template_spec.rb +84 -0
- data/spec/elasticsearch/dsl/search/queries/term_spec.rb +57 -0
- data/spec/elasticsearch/dsl/search/queries/terms_spec.rb +46 -0
- data/spec/elasticsearch/dsl/search/queries/top_children_spec.rb +93 -0
- data/spec/elasticsearch/dsl/search/queries/wildcard_spec.rb +81 -0
- data/spec/elasticsearch/dsl/search_spec.rb +385 -0
- data/spec/spec_helper.rb +24 -0
- data/test/integration/search_aggregation_children_test.rb +44 -37
- data/test/integration/search_aggregation_geo_test.rb +27 -16
- data/test/integration/search_aggregation_nested_test.rb +32 -20
- data/test/integration/search_aggregations_test.rb +28 -13
- data/test/integration/search_filters_test.rb +33 -22
- data/test/integration/search_options_test.rb +20 -3
- data/test/integration/search_query_test.rb +24 -11
- data/test/integration/search_size_from_test.rb +22 -5
- data/test/integration/search_sort_test.rb +20 -7
- data/test/integration/search_suggest_test.rb +30 -19
- data/test/integration/search_test.rb +21 -8
- data/test/test_helper.rb +30 -23
- data/test/unit/dsl_test.rb +17 -0
- data/test/unit/search_aggregation_test.rb +17 -0
- data/test/unit/search_base_aggregation_component_test.rb +17 -0
- data/test/unit/search_base_component_test.rb +17 -0
- data/test/unit/search_filter_test.rb +17 -0
- data/test/unit/search_highlight_test.rb +17 -0
- data/test/unit/search_options_test.rb +25 -0
- data/test/unit/search_query_test.rb +17 -0
- data/test/unit/search_size_from_test.rb +17 -0
- data/test/unit/search_sort_test.rb +17 -0
- data/test/unit/search_suggest_test.rb +17 -0
- data/test/unit/search_test.rb +24 -0
- data/test/unit/utils_test.rb +17 -0
- metadata +278 -270
- data/test/unit/aggregations/avg_test.rb +0 -24
- data/test/unit/aggregations/cardinality_test.rb +0 -40
- data/test/unit/aggregations/children_test.rb +0 -36
- data/test/unit/aggregations/date_histogram_test.rb +0 -49
- data/test/unit/aggregations/date_range_test.rb +0 -42
- data/test/unit/aggregations/extended_stats_test.rb +0 -24
- data/test/unit/aggregations/filter_test.rb +0 -31
- data/test/unit/aggregations/filters_test.rb +0 -52
- data/test/unit/aggregations/geo_bounds_test.rb +0 -37
- data/test/unit/aggregations/geo_distance_test.rb +0 -45
- data/test/unit/aggregations/geohash_grid_test.rb +0 -40
- data/test/unit/aggregations/global_test.rb +0 -38
- data/test/unit/aggregations/histogram_test.rb +0 -42
- data/test/unit/aggregations/ip_range_test.rb +0 -41
- data/test/unit/aggregations/max_test.rb +0 -24
- data/test/unit/aggregations/min_test.rb +0 -24
- data/test/unit/aggregations/missing_test.rb +0 -39
- data/test/unit/aggregations/nested_test.rb +0 -48
- data/test/unit/aggregations/percentile_ranks_test.rb +0 -41
- data/test/unit/aggregations/percentiles_test.rb +0 -40
- data/test/unit/aggregations/pipeline/avg_bucket_test.rb +0 -39
- data/test/unit/aggregations/pipeline/bucket_script_test.rb +0 -39
- data/test/unit/aggregations/pipeline/bucket_selector_test.rb +0 -38
- data/test/unit/aggregations/pipeline/cumulative_sum_test.rb +0 -37
- data/test/unit/aggregations/pipeline/derivative_test.rb +0 -39
- data/test/unit/aggregations/pipeline/extended_stats_bucket_test.rb +0 -38
- data/test/unit/aggregations/pipeline/max_bucket_test.rb +0 -38
- data/test/unit/aggregations/pipeline/min_bucket_test.rb +0 -38
- data/test/unit/aggregations/pipeline/moving_avg_test.rb +0 -41
- data/test/unit/aggregations/pipeline/percentiles_bucket_test.rb +0 -39
- data/test/unit/aggregations/pipeline/serial_diff_test.rb +0 -39
- data/test/unit/aggregations/pipeline/stats_bucket_test.rb +0 -38
- data/test/unit/aggregations/pipeline/sum_bucket_test.rb +0 -38
- data/test/unit/aggregations/range_test.rb +0 -59
- data/test/unit/aggregations/reverse_nested_test.rb +0 -20
- data/test/unit/aggregations/scripted_metric_test.rb +0 -41
- data/test/unit/aggregations/significant_terms_test.rb +0 -46
- data/test/unit/aggregations/stats_test.rb +0 -32
- data/test/unit/aggregations/sum_test.rb +0 -24
- data/test/unit/aggregations/terms_test.rb +0 -51
- data/test/unit/aggregations/top_hits_test.rb +0 -38
- data/test/unit/aggregations/value_count_test.rb +0 -24
- data/test/unit/filters/and_test.rb +0 -69
- data/test/unit/filters/bool_test.rb +0 -98
- data/test/unit/filters/exists_test.rb +0 -36
- data/test/unit/filters/geo_bounding_box_test.rb +0 -45
- data/test/unit/filters/geo_distance_range_test.rb +0 -51
- data/test/unit/filters/geo_distance_test.rb +0 -58
- data/test/unit/filters/geo_polygon_test.rb +0 -36
- data/test/unit/filters/geo_shape_test.rb +0 -37
- data/test/unit/filters/geohash_cell_test.rb +0 -43
- data/test/unit/filters/has_child_test.rb +0 -54
- data/test/unit/filters/has_parent_test.rb +0 -54
- data/test/unit/filters/ids_test.rb +0 -38
- data/test/unit/filters/indices_test.rb +0 -52
- data/test/unit/filters/limit_test.rb +0 -36
- data/test/unit/filters/match_all_test.rb +0 -20
- data/test/unit/filters/missing_test.rb +0 -38
- data/test/unit/filters/nested_test.rb +0 -40
- data/test/unit/filters/not_test.rb +0 -35
- data/test/unit/filters/or_test.rb +0 -53
- data/test/unit/filters/prefix_test.rb +0 -25
- data/test/unit/filters/query_test.rb +0 -33
- data/test/unit/filters/range_test.rb +0 -48
- data/test/unit/filters/regexp_test.rb +0 -42
- data/test/unit/filters/script_test.rb +0 -38
- data/test/unit/filters/term_test.rb +0 -27
- data/test/unit/filters/terms_test.rb +0 -24
- data/test/unit/filters/type_test.rb +0 -36
- data/test/unit/queries/bool_test.rb +0 -147
- data/test/unit/queries/boosting_test.rb +0 -41
- data/test/unit/queries/common_test.rb +0 -42
- data/test/unit/queries/constant_score_test.rb +0 -47
- data/test/unit/queries/dis_max_test.rb +0 -38
- data/test/unit/queries/exists_test.rb +0 -36
- data/test/unit/queries/filtered_test.rb +0 -51
- data/test/unit/queries/function_score_test.rb +0 -70
- data/test/unit/queries/fuzzy_like_this_field_test.rb +0 -42
- data/test/unit/queries/fuzzy_like_this_test.rb +0 -44
- data/test/unit/queries/fuzzy_test.rb +0 -40
- data/test/unit/queries/geo_shape_test.rb +0 -37
- data/test/unit/queries/has_child_test.rb +0 -55
- data/test/unit/queries/has_parent_test.rb +0 -41
- data/test/unit/queries/ids_test.rb +0 -38
- data/test/unit/queries/indices_test.rb +0 -39
- data/test/unit/queries/match_all_test.rb +0 -36
- data/test/unit/queries/match_phrase_prefix_test.rb +0 -62
- data/test/unit/queries/match_phrase_test.rb +0 -63
- data/test/unit/queries/match_test.rb +0 -65
- data/test/unit/queries/more_like_this_test.rb +0 -53
- data/test/unit/queries/multi_match_test.rb +0 -42
- data/test/unit/queries/nested_test.rb +0 -52
- data/test/unit/queries/prefix_test.rb +0 -37
- data/test/unit/queries/query_string_test.rb +0 -56
- data/test/unit/queries/range_test.rb +0 -41
- data/test/unit/queries/regexp_test.rb +0 -43
- data/test/unit/queries/simple_query_string_test.rb +0 -41
- data/test/unit/queries/span_first_test.rb +0 -36
- data/test/unit/queries/span_multi_test.rb +0 -36
- data/test/unit/queries/span_near_test.rb +0 -39
- data/test/unit/queries/span_not_test.rb +0 -40
- data/test/unit/queries/span_or_test.rb +0 -36
- data/test/unit/queries/span_term_test.rb +0 -24
- data/test/unit/queries/template_test.rb +0 -43
- data/test/unit/queries/term_test.rb +0 -27
- data/test/unit/queries/terms_test.rb +0 -24
- data/test/unit/queries/top_children_test.rb +0 -53
- data/test/unit/queries/wildcard_test.rb +0 -43
@@ -0,0 +1,74 @@
|
|
1
|
+
# Licensed to Elasticsearch B.V. under one or more contributor
|
2
|
+
# license agreements. See the NOTICE file distributed with
|
3
|
+
# this work for additional information regarding copyright
|
4
|
+
# ownership. Elasticsearch B.V. licenses this file to you under
|
5
|
+
# the Apache License, Version 2.0 (the "License"); you may
|
6
|
+
# not use this file except in compliance with the License.
|
7
|
+
# You may obtain a copy of the License at
|
8
|
+
#
|
9
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
10
|
+
#
|
11
|
+
# Unless required by applicable law or agreed to in writing,
|
12
|
+
# software distributed under the License is distributed on an
|
13
|
+
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
14
|
+
# KIND, either express or implied. See the License for the
|
15
|
+
# specific language governing permissions and limitations
|
16
|
+
# under the License.
|
17
|
+
|
18
|
+
require 'spec_helper'
|
19
|
+
|
20
|
+
describe Elasticsearch::DSL::Search::Filters::And do
|
21
|
+
|
22
|
+
let(:search) do
|
23
|
+
described_class.new
|
24
|
+
end
|
25
|
+
|
26
|
+
describe '#to_hash' do
|
27
|
+
|
28
|
+
it 'can be converted to a hash' do
|
29
|
+
expect(search.to_hash).to eq(and: {})
|
30
|
+
end
|
31
|
+
end
|
32
|
+
|
33
|
+
context 'when enumerable methods are called' do
|
34
|
+
|
35
|
+
before do
|
36
|
+
search << { term: { foo: 'bar' } }
|
37
|
+
search << { term: { moo: 'mam' } }
|
38
|
+
end
|
39
|
+
|
40
|
+
it 'behaves like an enumerable' do
|
41
|
+
expect(search.size).to eq(2)
|
42
|
+
expect(search[0][:term][:foo]).to eq('bar')
|
43
|
+
expect(search.any? { |d| d[:term] == { foo: 'bar' } }).to be(true)
|
44
|
+
end
|
45
|
+
end
|
46
|
+
|
47
|
+
describe '#initialize' do
|
48
|
+
|
49
|
+
context 'when a hash is provided' do
|
50
|
+
|
51
|
+
let(:search) do
|
52
|
+
described_class.new(filters: [ { term: { foo: 'bar' } } ])
|
53
|
+
end
|
54
|
+
|
55
|
+
it 'applies the hash' do
|
56
|
+
expect(search.to_hash).to eq(and: { filters: [ { term: { foo: 'bar' } } ] })
|
57
|
+
end
|
58
|
+
end
|
59
|
+
|
60
|
+
context 'when a block is provided' do
|
61
|
+
|
62
|
+
let(:search) do
|
63
|
+
described_class.new do
|
64
|
+
term foo: 'bar'
|
65
|
+
term moo: 'mam'
|
66
|
+
end
|
67
|
+
end
|
68
|
+
|
69
|
+
it 'executes the block' do
|
70
|
+
expect(search.to_hash).to eq(and: [ { term: { foo: 'bar' } }, { term: { moo: 'mam' } } ])
|
71
|
+
end
|
72
|
+
end
|
73
|
+
end
|
74
|
+
end
|
@@ -0,0 +1,213 @@
|
|
1
|
+
# Licensed to Elasticsearch B.V. under one or more contributor
|
2
|
+
# license agreements. See the NOTICE file distributed with
|
3
|
+
# this work for additional information regarding copyright
|
4
|
+
# ownership. Elasticsearch B.V. licenses this file to you under
|
5
|
+
# the Apache License, Version 2.0 (the "License"); you may
|
6
|
+
# not use this file except in compliance with the License.
|
7
|
+
# You may obtain a copy of the License at
|
8
|
+
#
|
9
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
10
|
+
#
|
11
|
+
# Unless required by applicable law or agreed to in writing,
|
12
|
+
# software distributed under the License is distributed on an
|
13
|
+
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
14
|
+
# KIND, either express or implied. See the License for the
|
15
|
+
# specific language governing permissions and limitations
|
16
|
+
# under the License.
|
17
|
+
|
18
|
+
require 'spec_helper'
|
19
|
+
|
20
|
+
describe Elasticsearch::DSL::Search::Filters::Bool do
|
21
|
+
|
22
|
+
let(:search) do
|
23
|
+
described_class.new
|
24
|
+
end
|
25
|
+
|
26
|
+
describe '#to_hash' do
|
27
|
+
|
28
|
+
it 'can be converted to a hash' do
|
29
|
+
expect(search.to_hash).to eq(bool: {})
|
30
|
+
end
|
31
|
+
end
|
32
|
+
|
33
|
+
describe '#initialize' do
|
34
|
+
|
35
|
+
context 'when an object instance is provided' do
|
36
|
+
|
37
|
+
let(:search) do
|
38
|
+
described_class.new.must( Elasticsearch::DSL::Search::Filters::Term.new foo: 'bar')
|
39
|
+
end
|
40
|
+
|
41
|
+
it 'applies the condition' do
|
42
|
+
expect(search.to_hash).to eq(bool: { must: [ { term: { foo: 'bar' } } ] })
|
43
|
+
end
|
44
|
+
|
45
|
+
context 'when the block calls multiple methods' do
|
46
|
+
|
47
|
+
let(:search) do
|
48
|
+
described_class.new do
|
49
|
+
must(Elasticsearch::DSL::Search::Filters::Term.new foo: 'bar')
|
50
|
+
must_not(Elasticsearch::DSL::Search::Filters::Term.new moo: 'bam')
|
51
|
+
should(Elasticsearch::DSL::Search::Filters::Term.new xoo: 'bax')
|
52
|
+
end
|
53
|
+
end
|
54
|
+
|
55
|
+
it 'executes the block' do
|
56
|
+
expect(search.to_hash).to eq(bool:
|
57
|
+
{ must: [ { term: { foo: 'bar' } } ],
|
58
|
+
must_not: [ { term: { moo: 'bam' } } ],
|
59
|
+
should: [ { term: { xoo: 'bax' } } ]
|
60
|
+
})
|
61
|
+
end
|
62
|
+
end
|
63
|
+
|
64
|
+
context 'when the block calls multiple conditions' do
|
65
|
+
|
66
|
+
let(:search) do
|
67
|
+
described_class.new do
|
68
|
+
must(Elasticsearch::DSL::Search::Filters::Term.new foo: 'bar')
|
69
|
+
must(Elasticsearch::DSL::Search::Filters::Term.new moo: 'bam')
|
70
|
+
|
71
|
+
should(Elasticsearch::DSL::Search::Filters::Term.new xoo: 'bax')
|
72
|
+
should(Elasticsearch::DSL::Search::Filters::Term.new zoo: 'baz')
|
73
|
+
end
|
74
|
+
end
|
75
|
+
|
76
|
+
it 'executes the block' do
|
77
|
+
expect(search.to_hash).to eq(bool:
|
78
|
+
{ must: [ { term: { foo: 'bar' } }, { term: { moo: 'bam' } } ],
|
79
|
+
should: [ { term: { xoo: 'bax' } }, { term: { zoo: 'baz' } } ]
|
80
|
+
})
|
81
|
+
end
|
82
|
+
end
|
83
|
+
end
|
84
|
+
|
85
|
+
context 'when a hash is provided' do
|
86
|
+
|
87
|
+
let(:search) do
|
88
|
+
described_class.new(must: [ { term: { foo: 'bar' } } ])
|
89
|
+
end
|
90
|
+
|
91
|
+
it 'applies the hash' do
|
92
|
+
expect(search.to_hash).to eq(bool: { must: [ { term: { foo: 'bar' } } ] })
|
93
|
+
end
|
94
|
+
end
|
95
|
+
|
96
|
+
context 'when a block is provided' do
|
97
|
+
|
98
|
+
let(:search) do
|
99
|
+
described_class.new do
|
100
|
+
must { term foo: 'bar' }
|
101
|
+
end
|
102
|
+
end
|
103
|
+
|
104
|
+
it 'executes the block' do
|
105
|
+
expect(search.to_hash).to eq(bool: { must: [ { term: { foo: 'bar' } } ] })
|
106
|
+
end
|
107
|
+
|
108
|
+
context 'when the block calls multiple methods' do
|
109
|
+
|
110
|
+
let(:search) do
|
111
|
+
described_class.new do
|
112
|
+
must { term foo: 'bar' }
|
113
|
+
must_not { term moo: 'bam' }
|
114
|
+
should { term xoo: 'bax' }
|
115
|
+
end
|
116
|
+
end
|
117
|
+
|
118
|
+
it 'executes the block' do
|
119
|
+
expect(search.to_hash).to eq(bool:
|
120
|
+
{ must: [ { term: { foo: 'bar' } } ],
|
121
|
+
must_not: [ { term: { moo: 'bam' } } ],
|
122
|
+
should: [ { term: { xoo: 'bax' } } ]
|
123
|
+
})
|
124
|
+
end
|
125
|
+
end
|
126
|
+
|
127
|
+
context 'when the block calls multiple conditions' do
|
128
|
+
|
129
|
+
let(:search) do
|
130
|
+
described_class.new do
|
131
|
+
must { term foo: 'bar' }
|
132
|
+
must { term moo: 'bam' }
|
133
|
+
|
134
|
+
should { term xoo: 'bax' }
|
135
|
+
should { term zoo: 'baz' }
|
136
|
+
end
|
137
|
+
end
|
138
|
+
|
139
|
+
it 'executes the block' do
|
140
|
+
expect(search.to_hash).to eq(bool:
|
141
|
+
{ must: [ { term: { foo: 'bar' } }, { term: { moo: 'bam' } } ],
|
142
|
+
should: [ { term: { xoo: 'bax' } }, { term: { zoo: 'baz' } } ]
|
143
|
+
})
|
144
|
+
end
|
145
|
+
end
|
146
|
+
end
|
147
|
+
end
|
148
|
+
|
149
|
+
context 'when options methods are called' do
|
150
|
+
|
151
|
+
describe '#minimum_should_match' do
|
152
|
+
|
153
|
+
before do
|
154
|
+
search.minimum_should_match 1
|
155
|
+
end
|
156
|
+
|
157
|
+
it 'applies the option' do
|
158
|
+
expect(search.to_hash).to eq(bool: { minimum_should_match: 1 })
|
159
|
+
end
|
160
|
+
end
|
161
|
+
end
|
162
|
+
|
163
|
+
describe '#must' do
|
164
|
+
|
165
|
+
before do
|
166
|
+
search.must { term foo: 'bar' }
|
167
|
+
end
|
168
|
+
|
169
|
+
it 'applies the condition' do
|
170
|
+
expect(search.to_hash).to eq(bool: { must: [ { term: { foo: 'bar' } } ] })
|
171
|
+
end
|
172
|
+
|
173
|
+
context 'when the method is called more than once' do
|
174
|
+
|
175
|
+
before do
|
176
|
+
search.must { term foo: 'bar' }
|
177
|
+
search.must { term moo: 'bam' }
|
178
|
+
end
|
179
|
+
|
180
|
+
it 'applies the conditions' do
|
181
|
+
expect(search.to_hash).to eq(bool: { must: [ { term: { foo: 'bar' } }, { term: { moo: 'bam' } } ] })
|
182
|
+
end
|
183
|
+
end
|
184
|
+
end
|
185
|
+
|
186
|
+
describe '#should' do
|
187
|
+
|
188
|
+
before do
|
189
|
+
search.should { term xoo: 'bax' }
|
190
|
+
end
|
191
|
+
|
192
|
+
it 'applies the condition' do
|
193
|
+
expect(search.to_hash).to eq(bool: { should: [ { term: { xoo: 'bax' } } ] })
|
194
|
+
end
|
195
|
+
end
|
196
|
+
|
197
|
+
context 'when methods are chained' do
|
198
|
+
|
199
|
+
before do
|
200
|
+
search.must { term foo: 'bar' }
|
201
|
+
search.must { term foo: 'baz' }.must { term moo: 'bam' }
|
202
|
+
search.must_not { term foo: 'biz' }
|
203
|
+
search.should { term foo: 'bor' }
|
204
|
+
end
|
205
|
+
|
206
|
+
it 'applies all the conditions' do
|
207
|
+
expect(search.to_hash).to eq(bool: { must: [{ term: { foo: 'bar' } }, { term: { foo: 'baz' } },
|
208
|
+
{ term: { moo: 'bam' } }],
|
209
|
+
must_not: [{ term: { foo: 'biz' } }],
|
210
|
+
should: [{ term: { foo: 'bor' } }] })
|
211
|
+
end
|
212
|
+
end
|
213
|
+
end
|
@@ -0,0 +1,66 @@
|
|
1
|
+
# Licensed to Elasticsearch B.V. under one or more contributor
|
2
|
+
# license agreements. See the NOTICE file distributed with
|
3
|
+
# this work for additional information regarding copyright
|
4
|
+
# ownership. Elasticsearch B.V. licenses this file to you under
|
5
|
+
# the Apache License, Version 2.0 (the "License"); you may
|
6
|
+
# not use this file except in compliance with the License.
|
7
|
+
# You may obtain a copy of the License at
|
8
|
+
#
|
9
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
10
|
+
#
|
11
|
+
# Unless required by applicable law or agreed to in writing,
|
12
|
+
# software distributed under the License is distributed on an
|
13
|
+
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
14
|
+
# KIND, either express or implied. See the License for the
|
15
|
+
# specific language governing permissions and limitations
|
16
|
+
# under the License.
|
17
|
+
|
18
|
+
require 'spec_helper'
|
19
|
+
|
20
|
+
describe Elasticsearch::DSL::Search::Filters::Exists do
|
21
|
+
|
22
|
+
let(:search) do
|
23
|
+
described_class.new
|
24
|
+
end
|
25
|
+
|
26
|
+
describe '#to_hash' do
|
27
|
+
|
28
|
+
it 'can be converted to a hash' do
|
29
|
+
expect(search.to_hash).to eq(exists: {})
|
30
|
+
end
|
31
|
+
end
|
32
|
+
|
33
|
+
context 'when options methods are called' do
|
34
|
+
|
35
|
+
let(:search) do
|
36
|
+
described_class.new(:foo)
|
37
|
+
end
|
38
|
+
|
39
|
+
describe '#field' do
|
40
|
+
|
41
|
+
before do
|
42
|
+
search.field('bar')
|
43
|
+
end
|
44
|
+
|
45
|
+
it 'applies the option' do
|
46
|
+
expect(search.to_hash[:exists][:foo][:field]).to eq('bar')
|
47
|
+
end
|
48
|
+
end
|
49
|
+
end
|
50
|
+
|
51
|
+
describe '#initialize' do
|
52
|
+
|
53
|
+
context 'when a block is provided' do
|
54
|
+
|
55
|
+
let(:search) do
|
56
|
+
described_class.new do
|
57
|
+
field 'bar'
|
58
|
+
end
|
59
|
+
end
|
60
|
+
|
61
|
+
it 'executes the block' do
|
62
|
+
expect(search.to_hash).to eq(exists: { field: 'bar' })
|
63
|
+
end
|
64
|
+
end
|
65
|
+
end
|
66
|
+
end
|
@@ -0,0 +1,144 @@
|
|
1
|
+
# Licensed to Elasticsearch B.V. under one or more contributor
|
2
|
+
# license agreements. See the NOTICE file distributed with
|
3
|
+
# this work for additional information regarding copyright
|
4
|
+
# ownership. Elasticsearch B.V. licenses this file to you under
|
5
|
+
# the Apache License, Version 2.0 (the "License"); you may
|
6
|
+
# not use this file except in compliance with the License.
|
7
|
+
# You may obtain a copy of the License at
|
8
|
+
#
|
9
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
10
|
+
#
|
11
|
+
# Unless required by applicable law or agreed to in writing,
|
12
|
+
# software distributed under the License is distributed on an
|
13
|
+
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
14
|
+
# KIND, either express or implied. See the License for the
|
15
|
+
# specific language governing permissions and limitations
|
16
|
+
# under the License.
|
17
|
+
|
18
|
+
require 'spec_helper'
|
19
|
+
|
20
|
+
describe Elasticsearch::DSL::Search::Filters::GeoBoundingBox do
|
21
|
+
|
22
|
+
describe '#to_hash' do
|
23
|
+
|
24
|
+
let(:search) do
|
25
|
+
described_class.new
|
26
|
+
end
|
27
|
+
|
28
|
+
it 'can be converted to a hash' do
|
29
|
+
expect(search.to_hash).to eq(geo_bounding_box: {})
|
30
|
+
end
|
31
|
+
end
|
32
|
+
|
33
|
+
context 'when options methods are called' do
|
34
|
+
|
35
|
+
let(:search) do
|
36
|
+
described_class.new
|
37
|
+
end
|
38
|
+
|
39
|
+
describe '#top_left' do
|
40
|
+
|
41
|
+
before do
|
42
|
+
search.top_left('bar')
|
43
|
+
end
|
44
|
+
|
45
|
+
it 'applies the option' do
|
46
|
+
expect(search.to_hash[:geo_bounding_box][:top_left]).to eq('bar')
|
47
|
+
end
|
48
|
+
end
|
49
|
+
|
50
|
+
describe '#bottom_right' do
|
51
|
+
|
52
|
+
before do
|
53
|
+
search.bottom_right('bar')
|
54
|
+
end
|
55
|
+
|
56
|
+
it 'applies the option' do
|
57
|
+
expect(search.to_hash[:geo_bounding_box][:bottom_right]).to eq('bar')
|
58
|
+
end
|
59
|
+
end
|
60
|
+
|
61
|
+
describe '#top_right' do
|
62
|
+
|
63
|
+
before do
|
64
|
+
search.top_right('bar')
|
65
|
+
end
|
66
|
+
|
67
|
+
it 'applies the option' do
|
68
|
+
expect(search.to_hash[:geo_bounding_box][:top_right]).to eq('bar')
|
69
|
+
end
|
70
|
+
end
|
71
|
+
|
72
|
+
describe '#bottom_left' do
|
73
|
+
|
74
|
+
before do
|
75
|
+
search.bottom_left('bar')
|
76
|
+
end
|
77
|
+
|
78
|
+
it 'applies the option' do
|
79
|
+
expect(search.to_hash[:geo_bounding_box][:bottom_left]).to eq('bar')
|
80
|
+
end
|
81
|
+
end
|
82
|
+
|
83
|
+
describe '#top' do
|
84
|
+
|
85
|
+
before do
|
86
|
+
search.top('bar')
|
87
|
+
end
|
88
|
+
|
89
|
+
it 'applies the option' do
|
90
|
+
expect(search.to_hash[:geo_bounding_box][:top]).to eq('bar')
|
91
|
+
end
|
92
|
+
end
|
93
|
+
|
94
|
+
describe '#left' do
|
95
|
+
|
96
|
+
before do
|
97
|
+
search.left('bar')
|
98
|
+
end
|
99
|
+
|
100
|
+
it 'applies the option' do
|
101
|
+
expect(search.to_hash[:geo_bounding_box][:left]).to eq('bar')
|
102
|
+
end
|
103
|
+
end
|
104
|
+
|
105
|
+
describe '#bottom' do
|
106
|
+
|
107
|
+
before do
|
108
|
+
search.bottom('bar')
|
109
|
+
end
|
110
|
+
|
111
|
+
it 'applies the option' do
|
112
|
+
expect(search.to_hash[:geo_bounding_box][:bottom]).to eq('bar')
|
113
|
+
end
|
114
|
+
end
|
115
|
+
|
116
|
+
describe '#right' do
|
117
|
+
|
118
|
+
before do
|
119
|
+
search.right('bar')
|
120
|
+
end
|
121
|
+
|
122
|
+
it 'applies the option' do
|
123
|
+
expect(search.to_hash[:geo_bounding_box][:right]).to eq('bar')
|
124
|
+
end
|
125
|
+
end
|
126
|
+
end
|
127
|
+
|
128
|
+
describe '#initialize' do
|
129
|
+
|
130
|
+
context 'when a block is provided' do
|
131
|
+
|
132
|
+
let(:search) do
|
133
|
+
described_class.new do
|
134
|
+
top_left [0,1]
|
135
|
+
bottom_right [3,2]
|
136
|
+
end
|
137
|
+
end
|
138
|
+
|
139
|
+
it 'executes the block' do
|
140
|
+
expect(search.to_hash).to eq(geo_bounding_box: { top_left: [0,1], bottom_right: [3,2] })
|
141
|
+
end
|
142
|
+
end
|
143
|
+
end
|
144
|
+
end
|
@@ -0,0 +1,103 @@
|
|
1
|
+
# Licensed to Elasticsearch B.V. under one or more contributor
|
2
|
+
# license agreements. See the NOTICE file distributed with
|
3
|
+
# this work for additional information regarding copyright
|
4
|
+
# ownership. Elasticsearch B.V. licenses this file to you under
|
5
|
+
# the Apache License, Version 2.0 (the "License"); you may
|
6
|
+
# not use this file except in compliance with the License.
|
7
|
+
# You may obtain a copy of the License at
|
8
|
+
#
|
9
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
10
|
+
#
|
11
|
+
# Unless required by applicable law or agreed to in writing,
|
12
|
+
# software distributed under the License is distributed on an
|
13
|
+
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
14
|
+
# KIND, either express or implied. See the License for the
|
15
|
+
# specific language governing permissions and limitations
|
16
|
+
# under the License.
|
17
|
+
|
18
|
+
require 'spec_helper'
|
19
|
+
|
20
|
+
describe Elasticsearch::DSL::Search::Filters::GeoDistanceRange do
|
21
|
+
|
22
|
+
describe '#to_hash' do
|
23
|
+
|
24
|
+
let(:search) do
|
25
|
+
described_class.new
|
26
|
+
end
|
27
|
+
|
28
|
+
it 'can be converted to a hash' do
|
29
|
+
expect(search.to_hash).to eq(geo_distance_range: {})
|
30
|
+
end
|
31
|
+
end
|
32
|
+
|
33
|
+
context 'when options methods are called' do
|
34
|
+
|
35
|
+
let(:search) do
|
36
|
+
described_class.new(:foo)
|
37
|
+
end
|
38
|
+
|
39
|
+
describe '#lat' do
|
40
|
+
|
41
|
+
before do
|
42
|
+
search.lat('bar')
|
43
|
+
end
|
44
|
+
|
45
|
+
it 'applies the option' do
|
46
|
+
expect(search.to_hash[:geo_distance_range][:foo][:lat]).to eq('bar')
|
47
|
+
end
|
48
|
+
end
|
49
|
+
|
50
|
+
describe '#lon' do
|
51
|
+
|
52
|
+
before do
|
53
|
+
search.lon('bar')
|
54
|
+
end
|
55
|
+
|
56
|
+
it 'applies the option' do
|
57
|
+
expect(search.to_hash[:geo_distance_range][:foo][:lon]).to eq('bar')
|
58
|
+
end
|
59
|
+
end
|
60
|
+
end
|
61
|
+
|
62
|
+
describe '#initialize' do
|
63
|
+
|
64
|
+
context 'when a block is provided' do
|
65
|
+
|
66
|
+
let(:search) do
|
67
|
+
described_class.new do
|
68
|
+
lat 40
|
69
|
+
lon -70
|
70
|
+
end
|
71
|
+
end
|
72
|
+
|
73
|
+
it 'executes the block' do
|
74
|
+
expect(search.to_hash).to eq(geo_distance_range: { lat: 40, lon: -70 })
|
75
|
+
end
|
76
|
+
|
77
|
+
context 'when options are also provided' do
|
78
|
+
|
79
|
+
let(:search) do
|
80
|
+
described_class.new :foo, from: '10km', to: '20km' do
|
81
|
+
lat 40
|
82
|
+
lon -70
|
83
|
+
end
|
84
|
+
end
|
85
|
+
|
86
|
+
it 'executes the block' do
|
87
|
+
expect(search.to_hash).to eq(geo_distance_range: { foo: { lat: 40, lon: -70 }, from: '10km', to: '20km' })
|
88
|
+
end
|
89
|
+
end
|
90
|
+
end
|
91
|
+
|
92
|
+
context 'when options are provided' do
|
93
|
+
|
94
|
+
let(:search) do
|
95
|
+
described_class.new(from: '10km', to: '20km', foo: { lat: 40, lon: -70 })
|
96
|
+
end
|
97
|
+
|
98
|
+
it 'executes the block' do
|
99
|
+
expect(search.to_hash).to eq(geo_distance_range: { foo: { lat: 40, lon: -70 }, from: '10km', to: '20km' })
|
100
|
+
end
|
101
|
+
end
|
102
|
+
end
|
103
|
+
end
|