chewy 0.10.0 → 6.0.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (157) hide show
  1. checksums.yaml +5 -5
  2. data/.circleci/config.yml +240 -0
  3. data/.rubocop.yml +25 -25
  4. data/Appraisals +12 -10
  5. data/CHANGELOG.md +252 -263
  6. data/Gemfile +5 -1
  7. data/LICENSE.txt +1 -1
  8. data/README.md +142 -78
  9. data/chewy.gemspec +10 -12
  10. data/gemfiles/{rails.4.2.mongoid.5.1.gemfile → rails.5.2.activerecord.gemfile} +6 -4
  11. data/gemfiles/{rails.4.2.activerecord.gemfile → rails.5.2.mongoid.6.4.gemfile} +6 -4
  12. data/gemfiles/{rails.4.0.activerecord.gemfile → rails.6.0.activerecord.gemfile} +6 -3
  13. data/gemfiles/rails.6.1.activerecord.gemfile +19 -0
  14. data/gemfiles/sequel.4.45.gemfile +2 -2
  15. data/lib/chewy.rb +2 -1
  16. data/lib/chewy/backports/duplicable.rb +1 -1
  17. data/lib/chewy/config.rb +10 -39
  18. data/lib/chewy/fields/base.rb +40 -28
  19. data/lib/chewy/fields/root.rb +18 -11
  20. data/lib/chewy/index.rb +3 -1
  21. data/lib/chewy/index/actions.rb +27 -15
  22. data/lib/chewy/index/settings.rb +2 -0
  23. data/lib/chewy/index/specification.rb +12 -10
  24. data/lib/chewy/minitest/helpers.rb +6 -6
  25. data/lib/chewy/minitest/search_index_receiver.rb +17 -17
  26. data/lib/chewy/multi_search.rb +62 -0
  27. data/lib/chewy/railtie.rb +4 -4
  28. data/lib/chewy/rake_helper.rb +5 -5
  29. data/lib/chewy/rspec/update_index.rb +3 -5
  30. data/lib/chewy/search.rb +4 -11
  31. data/lib/chewy/search/loader.rb +1 -1
  32. data/lib/chewy/search/pagination/will_paginate.rb +4 -2
  33. data/lib/chewy/search/parameters.rb +24 -6
  34. data/lib/chewy/search/parameters/allow_partial_search_results.rb +27 -0
  35. data/lib/chewy/search/parameters/concerns/query_storage.rb +4 -3
  36. data/lib/chewy/search/parameters/indices.rb +123 -0
  37. data/lib/chewy/search/parameters/none.rb +1 -3
  38. data/lib/chewy/search/request.rb +100 -74
  39. data/lib/chewy/search/scrolling.rb +7 -6
  40. data/lib/chewy/stash.rb +30 -21
  41. data/lib/chewy/strategy/active_job.rb +1 -1
  42. data/lib/chewy/strategy/atomic.rb +1 -1
  43. data/lib/chewy/strategy/sidekiq.rb +1 -1
  44. data/lib/chewy/type.rb +5 -2
  45. data/lib/chewy/type/adapter/active_record.rb +1 -1
  46. data/lib/chewy/type/adapter/base.rb +9 -9
  47. data/lib/chewy/type/adapter/mongoid.rb +2 -4
  48. data/lib/chewy/type/adapter/orm.rb +7 -4
  49. data/lib/chewy/type/adapter/sequel.rb +5 -7
  50. data/lib/chewy/type/crutch.rb +1 -1
  51. data/lib/chewy/type/import.rb +13 -11
  52. data/lib/chewy/type/import/bulk_builder.rb +1 -1
  53. data/lib/chewy/type/import/bulk_request.rb +4 -2
  54. data/lib/chewy/type/import/journal_builder.rb +3 -3
  55. data/lib/chewy/type/import/routine.rb +3 -3
  56. data/lib/chewy/type/mapping.rb +42 -36
  57. data/lib/chewy/type/observe.rb +16 -12
  58. data/lib/chewy/type/syncer.rb +15 -14
  59. data/lib/chewy/type/witchcraft.rb +11 -7
  60. data/lib/chewy/type/wrapper.rb +14 -4
  61. data/lib/chewy/version.rb +1 -1
  62. data/lib/sequel/plugins/chewy_observe.rb +4 -19
  63. data/migration_guide.md +18 -0
  64. data/spec/chewy/config_spec.rb +16 -21
  65. data/spec/chewy/fields/base_spec.rb +70 -70
  66. data/spec/chewy/fields/root_spec.rb +56 -9
  67. data/spec/chewy/index/actions_spec.rb +63 -7
  68. data/spec/chewy/index/specification_spec.rb +25 -16
  69. data/spec/chewy/index_spec.rb +75 -45
  70. data/spec/chewy/journal_spec.rb +33 -29
  71. data/spec/chewy/minitest/search_index_receiver_spec.rb +11 -9
  72. data/spec/chewy/multi_search_spec.rb +85 -0
  73. data/spec/chewy/rake_helper_spec.rb +123 -95
  74. data/spec/chewy/rspec/update_index_spec.rb +47 -46
  75. data/spec/chewy/runtime_spec.rb +2 -2
  76. data/spec/chewy/search/pagination/kaminari_spec.rb +7 -3
  77. data/spec/chewy/search/pagination/will_paginate_spec.rb +9 -3
  78. data/spec/chewy/search/parameters/indices_spec.rb +190 -0
  79. data/spec/chewy/search/parameters/none_spec.rb +1 -1
  80. data/spec/chewy/search/parameters_spec.rb +21 -4
  81. data/spec/chewy/search/request_spec.rb +101 -70
  82. data/spec/chewy/search/response_spec.rb +27 -17
  83. data/spec/chewy/search/scrolling_spec.rb +25 -16
  84. data/spec/chewy/search_spec.rb +49 -35
  85. data/spec/chewy/stash_spec.rb +15 -13
  86. data/spec/chewy/strategy/active_job_spec.rb +15 -2
  87. data/spec/chewy/strategy/shoryuken_spec.rb +8 -2
  88. data/spec/chewy/strategy/sidekiq_spec.rb +6 -2
  89. data/spec/chewy/type/adapter/active_record_spec.rb +16 -4
  90. data/spec/chewy/type/import/bulk_builder_spec.rb +9 -94
  91. data/spec/chewy/type/import/journal_builder_spec.rb +17 -15
  92. data/spec/chewy/type/import_spec.rb +6 -0
  93. data/spec/chewy/type/mapping_spec.rb +51 -18
  94. data/spec/chewy/type/observe_spec.rb +4 -4
  95. data/spec/chewy/type/witchcraft_spec.rb +31 -0
  96. data/spec/chewy/type/wrapper_spec.rb +3 -1
  97. data/spec/chewy_spec.rb +0 -7
  98. data/spec/spec_helper.rb +5 -1
  99. data/spec/support/active_record.rb +20 -0
  100. metadata +46 -116
  101. data/.travis.yml +0 -53
  102. data/LEGACY_DSL.md +0 -497
  103. data/gemfiles/rails.4.1.activerecord.gemfile +0 -14
  104. data/gemfiles/rails.5.0.activerecord.gemfile +0 -15
  105. data/gemfiles/rails.5.0.mongoid.6.0.gemfile +0 -15
  106. data/gemfiles/rails.5.1.activerecord.gemfile +0 -15
  107. data/gemfiles/rails.5.1.mongoid.6.1.gemfile +0 -15
  108. data/lib/chewy/query.rb +0 -1098
  109. data/lib/chewy/query/compose.rb +0 -68
  110. data/lib/chewy/query/criteria.rb +0 -191
  111. data/lib/chewy/query/filters.rb +0 -227
  112. data/lib/chewy/query/loading.rb +0 -111
  113. data/lib/chewy/query/nodes/and.rb +0 -25
  114. data/lib/chewy/query/nodes/base.rb +0 -17
  115. data/lib/chewy/query/nodes/bool.rb +0 -34
  116. data/lib/chewy/query/nodes/equal.rb +0 -34
  117. data/lib/chewy/query/nodes/exists.rb +0 -20
  118. data/lib/chewy/query/nodes/expr.rb +0 -28
  119. data/lib/chewy/query/nodes/field.rb +0 -110
  120. data/lib/chewy/query/nodes/has_child.rb +0 -15
  121. data/lib/chewy/query/nodes/has_parent.rb +0 -15
  122. data/lib/chewy/query/nodes/has_relation.rb +0 -59
  123. data/lib/chewy/query/nodes/match_all.rb +0 -11
  124. data/lib/chewy/query/nodes/missing.rb +0 -20
  125. data/lib/chewy/query/nodes/not.rb +0 -25
  126. data/lib/chewy/query/nodes/or.rb +0 -25
  127. data/lib/chewy/query/nodes/prefix.rb +0 -19
  128. data/lib/chewy/query/nodes/query.rb +0 -20
  129. data/lib/chewy/query/nodes/range.rb +0 -63
  130. data/lib/chewy/query/nodes/raw.rb +0 -15
  131. data/lib/chewy/query/nodes/regexp.rb +0 -35
  132. data/lib/chewy/query/nodes/script.rb +0 -20
  133. data/lib/chewy/query/pagination.rb +0 -25
  134. data/spec/chewy/query/criteria_spec.rb +0 -700
  135. data/spec/chewy/query/filters_spec.rb +0 -201
  136. data/spec/chewy/query/loading_spec.rb +0 -124
  137. data/spec/chewy/query/nodes/and_spec.rb +0 -12
  138. data/spec/chewy/query/nodes/bool_spec.rb +0 -14
  139. data/spec/chewy/query/nodes/equal_spec.rb +0 -32
  140. data/spec/chewy/query/nodes/exists_spec.rb +0 -18
  141. data/spec/chewy/query/nodes/has_child_spec.rb +0 -59
  142. data/spec/chewy/query/nodes/has_parent_spec.rb +0 -59
  143. data/spec/chewy/query/nodes/match_all_spec.rb +0 -11
  144. data/spec/chewy/query/nodes/missing_spec.rb +0 -16
  145. data/spec/chewy/query/nodes/not_spec.rb +0 -13
  146. data/spec/chewy/query/nodes/or_spec.rb +0 -12
  147. data/spec/chewy/query/nodes/prefix_spec.rb +0 -16
  148. data/spec/chewy/query/nodes/query_spec.rb +0 -12
  149. data/spec/chewy/query/nodes/range_spec.rb +0 -32
  150. data/spec/chewy/query/nodes/raw_spec.rb +0 -11
  151. data/spec/chewy/query/nodes/regexp_spec.rb +0 -43
  152. data/spec/chewy/query/nodes/script_spec.rb +0 -15
  153. data/spec/chewy/query/pagination/kaminari_spec.rb +0 -5
  154. data/spec/chewy/query/pagination/will_paginate_spec.rb +0 -5
  155. data/spec/chewy/query/pagination_spec.rb +0 -39
  156. data/spec/chewy/query_spec.rb +0 -636
  157. data/spec/chewy/search/parameters/indices_boost_spec.rb +0 -83
@@ -55,7 +55,7 @@ describe Chewy::Index::Actions do
55
55
  context do
56
56
  before { DummiesIndex.create }
57
57
  specify do
58
- expect { DummiesIndex.create! }.to raise_error(Elasticsearch::Transport::Transport::Errors::BadRequest).with_message(/index_already_exists_exception.*dummies/)
58
+ expect { DummiesIndex.create! }.to raise_error(Elasticsearch::Transport::Transport::Errors::BadRequest).with_message(/already exists.*dummies/)
59
59
  end
60
60
  specify { expect { DummiesIndex.create!('2013') }.to raise_error(Elasticsearch::Transport::Transport::Errors::BadRequest).with_message(/Invalid alias name \[dummies\]/) }
61
61
  end
@@ -67,7 +67,7 @@ describe Chewy::Index::Actions do
67
67
  specify { expect(DummiesIndex.aliases).to eq([]) }
68
68
  specify { expect(DummiesIndex.indexes).to eq(['dummies_2013']) }
69
69
  specify do
70
- expect { DummiesIndex.create!('2013') }.to raise_error(Elasticsearch::Transport::Transport::Errors::BadRequest).with_message(/index_already_exists_exception.*dummies_2013/)
70
+ expect { DummiesIndex.create!('2013') }.to raise_error(Elasticsearch::Transport::Transport::Errors::BadRequest).with_message(/already exists.*dummies_2013/)
71
71
  end
72
72
  specify { expect(DummiesIndex.create!('2014')['acknowledged']).to eq(true) }
73
73
 
@@ -281,6 +281,18 @@ describe Chewy::Index::Actions do
281
281
 
282
282
  specify { expect(CitiesIndex.import).to eq(true) }
283
283
 
284
+ specify 'with an empty array' do
285
+ expect(CitiesIndex).not_to receive(:exists?)
286
+ expect(CitiesIndex).not_to receive(:create!)
287
+ expect(CitiesIndex.import([])).to eq(true)
288
+ end
289
+
290
+ specify 'with an empty relation' do
291
+ expect(CitiesIndex).not_to receive(:exists?)
292
+ expect(CitiesIndex).not_to receive(:create!)
293
+ expect(CitiesIndex.import(City.where('1 = 2'))).to eq(true)
294
+ end
295
+
284
296
  context do
285
297
  before do
286
298
  stub_index(:cities) do
@@ -305,6 +317,18 @@ describe Chewy::Index::Actions do
305
317
 
306
318
  specify { expect(CitiesIndex.import!).to eq(true) }
307
319
 
320
+ specify 'with an empty array' do
321
+ expect(CitiesIndex).not_to receive(:exists?)
322
+ expect(CitiesIndex).not_to receive(:create!)
323
+ expect(CitiesIndex.import!([])).to eq(true)
324
+ end
325
+
326
+ specify 'with an empty relation' do
327
+ expect(CitiesIndex).not_to receive(:exists?)
328
+ expect(CitiesIndex).not_to receive(:create!)
329
+ expect(CitiesIndex.import!(City.where('1 = 2'))).to eq(true)
330
+ end
331
+
308
332
  context do
309
333
  before do
310
334
  stub_index(:cities) do
@@ -429,6 +453,12 @@ describe Chewy::Index::Actions do
429
453
  expect(CitiesIndex).to receive(:import).with(suffix: suffix, journal: false, refresh: false).and_call_original
430
454
  expect(CitiesIndex.reset!(suffix)).to eq(true)
431
455
  end
456
+
457
+ specify 'uses empty index settings if not defined' do
458
+ allow(Chewy).to receive(:wait_for_status).and_return(nil)
459
+ allow(CitiesIndex).to receive(:settings_hash).and_return({})
460
+ expect(CitiesIndex.reset!(suffix)).to eq(true)
461
+ end
432
462
  end
433
463
  end
434
464
 
@@ -478,7 +508,7 @@ describe Chewy::Index::Actions do
478
508
  end
479
509
  end
480
510
 
481
- context 'applying journal' do
511
+ xcontext 'applying journal' do
482
512
  before do
483
513
  stub_index(:cities) do
484
514
  define_type City do
@@ -494,23 +524,49 @@ describe Chewy::Index::Actions do
494
524
 
495
525
  let(:parallel_update) do
496
526
  Thread.new do
527
+ p 'start parallel'
497
528
  sleep(1.5)
498
529
  cities.first.update(name: 'NewName1', rating: 0)
499
530
  cities.last.update(name: 'NewName3', rating: 0)
500
531
  CitiesIndex::City.import!([cities.first, cities.last], journal: true)
532
+ p 'end parallel'
501
533
  end
502
534
  end
503
535
 
504
536
  specify 'with journal application' do
505
- parallel_update
506
- CitiesIndex.reset!('suffix')
537
+ cities
538
+ p 'cities created1'
539
+ ::ActiveRecord::Base.connection.close if defined?(::ActiveRecord::Base)
540
+ [
541
+ parallel_update,
542
+ Thread.new do
543
+ p 'start reset1'
544
+ CitiesIndex.reset!('suffix')
545
+ p 'end reset1'
546
+ end
547
+ ].map(&:join)
548
+ ::ActiveRecord::Base.connection.reconnect! if defined?(::ActiveRecord::Base)
549
+ p 'expect1'
507
550
  expect(CitiesIndex::City.pluck(:_id, :name)).to contain_exactly(%w[1 NewName1], %w[2 Name2], %w[3 NewName3])
551
+ p 'end expect1'
508
552
  end
509
553
 
510
554
  specify 'without journal application' do
511
- parallel_update
512
- CitiesIndex.reset!('suffix', apply_journal: false)
555
+ cities
556
+ p 'cities created2'
557
+ ::ActiveRecord::Base.connection.close if defined?(::ActiveRecord::Base)
558
+ [
559
+ parallel_update,
560
+ Thread.new do
561
+ p 'start reset2'
562
+ CitiesIndex.reset!('suffix', apply_journal: false)
563
+ p 'end reset2'
564
+ end
565
+ ].map(&:join)
566
+ ::ActiveRecord::Base.connection.reconnect! if defined?(::ActiveRecord::Base)
567
+ p 'expect2'
513
568
  expect(CitiesIndex::City.pluck(:_id, :name)).to contain_exactly(%w[1 Name1], %w[2 Name2], %w[3 Name3])
569
+ p 'end expect2'
514
570
  end
515
571
  end
516
572
 
@@ -6,7 +6,7 @@ describe Chewy::Index::Specification do
6
6
  let(:index1) do
7
7
  stub_index(:places) do
8
8
  define_type(:city) do
9
- field :name, type: 'string'
9
+ field :founded_on, type: 'date'
10
10
  end
11
11
  end
12
12
  end
@@ -15,7 +15,7 @@ describe Chewy::Index::Specification do
15
15
  stub_index(:places) do
16
16
  settings analyzer: {}
17
17
  define_type(:city) do
18
- field :name, type: 'string'
18
+ field :founded_on, type: 'date'
19
19
  end
20
20
  end
21
21
  end
@@ -23,7 +23,7 @@ describe Chewy::Index::Specification do
23
23
  let(:index3) do
24
24
  stub_index(:places) do
25
25
  define_type(:city) do
26
- field :name, type: 'string'
26
+ field :founded_on, type: 'date'
27
27
  field :population, type: 'integer'
28
28
  end
29
29
  end
@@ -33,7 +33,7 @@ describe Chewy::Index::Specification do
33
33
  stub_index(:places) do
34
34
  define_type(:city) do
35
35
  field :population, type: 'integer'
36
- field :name, type: 'string'
36
+ field :founded_on, type: 'date'
37
37
  end
38
38
  end
39
39
  end
@@ -55,11 +55,14 @@ describe Chewy::Index::Specification do
55
55
  describe '#lock!' do
56
56
  specify do
57
57
  expect { specification1.lock! }.to change { Chewy::Stash::Specification.all.hits }.from([]).to([{
58
- '_index' => 'chewy_stash',
58
+ '_index' => 'chewy_specifications',
59
59
  '_type' => 'specification',
60
60
  '_id' => 'places',
61
61
  '_score' => 1.0,
62
- '_source' => {'value' => '{"settings":{"index":{"number_of_shards":1,"number_of_replicas":0}},"mappings":{"city":{"properties":{"name":{"type":"string"}}}}}'}
62
+ '_source' => {'specification' => Base64.encode64({
63
+ 'settings' => {'index' => {'number_of_shards' => 1, 'number_of_replicas' => 0}},
64
+ 'mappings' => {'city' => {'properties' => {'founded_on' => {'type' => 'date'}}}}
65
+ }.to_json)}
63
66
  }])
64
67
  end
65
68
 
@@ -68,17 +71,23 @@ describe Chewy::Index::Specification do
68
71
 
69
72
  specify do
70
73
  expect { specification5.lock! }.to change { Chewy::Stash::Specification.all.hits }.to([{
71
- '_index' => 'chewy_stash',
74
+ '_index' => 'chewy_specifications',
72
75
  '_type' => 'specification',
73
76
  '_id' => 'places',
74
77
  '_score' => 1.0,
75
- '_source' => {'value' => '{"settings":{"index":{"number_of_shards":1,"number_of_replicas":0}},"mappings":{"city":{"properties":{"name":{"type":"string"}}}}}'}
78
+ '_source' => {'specification' => Base64.encode64({
79
+ 'settings' => {'index' => {'number_of_shards' => 1, 'number_of_replicas' => 0}},
80
+ 'mappings' => {'city' => {'properties' => {'founded_on' => {'type' => 'date'}}}}
81
+ }.to_json)}
76
82
  }, {
77
- '_index' => 'chewy_stash',
83
+ '_index' => 'chewy_specifications',
78
84
  '_type' => 'specification',
79
85
  '_id' => 'namespace/cities',
80
86
  '_score' => 1.0,
81
- '_source' => {'value' => '{"settings":{"index":{"number_of_shards":1,"number_of_replicas":0}},"mappings":{"city":{"properties":{"population":{"type":"integer"}}}}}'}
87
+ '_source' => {'specification' => Base64.encode64({
88
+ 'settings' => {'index' => {'number_of_shards' => 1, 'number_of_replicas' => 0}},
89
+ 'mappings' => {'city' => {'properties' => {'population' => {'type' => 'integer'}}}}
90
+ }.to_json)}
82
91
  }])
83
92
  end
84
93
  end
@@ -88,7 +97,7 @@ describe Chewy::Index::Specification do
88
97
  specify do
89
98
  expect { specification1.lock! }.to change { specification1.locked }.from({}).to(
90
99
  'settings' => {'index' => {'number_of_shards' => 1, 'number_of_replicas' => 0}},
91
- 'mappings' => {'city' => {'properties' => {'name' => {'type' => 'string'}}}}
100
+ 'mappings' => {'city' => {'properties' => {'founded_on' => {'type' => 'date'}}}}
92
101
  )
93
102
  end
94
103
 
@@ -105,20 +114,20 @@ describe Chewy::Index::Specification do
105
114
  specify do
106
115
  expect { specification2.lock! }.to change { specification2.locked }.from(
107
116
  'settings' => {'index' => {'number_of_shards' => 1, 'number_of_replicas' => 0}},
108
- 'mappings' => {'city' => {'properties' => {'name' => {'type' => 'string'}}}}
117
+ 'mappings' => {'city' => {'properties' => {'founded_on' => {'type' => 'date'}}}}
109
118
  ).to(
110
119
  'settings' => {'analyzer' => {}, 'index' => {'number_of_shards' => 1, 'number_of_replicas' => 0}},
111
- 'mappings' => {'city' => {'properties' => {'name' => {'type' => 'string'}}}}
120
+ 'mappings' => {'city' => {'properties' => {'founded_on' => {'type' => 'date'}}}}
112
121
  )
113
122
  end
114
123
 
115
124
  specify do
116
125
  expect { specification3.lock! }.to change { specification3.locked }.from(
117
126
  'settings' => {'index' => {'number_of_shards' => 1, 'number_of_replicas' => 0}},
118
- 'mappings' => {'city' => {'properties' => {'name' => {'type' => 'string'}}}}
127
+ 'mappings' => {'city' => {'properties' => {'founded_on' => {'type' => 'date'}}}}
119
128
  ).to(
120
129
  'settings' => {'index' => {'number_of_shards' => 1, 'number_of_replicas' => 0}},
121
- 'mappings' => {'city' => {'properties' => {'name' => {'type' => 'string'}, 'population' => {'type' => 'integer'}}}}
130
+ 'mappings' => {'city' => {'properties' => {'founded_on' => {'type' => 'date'}, 'population' => {'type' => 'integer'}}}}
122
131
  )
123
132
  end
124
133
  end
@@ -127,7 +136,7 @@ describe Chewy::Index::Specification do
127
136
  describe '#current' do
128
137
  specify do
129
138
  expect(specification2.current).to eq(
130
- 'mappings' => {'city' => {'properties' => {'name' => {'type' => 'string'}}}},
139
+ 'mappings' => {'city' => {'properties' => {'founded_on' => {'type' => 'date'}}}},
131
140
  'settings' => {'analyzer' => {}, 'index' => {'number_of_shards' => 1, 'number_of_replicas' => 0}}
132
141
  )
133
142
  end
@@ -12,8 +12,11 @@ describe Chewy::Index do
12
12
  stub_model(:city)
13
13
  stub_model(:country)
14
14
 
15
- stub_index(:places) do
15
+ stub_index(:cities) do
16
16
  define_type City
17
+ end
18
+
19
+ stub_index(:countries) do
17
20
  define_type Country
18
21
  end
19
22
  end
@@ -22,23 +25,23 @@ describe Chewy::Index do
22
25
  let!(:countries) { Array.new(2) { |i| Country.create! id: i + 1 } }
23
26
 
24
27
  specify do
25
- expect { PlacesIndex.import }.to update_index(PlacesIndex::City).and_reindex(cities)
26
- expect { PlacesIndex.import }.to update_index(PlacesIndex::Country).and_reindex(countries)
28
+ expect { CitiesIndex.import }.to update_index(CitiesIndex).and_reindex(cities)
29
+ expect { CountriesIndex.import }.to update_index(CountriesIndex).and_reindex(countries)
27
30
  end
28
31
 
29
32
  specify do
30
- expect { PlacesIndex.import city: cities.first }.to update_index(PlacesIndex::City).and_reindex(cities.first).only
31
- expect { PlacesIndex.import city: cities.first }.to update_index(PlacesIndex::Country).and_reindex(countries)
33
+ expect { CitiesIndex.import city: cities.first }.to update_index(CitiesIndex).and_reindex(cities.first).only
34
+ expect { CountriesIndex.import city: cities.first }.to update_index(CountriesIndex).and_reindex(countries)
32
35
  end
33
36
 
34
37
  specify do
35
- expect { PlacesIndex.import city: cities.first, country: countries.last }.to update_index(PlacesIndex::City).and_reindex(cities.first).only
36
- expect { PlacesIndex.import city: cities.first, country: countries.last }.to update_index(PlacesIndex::Country).and_reindex(countries.last).only
38
+ expect { CitiesIndex.import city: cities.first, country: countries.last }.to update_index(CitiesIndex).and_reindex(cities.first).only
39
+ expect { CountriesIndex.import city: cities.first, country: countries.last }.to update_index(CountriesIndex).and_reindex(countries.last).only
37
40
  end
38
41
 
39
42
  specify do
40
- expect(PlacesIndex.client).to receive(:bulk).with(hash_including(refresh: false)).twice
41
- PlacesIndex.import city: cities.first, refresh: false
43
+ expect(CitiesIndex.client).to receive(:bulk).with(hash_including(refresh: false)).once
44
+ CitiesIndex.import city: cities.first, refresh: false
42
45
  end
43
46
  end
44
47
 
@@ -101,43 +104,27 @@ describe Chewy::Index do
101
104
 
102
105
  context do
103
106
  before { stub_class('City') }
104
- before { stub_class('City::District', City) }
107
+ before { stub_class('Country') }
105
108
 
106
109
  specify do
107
110
  expect do
108
111
  Kernel.eval <<-DUMMY_CITY_INDEX
109
- class DummyCityIndex < Chewy::Index
112
+ class DummyCityIndex2 < Chewy::Index
110
113
  define_type City
111
- define_type City::District
114
+ define_type Country
112
115
  end
113
116
  DUMMY_CITY_INDEX
114
- end.not_to raise_error
115
- end
117
+ end.to raise_error(/Multiple types are deprecated/)
116
118
 
117
- specify do
118
119
  expect do
119
120
  Kernel.eval <<-DUMMY_CITY_INDEX
120
121
  class DummyCityIndex2 < Chewy::Index
121
- define_type City
122
122
  define_type City::Nothing
123
123
  end
124
124
  DUMMY_CITY_INDEX
125
125
  end.to raise_error(NameError)
126
126
  end
127
127
  end
128
-
129
- context 'type methods should be deprecated and can\'t redefine existing ones' do
130
- before do
131
- stub_index(:places) do
132
- def self.city; end
133
- define_type :city
134
- define_type :country
135
- end
136
- end
137
-
138
- specify { expect(PlacesIndex.city).to be_nil }
139
- specify { expect(PlacesIndex::Country).to be < Chewy::Type }
140
- end
141
128
  end
142
129
 
143
130
  describe '.type_hash' do
@@ -191,16 +178,44 @@ describe Chewy::Index do
191
178
  stub_index(:places) do
192
179
  def self.by_rating; end
193
180
 
194
- def self.by_name; end
181
+ def self.colors(*colors)
182
+ filter(terms: {colors: colors.flatten(1).map(&:to_s)})
183
+ end
195
184
 
196
185
  define_type :city do
197
186
  def self.by_id; end
187
+ field :colors
198
188
  end
199
189
  end
200
190
  end
201
191
 
202
192
  specify { expect(described_class.scopes).to eq([]) }
203
- specify { expect(PlacesIndex.scopes).to match_array(%i[by_rating by_name]) }
193
+ specify { expect(PlacesIndex.scopes).to match_array(%i[by_rating colors]) }
194
+
195
+ context do
196
+ before do
197
+ Chewy.massacre
198
+ PlacesIndex::City.import!(
199
+ double(colors: ['red']),
200
+ double(colors: %w[red green]),
201
+ double(colors: %w[green yellow])
202
+ )
203
+ end
204
+
205
+ specify do
206
+ # This `blank?`` call is for the messed scopes bug reproduction. See #573
207
+ PlacesIndex::City.blank?
208
+ expect(PlacesIndex.colors(:green).map(&:colors))
209
+ .to contain_exactly(%w[red green], %w[green yellow])
210
+ end
211
+
212
+ specify do
213
+ # This `blank?` call is for the messed scopes bug reproduction. See #573
214
+ PlacesIndex::City.blank?
215
+ expect(PlacesIndex::City.colors(:green).map(&:colors))
216
+ .to contain_exactly(%w[red green], %w[green yellow])
217
+ end
218
+ end
204
219
  end
205
220
 
206
221
  describe '.settings_hash' do
@@ -216,19 +231,9 @@ describe Chewy::Index do
216
231
  specify do
217
232
  expect(stub_index(:documents) do
218
233
  define_type :document do
219
- field :name, type: 'string'
234
+ field :date, type: 'date'
220
235
  end
221
- end.mappings_hash).to eq(mappings: {document: {properties: {name: {type: 'string'}}}})
222
- end
223
- specify do
224
- expect(stub_index(:documents) do
225
- define_type :document do
226
- field :name, type: 'string'
227
- end
228
- define_type :document2 do
229
- field :name, type: 'string'
230
- end
231
- end.mappings_hash[:mappings].keys).to match_array(%i[document document2])
236
+ end.mappings_hash).to eq(mappings: {document: {properties: {date: {type: 'date'}}}})
232
237
  end
233
238
  end
234
239
 
@@ -240,7 +245,7 @@ describe Chewy::Index do
240
245
  specify do
241
246
  expect(stub_index(:documents) do
242
247
  define_type :document do
243
- field :name, type: 'string'
248
+ field :name
244
249
  end
245
250
  end.specification_hash.keys).to eq([:mappings])
246
251
  end
@@ -248,7 +253,7 @@ describe Chewy::Index do
248
253
  expect(stub_index(:documents) do
249
254
  settings number_of_shards: 1
250
255
  define_type :document do
251
- field :name, type: 'string'
256
+ field :name
252
257
  end
253
258
  end.specification_hash.keys).to match_array(%i[mappings settings])
254
259
  end
@@ -281,4 +286,29 @@ describe Chewy::Index do
281
286
  specify { expect(DummiesIndex.index_name).to eq('borogoves_dummies') }
282
287
  end
283
288
  end
289
+
290
+ context 'index call inside index', :orm do
291
+ before do
292
+ stub_index(:cities) do
293
+ define_type :city do
294
+ field :country_name, value: (lambda do |city|
295
+ CountriesIndex::Country.filter(term: {_id: city.country_id}).first.name
296
+ end)
297
+ end
298
+ end
299
+
300
+ stub_index(:countries) do
301
+ define_type :country do
302
+ field :name
303
+ end
304
+ end
305
+
306
+ CountriesIndex::Country.import!(double(id: 1, name: 'Country'))
307
+ end
308
+
309
+ specify do
310
+ expect { CitiesIndex::City.import!(double(country_id: 1)) }
311
+ .to update_index(CitiesIndex::City).and_reindex(country_name: 'Country')
312
+ end
313
+ end
284
314
  end