chewy 0.8.4 → 0.9.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (179) hide show
  1. checksums.yaml +4 -4
  2. data/.rubocop.yml +34 -0
  3. data/.rubocop_todo.yml +44 -0
  4. data/.travis.yml +20 -60
  5. data/Appraisals +15 -40
  6. data/CHANGELOG.md +42 -0
  7. data/Gemfile +1 -0
  8. data/Guardfile +5 -5
  9. data/README.md +155 -6
  10. data/Rakefile +11 -1
  11. data/chewy.gemspec +5 -7
  12. data/gemfiles/rails.3.2.activerecord.gemfile +1 -0
  13. data/gemfiles/rails.3.2.activerecord.kaminari.gemfile +1 -0
  14. data/gemfiles/rails.3.2.activerecord.will_paginate.gemfile +1 -0
  15. data/gemfiles/rails.4.2.activerecord.gemfile +1 -0
  16. data/gemfiles/rails.4.2.activerecord.kaminari.gemfile +1 -0
  17. data/gemfiles/rails.4.2.activerecord.will_paginate.gemfile +1 -0
  18. data/gemfiles/{rails.4.2.mongoid.4.0.0.gemfile → rails.4.2.mongoid.4.0.gemfile} +2 -1
  19. data/gemfiles/{rails.4.2.mongoid.4.0.0.kaminari.gemfile → rails.4.2.mongoid.4.0.kaminari.gemfile} +2 -1
  20. data/gemfiles/{rails.4.2.mongoid.4.0.0.will_paginate.gemfile → rails.4.2.mongoid.4.0.will_paginate.gemfile} +2 -1
  21. data/gemfiles/{rails.4.2.mongoid.5.1.0.gemfile → rails.4.2.mongoid.5.1.gemfile} +2 -1
  22. data/gemfiles/{rails.4.2.mongoid.5.1.0.kaminari.gemfile → rails.4.2.mongoid.5.1.kaminari.gemfile} +2 -1
  23. data/gemfiles/{rails.4.2.mongoid.5.1.0.will_paginate.gemfile → rails.4.2.mongoid.5.1.will_paginate.gemfile} +2 -1
  24. data/gemfiles/{rails.4.0.activerecord.gemfile → rails.5.0.activerecord.gemfile} +4 -2
  25. data/gemfiles/{rails.4.0.mongoid.4.0.0.kaminari.gemfile → rails.5.0.activerecord.kaminari.gemfile} +4 -2
  26. data/gemfiles/{rails.4.0.mongoid.4.0.0.will_paginate.gemfile → rails.5.0.activerecord.will_paginate.gemfile} +4 -2
  27. data/gemfiles/{sequel.4.31.gemfile → sequel.4.38.gemfile} +3 -2
  28. data/lib/chewy.rb +24 -16
  29. data/lib/chewy/backports/deep_dup.rb +1 -1
  30. data/lib/chewy/backports/duplicable.rb +1 -0
  31. data/lib/chewy/config.rb +13 -7
  32. data/lib/chewy/errors.rb +4 -4
  33. data/lib/chewy/fields/base.rb +19 -14
  34. data/lib/chewy/fields/root.rb +11 -9
  35. data/lib/chewy/index.rb +38 -25
  36. data/lib/chewy/index/actions.rb +17 -17
  37. data/lib/chewy/index/settings.rb +3 -4
  38. data/lib/chewy/journal.rb +107 -0
  39. data/lib/chewy/journal/apply.rb +31 -0
  40. data/lib/chewy/journal/clean.rb +24 -0
  41. data/lib/chewy/journal/entry.rb +83 -0
  42. data/lib/chewy/journal/query.rb +87 -0
  43. data/lib/chewy/log_subscriber.rb +8 -8
  44. data/lib/chewy/minitest.rb +1 -0
  45. data/lib/chewy/minitest/helpers.rb +77 -0
  46. data/lib/chewy/minitest/search_index_receiver.rb +80 -0
  47. data/lib/chewy/query.rb +116 -60
  48. data/lib/chewy/query/compose.rb +5 -6
  49. data/lib/chewy/query/criteria.rb +26 -16
  50. data/lib/chewy/query/filters.rb +9 -9
  51. data/lib/chewy/query/loading.rb +2 -2
  52. data/lib/chewy/query/nodes/and.rb +3 -3
  53. data/lib/chewy/query/nodes/base.rb +1 -1
  54. data/lib/chewy/query/nodes/bool.rb +6 -4
  55. data/lib/chewy/query/nodes/equal.rb +6 -6
  56. data/lib/chewy/query/nodes/exists.rb +2 -2
  57. data/lib/chewy/query/nodes/expr.rb +2 -2
  58. data/lib/chewy/query/nodes/field.rb +35 -31
  59. data/lib/chewy/query/nodes/has_child.rb +1 -0
  60. data/lib/chewy/query/nodes/has_parent.rb +1 -0
  61. data/lib/chewy/query/nodes/has_relation.rb +11 -13
  62. data/lib/chewy/query/nodes/match_all.rb +1 -1
  63. data/lib/chewy/query/nodes/missing.rb +2 -2
  64. data/lib/chewy/query/nodes/not.rb +3 -3
  65. data/lib/chewy/query/nodes/or.rb +3 -3
  66. data/lib/chewy/query/nodes/prefix.rb +4 -3
  67. data/lib/chewy/query/nodes/query.rb +3 -3
  68. data/lib/chewy/query/nodes/range.rb +11 -11
  69. data/lib/chewy/query/nodes/raw.rb +1 -1
  70. data/lib/chewy/query/nodes/regexp.rb +15 -11
  71. data/lib/chewy/query/nodes/script.rb +6 -6
  72. data/lib/chewy/query/pagination/will_paginate.rb +2 -2
  73. data/lib/chewy/railtie.rb +3 -3
  74. data/lib/chewy/rake_helper.rb +51 -30
  75. data/lib/chewy/repository.rb +2 -2
  76. data/lib/chewy/rspec.rb +1 -1
  77. data/lib/chewy/rspec/update_index.rb +46 -47
  78. data/lib/chewy/runtime/version.rb +4 -4
  79. data/lib/chewy/search.rb +7 -5
  80. data/lib/chewy/strategy.rb +10 -8
  81. data/lib/chewy/strategy/atomic.rb +2 -2
  82. data/lib/chewy/strategy/base.rb +4 -4
  83. data/lib/chewy/strategy/bypass.rb +1 -2
  84. data/lib/chewy/strategy/sidekiq.rb +2 -0
  85. data/lib/chewy/strategy/urgent.rb +1 -1
  86. data/lib/chewy/type.rb +51 -45
  87. data/lib/chewy/type/adapter/active_record.rb +23 -12
  88. data/lib/chewy/type/adapter/base.rb +4 -4
  89. data/lib/chewy/type/adapter/mongoid.rb +6 -6
  90. data/lib/chewy/type/adapter/object.rb +15 -12
  91. data/lib/chewy/type/adapter/orm.rb +24 -15
  92. data/lib/chewy/type/adapter/sequel.rb +11 -7
  93. data/lib/chewy/type/crutch.rb +4 -3
  94. data/lib/chewy/type/import.rb +51 -32
  95. data/lib/chewy/type/mapping.rb +17 -17
  96. data/lib/chewy/type/observe.rb +9 -7
  97. data/lib/chewy/type/witchcraft.rb +62 -23
  98. data/lib/chewy/type/wrapper.rb +20 -14
  99. data/lib/chewy/version.rb +1 -1
  100. data/lib/generators/chewy/install_generator.rb +3 -3
  101. data/lib/tasks/chewy.rake +28 -23
  102. data/spec/chewy/config_spec.rb +33 -12
  103. data/spec/chewy/fields/base_spec.rb +143 -154
  104. data/spec/chewy/fields/root_spec.rb +22 -20
  105. data/spec/chewy/fields/time_fields_spec.rb +11 -9
  106. data/spec/chewy/index/actions_spec.rb +27 -4
  107. data/spec/chewy/index/aliases_spec.rb +2 -2
  108. data/spec/chewy/index/settings_spec.rb +72 -50
  109. data/spec/chewy/index_spec.rb +95 -43
  110. data/spec/chewy/journal/apply_spec.rb +120 -0
  111. data/spec/chewy/journal/entry_spec.rb +237 -0
  112. data/spec/chewy/journal_spec.rb +173 -0
  113. data/spec/chewy/minitest/helpers_spec.rb +90 -0
  114. data/spec/chewy/minitest/search_index_receiver_spec.rb +120 -0
  115. data/spec/chewy/query/criteria_spec.rb +504 -237
  116. data/spec/chewy/query/filters_spec.rb +94 -66
  117. data/spec/chewy/query/loading_spec.rb +76 -40
  118. data/spec/chewy/query/nodes/and_spec.rb +3 -7
  119. data/spec/chewy/query/nodes/bool_spec.rb +5 -13
  120. data/spec/chewy/query/nodes/equal_spec.rb +20 -20
  121. data/spec/chewy/query/nodes/exists_spec.rb +7 -7
  122. data/spec/chewy/query/nodes/has_child_spec.rb +42 -23
  123. data/spec/chewy/query/nodes/has_parent_spec.rb +42 -23
  124. data/spec/chewy/query/nodes/match_all_spec.rb +2 -2
  125. data/spec/chewy/query/nodes/missing_spec.rb +6 -5
  126. data/spec/chewy/query/nodes/not_spec.rb +3 -7
  127. data/spec/chewy/query/nodes/or_spec.rb +3 -7
  128. data/spec/chewy/query/nodes/prefix_spec.rb +6 -6
  129. data/spec/chewy/query/nodes/query_spec.rb +3 -3
  130. data/spec/chewy/query/nodes/range_spec.rb +19 -19
  131. data/spec/chewy/query/nodes/raw_spec.rb +2 -2
  132. data/spec/chewy/query/nodes/regexp_spec.rb +31 -19
  133. data/spec/chewy/query/nodes/script_spec.rb +5 -5
  134. data/spec/chewy/query/pagination/kaminari_spec.rb +2 -2
  135. data/spec/chewy/query/pagination/will_paginage_spec.rb +6 -7
  136. data/spec/chewy/query/pagination_spec.rb +2 -3
  137. data/spec/chewy/query_spec.rb +208 -145
  138. data/spec/chewy/repository_spec.rb +8 -8
  139. data/spec/chewy/rspec/update_index_spec.rb +180 -111
  140. data/spec/chewy/search_spec.rb +8 -8
  141. data/spec/chewy/strategy/active_job_spec.rb +2 -2
  142. data/spec/chewy/strategy/atomic_spec.rb +4 -1
  143. data/spec/chewy/strategy/resque_spec.rb +2 -2
  144. data/spec/chewy/strategy/sidekiq_spec.rb +2 -2
  145. data/spec/chewy/type/actions_spec.rb +1 -1
  146. data/spec/chewy/type/adapter/active_record_spec.rb +255 -149
  147. data/spec/chewy/type/adapter/mongoid_spec.rb +169 -108
  148. data/spec/chewy/type/adapter/object_spec.rb +56 -40
  149. data/spec/chewy/type/adapter/sequel_spec.rb +248 -163
  150. data/spec/chewy/type/import_spec.rb +78 -47
  151. data/spec/chewy/type/mapping_spec.rb +6 -6
  152. data/spec/chewy/type/observe_spec.rb +20 -14
  153. data/spec/chewy/type/witchcraft_spec.rb +89 -43
  154. data/spec/chewy/type_spec.rb +4 -3
  155. data/spec/chewy_spec.rb +10 -8
  156. data/spec/spec_helper.rb +3 -0
  157. data/spec/support/active_record.rb +1 -1
  158. data/spec/support/class_helpers.rb +10 -11
  159. data/spec/support/mongoid.rb +2 -2
  160. data/spec/support/sequel.rb +1 -1
  161. metadata +65 -35
  162. data/gemfiles/rails.4.0.activerecord.kaminari.gemfile +0 -14
  163. data/gemfiles/rails.4.0.activerecord.will_paginate.gemfile +0 -14
  164. data/gemfiles/rails.4.0.mongoid.4.0.0.gemfile +0 -15
  165. data/gemfiles/rails.4.0.mongoid.5.1.0.gemfile +0 -15
  166. data/gemfiles/rails.4.0.mongoid.5.1.0.kaminari.gemfile +0 -14
  167. data/gemfiles/rails.4.0.mongoid.5.1.0.will_paginate.gemfile +0 -14
  168. data/gemfiles/rails.4.1.activerecord.gemfile +0 -15
  169. data/gemfiles/rails.4.1.activerecord.kaminari.gemfile +0 -14
  170. data/gemfiles/rails.4.1.activerecord.will_paginate.gemfile +0 -14
  171. data/gemfiles/rails.4.1.mongoid.4.0.0.gemfile +0 -15
  172. data/gemfiles/rails.4.1.mongoid.4.0.0.kaminari.gemfile +0 -14
  173. data/gemfiles/rails.4.1.mongoid.4.0.0.will_paginate.gemfile +0 -14
  174. data/gemfiles/rails.4.1.mongoid.5.1.0.gemfile +0 -15
  175. data/gemfiles/rails.4.1.mongoid.5.1.0.kaminari.gemfile +0 -14
  176. data/gemfiles/rails.4.1.mongoid.5.1.0.will_paginate.gemfile +0 -14
  177. data/gemfiles/rails.5.0.0.beta3.activerecord.gemfile +0 -16
  178. data/gemfiles/rails.5.0.0.beta3.activerecord.kaminari.gemfile +0 -16
  179. data/gemfiles/rails.5.0.0.beta3.activerecord.will_paginate.gemfile +0 -15
@@ -2,17 +2,17 @@ require 'spec_helper'
2
2
 
3
3
  describe Chewy::Query::Nodes::Exists do
4
4
  describe '#__render__' do
5
- def render &block
5
+ def render(&block)
6
6
  Chewy::Query::Filters.new(&block).__render__
7
7
  end
8
8
 
9
- specify { expect(render { name? }).to eq({exists: {field: 'name'}}) }
9
+ specify { expect(render { name? }).to eq(exists: { field: 'name' }) }
10
10
 
11
- specify { expect(render { !!name? }).to eq({exists: {field: 'name'}}) }
12
- specify { expect(render { !!name }).to eq({exists: {field: 'name'}}) }
13
- specify { expect(render { name != nil }).to eq({exists: {field: 'name'}}) }
14
- specify { expect(render { !(name == nil) }).to eq({exists: {field: 'name'}}) }
11
+ specify { expect(render { !!name? }).to eq(exists: { field: 'name' }) }
12
+ specify { expect(render { !!name }).to eq(exists: { field: 'name' }) }
13
+ specify { expect(render { name != nil }).to eq(exists: { field: 'name' }) } # rubocop:disable Style/NonNilCheck
14
+ specify { expect(render { !name.nil? }).to eq(exists: { field: 'name' }) }
15
15
 
16
- specify { expect(render { ~name? }).to eq({exists: {field: 'name'}}) }
16
+ specify { expect(render { ~name? }).to eq(exists: { field: 'name' }) }
17
17
  end
18
18
  end
@@ -2,39 +2,58 @@ require 'spec_helper'
2
2
 
3
3
  describe Chewy::Query::Nodes::HasChild do
4
4
  describe '#__render__' do
5
- def render &block
5
+ def render(&block)
6
6
  Chewy::Query::Filters.new(&block).__render__
7
7
  end
8
8
 
9
- specify { expect(render { has_child('child') }).to eq({has_child: {type: 'child'}}) }
9
+ specify { expect(render { has_child('child') }).to eq(has_child: { type: 'child' }) }
10
10
 
11
+ specify do
12
+ expect(render { has_child('child').filter(term: { name: 'name' }) })
13
+ .to eq(has_child: { type: 'child', filter: { term: { name: 'name' } } })
14
+ end
15
+ specify do
16
+ expect(render { has_child('child').filter { name == 'name' } })
17
+ .to eq(has_child: { type: 'child', filter: { term: { 'name' => 'name' } } })
18
+ end
19
+ specify do
20
+ expect(render { has_child('child').filter(term: { name: 'name' }).filter { age < 42 } })
21
+ .to eq(has_child: { type: 'child', filter: { and: [{ term: { name: 'name' } }, range: { 'age' => { lt: 42 } }] } })
22
+ end
23
+ specify do
24
+ expect(render { has_child('child').filter(term: { name: 'name' }).filter { age < 42 }.filter_mode(:or) })
25
+ .to eq(has_child: { type: 'child', filter: { or: [{ term: { name: 'name' } }, range: { 'age' => { lt: 42 } }] } })
26
+ end
11
27
 
12
- specify { expect(render { has_child('child').filter(term: {name: 'name'}) })
13
- .to eq({has_child: {type: 'child', filter: {term: {name: 'name'}}}}) }
14
- specify { expect(render { has_child('child').filter{ name == 'name' } })
15
- .to eq({has_child: {type: 'child', filter: {term: {'name' => 'name'}}}}) }
16
- specify { expect(render { has_child('child').filter(term: {name: 'name'}).filter{ age < 42 } })
17
- .to eq({has_child: {type: 'child', filter: {and: [{term: {name: 'name'}}, range: {'age' => {lt: 42}}]}}}) }
18
- specify { expect(render { has_child('child').filter(term: {name: 'name'}).filter{ age < 42 }.filter_mode(:or) })
19
- .to eq({has_child: {type: 'child', filter: {or: [{term: {name: 'name'}}, range: {'age' => {lt: 42}}]}}}) }
20
-
21
- specify { expect(render { has_child('child').query(match: {name: 'name'}) })
22
- .to eq({has_child: {type: 'child', query: {match: {name: 'name'}}}}) }
23
- specify { expect(render { has_child('child').query(match: {name: 'name'}).query(match: {surname: 'surname'}) })
24
- .to eq({has_child: {type: 'child', query: {bool: {must: [{match: {name: 'name'}}, {match: {surname: 'surname'}}]}}}}) }
25
- specify { expect(render { has_child('child').query(match: {name: 'name'}).query(match: {surname: 'surname'}).query_mode(:should) })
26
- .to eq({has_child: {type: 'child', query: {bool: {should: [{match: {name: 'name'}}, {match: {surname: 'surname'}}]}}}}) }
28
+ specify do
29
+ expect(render { has_child('child').query(match: { name: 'name' }) })
30
+ .to eq(has_child: { type: 'child', query: { match: { name: 'name' } } })
31
+ end
32
+ specify do
33
+ expect(render { has_child('child').query(match: { name: 'name' }).query(match: { surname: 'surname' }) })
34
+ .to eq(has_child: { type: 'child', query: { bool: { must: [{ match: { name: 'name' } }, { match: { surname: 'surname' } }] } } })
35
+ end
36
+ specify do
37
+ expect(render { has_child('child').query(match: { name: 'name' }).query(match: { surname: 'surname' }).query_mode(:should) })
38
+ .to eq(has_child: { type: 'child', query: { bool: { should: [{ match: { name: 'name' } }, { match: { surname: 'surname' } }] } } })
39
+ end
27
40
 
28
- specify { expect(render { has_child('child').filter{ name == 'name' }.query(match: {name: 'name'}) })
29
- .to eq({has_child: {type: 'child', query: {filtered: {query: {match: {name: 'name'}}, filter: {term: {'name' => 'name'}}}}}}) }
30
- specify { expect(render { has_child('child').filter{ name == 'name' }.query(match: {name: 'name'}).filter{ age < 42 } })
31
- .to eq({has_child: {type: 'child', query: {filtered: {query: {match: {name: 'name'}}, filter: {and: [{term: {'name' => 'name'}}, range: {'age' => {lt: 42}}]}}}}}) }
41
+ specify do
42
+ expect(render { has_child('child').filter { name == 'name' }.query(match: { name: 'name' }) })
43
+ .to eq(has_child: { type: 'child', query: { filtered: { query: { match: { name: 'name' } }, filter: { term: { 'name' => 'name' } } } } })
44
+ end
45
+ specify do
46
+ expect(render { has_child('child').filter { name == 'name' }.query(match: { name: 'name' }).filter { age < 42 } })
47
+ .to eq(has_child: { type: 'child', query: { filtered: { query: { match: { name: 'name' } }, filter: { and: [{ term: { 'name' => 'name' } }, range: { 'age' => { lt: 42 } }] } } } })
48
+ end
32
49
 
33
50
  context do
34
51
  let(:name) { 'Name' }
35
52
 
36
- specify { expect(render { has_child('child').filter{ name == o{name} } })
37
- .to eq({has_child: {type: 'child', filter: {term: {'name' => 'Name'}}}}) }
53
+ specify do
54
+ expect(render { has_child('child').filter { name == o { name } } })
55
+ .to eq(has_child: { type: 'child', filter: { term: { 'name' => 'Name' } } })
56
+ end
38
57
  end
39
58
  end
40
59
  end
@@ -2,39 +2,58 @@ require 'spec_helper'
2
2
 
3
3
  describe Chewy::Query::Nodes::HasParent do
4
4
  describe '#__render__' do
5
- def render &block
5
+ def render(&block)
6
6
  Chewy::Query::Filters.new(&block).__render__
7
7
  end
8
8
 
9
- specify { expect(render { has_parent('child') }).to eq({has_parent: {type: 'child'}}) }
9
+ specify { expect(render { has_parent('child') }).to eq(has_parent: { type: 'child' }) }
10
10
 
11
+ specify do
12
+ expect(render { has_parent('child').filter(term: { name: 'name' }) })
13
+ .to eq(has_parent: { type: 'child', filter: { term: { name: 'name' } } })
14
+ end
15
+ specify do
16
+ expect(render { has_parent('child').filter { name == 'name' } })
17
+ .to eq(has_parent: { type: 'child', filter: { term: { 'name' => 'name' } } })
18
+ end
19
+ specify do
20
+ expect(render { has_parent('child').filter(term: { name: 'name' }).filter { age < 42 } })
21
+ .to eq(has_parent: { type: 'child', filter: { and: [{ term: { name: 'name' } }, range: { 'age' => { lt: 42 } }] } })
22
+ end
23
+ specify do
24
+ expect(render { has_parent('child').filter(term: { name: 'name' }).filter { age < 42 }.filter_mode(:or) })
25
+ .to eq(has_parent: { type: 'child', filter: { or: [{ term: { name: 'name' } }, range: { 'age' => { lt: 42 } }] } })
26
+ end
11
27
 
12
- specify { expect(render { has_parent('child').filter(term: {name: 'name'}) })
13
- .to eq({has_parent: {type: 'child', filter: {term: {name: 'name'}}}}) }
14
- specify { expect(render { has_parent('child').filter{ name == 'name' } })
15
- .to eq({has_parent: {type: 'child', filter: {term: {'name' => 'name'}}}}) }
16
- specify { expect(render { has_parent('child').filter(term: {name: 'name'}).filter{ age < 42 } })
17
- .to eq({has_parent: {type: 'child', filter: {and: [{term: {name: 'name'}}, range: {'age' => {lt: 42}}]}}}) }
18
- specify { expect(render { has_parent('child').filter(term: {name: 'name'}).filter{ age < 42 }.filter_mode(:or) })
19
- .to eq({has_parent: {type: 'child', filter: {or: [{term: {name: 'name'}}, range: {'age' => {lt: 42}}]}}}) }
20
-
21
- specify { expect(render { has_parent('child').query(match: {name: 'name'}) })
22
- .to eq({has_parent: {type: 'child', query: {match: {name: 'name'}}}}) }
23
- specify { expect(render { has_parent('child').query(match: {name: 'name'}).query(match: {surname: 'surname'}) })
24
- .to eq({has_parent: {type: 'child', query: {bool: {must: [{match: {name: 'name'}}, {match: {surname: 'surname'}}]}}}}) }
25
- specify { expect(render { has_parent('child').query(match: {name: 'name'}).query(match: {surname: 'surname'}).query_mode(:should) })
26
- .to eq({has_parent: {type: 'child', query: {bool: {should: [{match: {name: 'name'}}, {match: {surname: 'surname'}}]}}}}) }
28
+ specify do
29
+ expect(render { has_parent('child').query(match: { name: 'name' }) })
30
+ .to eq(has_parent: { type: 'child', query: { match: { name: 'name' } } })
31
+ end
32
+ specify do
33
+ expect(render { has_parent('child').query(match: { name: 'name' }).query(match: { surname: 'surname' }) })
34
+ .to eq(has_parent: { type: 'child', query: { bool: { must: [{ match: { name: 'name' } }, { match: { surname: 'surname' } }] } } })
35
+ end
36
+ specify do
37
+ expect(render { has_parent('child').query(match: { name: 'name' }).query(match: { surname: 'surname' }).query_mode(:should) })
38
+ .to eq(has_parent: { type: 'child', query: { bool: { should: [{ match: { name: 'name' } }, { match: { surname: 'surname' } }] } } })
39
+ end
27
40
 
28
- specify { expect(render { has_parent('child').filter{ name == 'name' }.query(match: {name: 'name'}) })
29
- .to eq({has_parent: {type: 'child', query: {filtered: {query: {match: {name: 'name'}}, filter: {term: {'name' => 'name'}}}}}}) }
30
- specify { expect(render { has_parent('child').filter{ name == 'name' }.query(match: {name: 'name'}).filter{ age < 42 } })
31
- .to eq({has_parent: {type: 'child', query: {filtered: {query: {match: {name: 'name'}}, filter: {and: [{term: {'name' => 'name'}}, range: {'age' => {lt: 42}}]}}}}}) }
41
+ specify do
42
+ expect(render { has_parent('child').filter { name == 'name' }.query(match: { name: 'name' }) })
43
+ .to eq(has_parent: { type: 'child', query: { filtered: { query: { match: { name: 'name' } }, filter: { term: { 'name' => 'name' } } } } })
44
+ end
45
+ specify do
46
+ expect(render { has_parent('child').filter { name == 'name' }.query(match: { name: 'name' }).filter { age < 42 } })
47
+ .to eq(has_parent: { type: 'child', query: { filtered: { query: { match: { name: 'name' } }, filter: { and: [{ term: { 'name' => 'name' } }, range: { 'age' => { lt: 42 } }] } } } })
48
+ end
32
49
 
33
50
  context do
34
51
  let(:name) { 'Name' }
35
52
 
36
- specify { expect(render { has_parent('child').filter{ name == o{name} } })
37
- .to eq({has_parent: {type: 'child', filter: {term: {'name' => 'Name'}}}}) }
53
+ specify do
54
+ expect(render { has_parent('child').filter { name == o { name } } })
55
+ .to eq(has_parent: { type: 'child', filter: { term: { 'name' => 'Name' } } })
56
+ end
38
57
  end
39
58
  end
40
59
  end
@@ -2,10 +2,10 @@ require 'spec_helper'
2
2
 
3
3
  describe Chewy::Query::Nodes::MatchAll do
4
4
  describe '#__render__' do
5
- def render &block
5
+ def render(&block)
6
6
  Chewy::Query::Filters.new(&block).__render__
7
7
  end
8
8
 
9
- specify { expect(render { match_all }).to eq({match_all: {}}) }
9
+ specify { expect(render { match_all }).to eq(match_all: {}) }
10
10
  end
11
11
  end
@@ -2,14 +2,15 @@ require 'spec_helper'
2
2
 
3
3
  describe Chewy::Query::Nodes::Missing do
4
4
  describe '#__render__' do
5
- def render &block
5
+ def render(&block)
6
6
  Chewy::Query::Filters.new(&block).__render__
7
7
  end
8
8
 
9
- specify { expect(render { !name }).to eq({missing: {field: 'name', existence: true, null_value: false}}) }
10
- specify { expect(render { !name? }).to eq({missing: {field: 'name', existence: true, null_value: true}}) }
11
- specify { expect(render { name == nil }).to eq({missing: {field: 'name', existence: false, null_value: true}}) }
9
+ specify { expect(render { !name }).to eq(missing: { field: 'name', existence: true, null_value: false }) }
10
+ specify { expect(render { !name? }).to eq(missing: { field: 'name', existence: true, null_value: true }) }
11
+ specify { expect(render { name == nil }).to eq(missing: { field: 'name', existence: false, null_value: true }) } # rubocop:disable Style/NilComparison
12
+ specify { expect(render { name.nil? }).to eq(missing: { field: 'name', existence: false, null_value: true }) }
12
13
 
13
- specify { expect(render { ~!name }).to eq({missing: {field: 'name', existence: true, null_value: false}}) }
14
+ specify { expect(render { ~!name }).to eq(missing: { field: 'name', existence: true, null_value: false }) }
14
15
  end
15
16
  end
@@ -2,15 +2,11 @@ require 'spec_helper'
2
2
 
3
3
  describe Chewy::Query::Nodes::Not do
4
4
  describe '#__render__' do
5
- def render &block
5
+ def render(&block)
6
6
  Chewy::Query::Filters.new(&block).__render__
7
7
  end
8
8
 
9
- specify { expect(render { !(email == 'email') }).to eq({
10
- not: {term: {'email' => 'email'}}
11
- }) }
12
- specify { expect(render { ~!(email == 'email') }).to eq({
13
- not: {filter: {term: {'email' => 'email'}}, _cache: true}
14
- }) }
9
+ specify { expect(render { !(email == 'email') }).to eq(not: { term: { 'email' => 'email' } }) }
10
+ specify { expect(render { ~!(email == 'email') }).to eq(not: { filter: { term: { 'email' => 'email' } }, _cache: true }) }
15
11
  end
16
12
  end
@@ -2,15 +2,11 @@ require 'spec_helper'
2
2
 
3
3
  describe Chewy::Query::Nodes::Or do
4
4
  describe '#__render__' do
5
- def render &block
5
+ def render(&block)
6
6
  Chewy::Query::Filters.new(&block).__render__
7
7
  end
8
8
 
9
- specify { expect(render { name? | (email == 'email') }).to eq({
10
- or: [{exists: {field: 'name'}}, {term: {'email' => 'email'}}]
11
- }) }
12
- specify { expect(render { ~(name? | (email == 'email')) }).to eq({
13
- or: {filters: [{exists: {field: 'name'}}, {term: {'email' => 'email'}}], _cache: true}
14
- }) }
9
+ specify { expect(render { name? | (email == 'email') }).to eq(or: [{ exists: { field: 'name' } }, { term: { 'email' => 'email' } }]) }
10
+ specify { expect(render { ~(name? | (email == 'email')) }).to eq(or: { filters: [{ exists: { field: 'name' } }, { term: { 'email' => 'email' } }], _cache: true }) }
15
11
  end
16
12
  end
@@ -2,15 +2,15 @@ require 'spec_helper'
2
2
 
3
3
  describe Chewy::Query::Nodes::Prefix do
4
4
  describe '#__render__' do
5
- def render &block
5
+ def render(&block)
6
6
  Chewy::Query::Filters.new(&block).__render__
7
7
  end
8
8
 
9
- specify { expect(render { name =~ 'nam' }).to eq({prefix: {'name' => 'nam'}}) }
10
- specify { expect(render { name !~ 'nam' }).to eq({not: {prefix: {'name' => 'nam'}}}) }
9
+ specify { expect(render { name =~ 'nam' }).to eq(prefix: { 'name' => 'nam' }) }
10
+ specify { expect(render { name !~ 'nam' }).to eq(not: { prefix: { 'name' => 'nam' } }) }
11
11
 
12
- specify { expect(render { ~name =~ 'nam' }).to eq({prefix: {'name' => 'nam', _cache: true}}) }
13
- specify { expect(render { ~name !~ 'nam' }).to eq({not: {prefix: {'name' => 'nam', _cache: true}}}) }
14
- specify { expect(render { name(cache: false) =~ 'nam' }).to eq({prefix: {'name' => 'nam', _cache: false}}) }
12
+ specify { expect(render { ~name =~ 'nam' }).to eq(prefix: { 'name' => 'nam', _cache: true }) }
13
+ specify { expect(render { ~name !~ 'nam' }).to eq(not: { prefix: { 'name' => 'nam', _cache: true } }) }
14
+ specify { expect(render { name(cache: false) =~ 'nam' }).to eq(prefix: { 'name' => 'nam', _cache: false }) }
15
15
  end
16
16
  end
@@ -2,11 +2,11 @@ require 'spec_helper'
2
2
 
3
3
  describe Chewy::Query::Nodes::Query do
4
4
  describe '#__render__' do
5
- def render &block
5
+ def render(&block)
6
6
  Chewy::Query::Filters.new(&block).__render__
7
7
  end
8
8
 
9
- specify { expect(render { q(query_string: {query: 'name: hello'}) }).to eq({query: {query_string: {query: 'name: hello'}}}) }
10
- specify { expect(render { ~q(query_string: {query: 'name: hello'}) }).to eq({fquery: {query: {query_string: {query: 'name: hello'}}, _cache: true}}) }
9
+ specify { expect(render { q(query_string: { query: 'name: hello' }) }).to eq(query: { query_string: { query: 'name: hello' } }) }
10
+ specify { expect(render { ~q(query_string: { query: 'name: hello' }) }).to eq(fquery: { query: { query_string: { query: 'name: hello' } }, _cache: true }) }
11
11
  end
12
12
  end
@@ -2,31 +2,31 @@ require 'spec_helper'
2
2
 
3
3
  describe Chewy::Query::Nodes::Range do
4
4
  describe '#__render__' do
5
- def render &block
5
+ def render(&block)
6
6
  Chewy::Query::Filters.new(&block).__render__
7
7
  end
8
8
 
9
- specify { expect(render { age > nil }).to eq({range: {'age' => {gt: nil}}}) }
10
- specify { expect(render { age == (nil..nil) }).to eq({range: {'age' => {gt: nil, lt: nil}}}) }
9
+ specify { expect(render { age > nil }).to eq(range: { 'age' => { gt: nil } }) }
10
+ specify { expect(render { age == (nil..nil) }).to eq(range: { 'age' => { gt: nil, lt: nil } }) }
11
11
 
12
- specify { expect(render { age > 42 }).to eq({range: {'age' => {gt: 42}}}) }
13
- specify { expect(render { age == (42..45) }).to eq({range: {'age' => {gt: 42, lt: 45}}}) }
14
- specify { expect(render { age == [42..45] }).to eq({range: {'age' => {gte: 42, lte: 45}}}) }
15
- specify { expect(render { (age > 42) & (age <= 45) }).to eq({range: {'age' => {gt: 42, lte: 45}}}) }
12
+ specify { expect(render { age > 42 }).to eq(range: { 'age' => { gt: 42 } }) }
13
+ specify { expect(render { age == (42..45) }).to eq(range: { 'age' => { gt: 42, lt: 45 } }) }
14
+ specify { expect(render { age == [42..45] }).to eq(range: { 'age' => { gte: 42, lte: 45 } }) }
15
+ specify { expect(render { (age > 42) & (age <= 45) }).to eq(range: { 'age' => { gt: 42, lte: 45 } }) }
16
16
 
17
- specify { expect(render { ~age > 42 }).to eq({range: {'age' => {gt: 42}, _cache: true}}) }
18
- specify { expect(render { ~age == (42..45) }).to eq({range: {'age' => {gt: 42, lt: 45}, _cache: true}}) }
19
- specify { expect(render { ~age == [42..45] }).to eq({range: {'age' => {gte: 42, lte: 45}, _cache: true}}) }
20
- specify { expect(render { (age > 42) & ~(age <= 45) }).to eq({range: {'age' => {gt: 42, lte: 45}, _cache: true}}) }
21
- specify { expect(render { (~age > 42) & (age <= 45) }).to eq({range: {'age' => {gt: 42, lte: 45}, _cache: true}}) }
17
+ specify { expect(render { ~age > 42 }).to eq(range: { 'age' => { gt: 42 }, _cache: true }) }
18
+ specify { expect(render { ~age == (42..45) }).to eq(range: { 'age' => { gt: 42, lt: 45 }, _cache: true }) }
19
+ specify { expect(render { ~age == [42..45] }).to eq(range: { 'age' => { gte: 42, lte: 45 }, _cache: true }) }
20
+ specify { expect(render { (age > 42) & ~(age <= 45) }).to eq(range: { 'age' => { gt: 42, lte: 45 }, _cache: true }) }
21
+ specify { expect(render { (~age > 42) & (age <= 45) }).to eq(range: { 'age' => { gt: 42, lte: 45 }, _cache: true }) }
22
22
 
23
- specify { expect(render { age(:i) > 42 }).to eq({range: {'age' => {gt: 42}, execution: :index}}) }
24
- specify { expect(render { age(:index) > 42 }).to eq({range: {'age' => {gt: 42}, execution: :index}}) }
25
- specify { expect(render { age(:f) > 42 }).to eq({range: {'age' => {gt: 42}, execution: :fielddata}}) }
26
- specify { expect(render { age(:fielddata) > 42 }).to eq({range: {'age' => {gt: 42}, execution: :fielddata}}) }
27
- specify { expect(render { (age(:f) > 42) & (age <= 45) }).to eq({range: {'age' => {gt: 42, lte: 45}, execution: :fielddata}}) }
23
+ specify { expect(render { age(:i) > 42 }).to eq(range: { 'age' => { gt: 42 }, execution: :index }) }
24
+ specify { expect(render { age(:index) > 42 }).to eq(range: { 'age' => { gt: 42 }, execution: :index }) }
25
+ specify { expect(render { age(:f) > 42 }).to eq(range: { 'age' => { gt: 42 }, execution: :fielddata }) }
26
+ specify { expect(render { age(:fielddata) > 42 }).to eq(range: { 'age' => { gt: 42 }, execution: :fielddata }) }
27
+ specify { expect(render { (age(:f) > 42) & (age <= 45) }).to eq(range: { 'age' => { gt: 42, lte: 45 }, execution: :fielddata }) }
28
28
 
29
- specify { expect(render { ~age(:f) > 42 }).to eq({range: {'age' => {gt: 42}, execution: :fielddata, _cache: true}}) }
30
- specify { expect(render { (age(:f) > 42) & (~age <= 45) }).to eq({range: {'age' => {gt: 42, lte: 45}, execution: :fielddata, _cache: true}}) }
29
+ specify { expect(render { ~age(:f) > 42 }).to eq(range: { 'age' => { gt: 42 }, execution: :fielddata, _cache: true }) }
30
+ specify { expect(render { (age(:f) > 42) & (~age <= 45) }).to eq(range: { 'age' => { gt: 42, lte: 45 }, execution: :fielddata, _cache: true }) }
31
31
  end
32
32
  end
@@ -2,10 +2,10 @@ require 'spec_helper'
2
2
 
3
3
  describe Chewy::Query::Nodes::Raw do
4
4
  describe '#__render__' do
5
- def render &block
5
+ def render(&block)
6
6
  Chewy::Query::Filters.new(&block).__render__
7
7
  end
8
8
 
9
- specify { expect(render { r(term: {name: 'name'}) }).to eq({term: {name: 'name'}}) }
9
+ specify { expect(render { r(term: { name: 'name' }) }).to eq(term: { name: 'name' }) }
10
10
  end
11
11
  end
@@ -2,30 +2,42 @@ require 'spec_helper'
2
2
 
3
3
  describe Chewy::Query::Nodes::Regexp do
4
4
  describe '#__render__' do
5
- def render &block
5
+ def render(&block)
6
6
  Chewy::Query::Filters.new(&block).__render__
7
7
  end
8
8
 
9
- specify { expect(render { names.first == /nam.*/ }).to eq({regexp: {'names.first' => 'nam.*'}}) }
10
- specify { expect(render { names.first =~ /nam.*/ }).to eq({regexp: {'names.first' => 'nam.*'}}) }
11
- specify { expect(render { name != /nam.*/ }).to eq({not: {regexp: {'name' => 'nam.*'}}}) }
12
- specify { expect(render { name !~ /nam.*/ }).to eq({not: {regexp: {'name' => 'nam.*'}}}) }
9
+ specify { expect(render { names.first == /nam.*/ }).to eq(regexp: { 'names.first' => 'nam.*' }) }
10
+ specify { expect(render { names.first =~ /nam.*/ }).to eq(regexp: { 'names.first' => 'nam.*' }) }
11
+ specify { expect(render { name != /nam.*/ }).to eq(not: { regexp: { 'name' => 'nam.*' } }) }
12
+ specify { expect(render { name !~ /nam.*/ }).to eq(not: { regexp: { 'name' => 'nam.*' } }) }
13
13
 
14
- specify { expect(render { names.first(flags: [:anystring, :intersection, :borogoves]) == /nam.*/ })
15
- .to eq({regexp: {'names.first' => {value: 'nam.*', flags: 'ANYSTRING|INTERSECTION'}}}) }
16
- specify { expect(render { names.first(:anystring, :intersection, :borogoves) == /nam.*/ })
17
- .to eq({regexp: {'names.first' => {value: 'nam.*', flags: 'ANYSTRING|INTERSECTION'}}}) }
14
+ specify do
15
+ expect(render { names.first(flags: [:anystring, :intersection, :borogoves]) == /nam.*/ })
16
+ .to eq(regexp: { 'names.first' => { value: 'nam.*', flags: 'ANYSTRING|INTERSECTION' } })
17
+ end
18
+ specify do
19
+ expect(render { names.first(:anystring, :intersection, :borogoves) == /nam.*/ })
20
+ .to eq(regexp: { 'names.first' => { value: 'nam.*', flags: 'ANYSTRING|INTERSECTION' } })
21
+ end
18
22
 
19
- specify { expect(render { names.first(flags: [:anystring, :intersection, :borogoves]) =~ /nam.*/ })
20
- .to eq({regexp: {'names.first' => {value: 'nam.*', flags: 'ANYSTRING|INTERSECTION'}}}) }
21
- specify { expect(render { names.first(:anystring, :intersection, :borogoves) =~ /nam.*/ })
22
- .to eq({regexp: {'names.first' => {value: 'nam.*', flags: 'ANYSTRING|INTERSECTION'}}}) }
23
+ specify do
24
+ expect(render { names.first(flags: [:anystring, :intersection, :borogoves]) =~ /nam.*/ })
25
+ .to eq(regexp: { 'names.first' => { value: 'nam.*', flags: 'ANYSTRING|INTERSECTION' } })
26
+ end
27
+ specify do
28
+ expect(render { names.first(:anystring, :intersection, :borogoves) =~ /nam.*/ })
29
+ .to eq(regexp: { 'names.first' => { value: 'nam.*', flags: 'ANYSTRING|INTERSECTION' } })
30
+ end
23
31
 
24
- specify { expect(render { ~names.first == /nam.*/ }).to eq({regexp: {'names.first' => 'nam.*', _cache: true, _cache_key: 'nam.*'}}) }
25
- specify { expect(render { names.first(cache: 'name') == /nam.*/ }).to eq({regexp: {'names.first' => 'nam.*', _cache: true, _cache_key: 'name'}}) }
26
- specify { expect(render { ~names.first(:anystring) =~ /nam.*/ })
27
- .to eq({regexp: {'names.first' => {value: 'nam.*', flags: 'ANYSTRING'}, _cache: true, _cache_key: 'nam.*'}}) }
28
- specify { expect(render { names.first(:anystring, cache: 'name') =~ /nam.*/ })
29
- .to eq({regexp: {'names.first' => {value: 'nam.*', flags: 'ANYSTRING'}, _cache: true, _cache_key: 'name'}}) }
32
+ specify { expect(render { ~names.first == /nam.*/ }).to eq(regexp: { 'names.first' => 'nam.*', _cache: true, _cache_key: 'nam.*' }) }
33
+ specify { expect(render { names.first(cache: 'name') == /nam.*/ }).to eq(regexp: { 'names.first' => 'nam.*', _cache: true, _cache_key: 'name' }) }
34
+ specify do
35
+ expect(render { ~names.first(:anystring) =~ /nam.*/ })
36
+ .to eq(regexp: { 'names.first' => { value: 'nam.*', flags: 'ANYSTRING' }, _cache: true, _cache_key: 'nam.*' })
37
+ end
38
+ specify do
39
+ expect(render { names.first(:anystring, cache: 'name') =~ /nam.*/ })
40
+ .to eq(regexp: { 'names.first' => { value: 'nam.*', flags: 'ANYSTRING' }, _cache: true, _cache_key: 'name' })
41
+ end
30
42
  end
31
43
  end
@@ -2,14 +2,14 @@ require 'spec_helper'
2
2
 
3
3
  describe Chewy::Query::Nodes::Script do
4
4
  describe '#__render__' do
5
- def render &block
5
+ def render(&block)
6
6
  Chewy::Query::Filters.new(&block).__render__
7
7
  end
8
8
 
9
- specify { expect(render { s('var = val') }).to eq({script: {script: 'var = val'}}) }
10
- specify { expect(render { s('var = val', val: 42) }).to eq({script: {script: 'var = val', params: {val: 42}}}) }
9
+ specify { expect(render { s('var = val') }).to eq(script: { script: 'var = val' }) }
10
+ specify { expect(render { s('var = val', val: 42) }).to eq(script: { script: 'var = val', params: { val: 42 } }) }
11
11
 
12
- specify { expect(render { ~s('var = val') }).to eq({script: {script: 'var = val', _cache: true}}) }
13
- specify { expect(render { ~s('var = val', val: 42) }).to eq({script: {script: 'var = val', params: {val: 42}, _cache: true}}) }
12
+ specify { expect(render { ~s('var = val') }).to eq(script: { script: 'var = val', _cache: true }) }
13
+ specify { expect(render { ~s('var = val', val: 42) }).to eq(script: { script: 'var = val', params: { val: 42 }, _cache: true }) }
14
14
  end
15
15
  end