chewy 0.10.1 → 7.3.2

Sign up to get free protection for your applications and to get access to all the features.
Files changed (243) hide show
  1. checksums.yaml +5 -5
  2. data/.github/CODEOWNERS +1 -0
  3. data/.github/ISSUE_TEMPLATE/bug_report.md +39 -0
  4. data/.github/ISSUE_TEMPLATE/feature_request.md +20 -0
  5. data/.github/PULL_REQUEST_TEMPLATE.md +16 -0
  6. data/.github/workflows/ruby.yml +74 -0
  7. data/.rubocop.yml +28 -23
  8. data/.rubocop_todo.yml +110 -22
  9. data/CHANGELOG.md +480 -298
  10. data/CODE_OF_CONDUCT.md +14 -0
  11. data/CONTRIBUTING.md +63 -0
  12. data/Gemfile +3 -5
  13. data/Guardfile +3 -1
  14. data/LICENSE.txt +1 -1
  15. data/README.md +571 -333
  16. data/chewy.gemspec +12 -15
  17. data/gemfiles/rails.5.2.activerecord.gemfile +11 -0
  18. data/gemfiles/rails.6.0.activerecord.gemfile +11 -0
  19. data/gemfiles/rails.6.1.activerecord.gemfile +13 -0
  20. data/gemfiles/rails.7.0.activerecord.gemfile +13 -0
  21. data/lib/chewy/config.rb +48 -77
  22. data/lib/chewy/errors.rb +4 -10
  23. data/lib/chewy/fields/base.rb +88 -16
  24. data/lib/chewy/fields/root.rb +15 -21
  25. data/lib/chewy/index/actions.rb +67 -38
  26. data/lib/chewy/{type → index}/adapter/active_record.rb +18 -4
  27. data/lib/chewy/{type → index}/adapter/base.rb +11 -12
  28. data/lib/chewy/{type → index}/adapter/object.rb +28 -32
  29. data/lib/chewy/{type → index}/adapter/orm.rb +26 -24
  30. data/lib/chewy/index/aliases.rb +14 -5
  31. data/lib/chewy/index/crutch.rb +40 -0
  32. data/lib/chewy/index/import/bulk_builder.rb +311 -0
  33. data/lib/chewy/{type → index}/import/bulk_request.rb +10 -9
  34. data/lib/chewy/{type → index}/import/journal_builder.rb +11 -12
  35. data/lib/chewy/{type → index}/import/routine.rb +19 -18
  36. data/lib/chewy/{type → index}/import.rb +82 -36
  37. data/lib/chewy/{type → index}/mapping.rb +63 -62
  38. data/lib/chewy/index/observe/active_record_methods.rb +87 -0
  39. data/lib/chewy/index/observe/callback.rb +34 -0
  40. data/lib/chewy/index/observe.rb +17 -0
  41. data/lib/chewy/index/settings.rb +2 -0
  42. data/lib/chewy/index/specification.rb +13 -10
  43. data/lib/chewy/{type → index}/syncer.rb +62 -63
  44. data/lib/chewy/{type → index}/witchcraft.rb +15 -9
  45. data/lib/chewy/{type → index}/wrapper.rb +16 -6
  46. data/lib/chewy/index.rb +68 -93
  47. data/lib/chewy/journal.rb +25 -14
  48. data/lib/chewy/minitest/helpers.rb +91 -18
  49. data/lib/chewy/minitest/search_index_receiver.rb +29 -33
  50. data/lib/chewy/multi_search.rb +62 -0
  51. data/lib/chewy/railtie.rb +8 -24
  52. data/lib/chewy/rake_helper.rb +141 -112
  53. data/lib/chewy/rspec/build_query.rb +12 -0
  54. data/lib/chewy/rspec/helpers.rb +55 -0
  55. data/lib/chewy/rspec/update_index.rb +58 -49
  56. data/lib/chewy/rspec.rb +2 -0
  57. data/lib/chewy/runtime.rb +1 -1
  58. data/lib/chewy/search/loader.rb +19 -41
  59. data/lib/chewy/search/parameters/allow_partial_search_results.rb +27 -0
  60. data/lib/chewy/search/parameters/collapse.rb +16 -0
  61. data/lib/chewy/search/parameters/concerns/query_storage.rb +6 -5
  62. data/lib/chewy/search/parameters/ignore_unavailable.rb +27 -0
  63. data/lib/chewy/search/parameters/indices.rb +78 -0
  64. data/lib/chewy/search/parameters/none.rb +1 -3
  65. data/lib/chewy/search/parameters/order.rb +6 -19
  66. data/lib/chewy/search/parameters/source.rb +5 -1
  67. data/lib/chewy/search/parameters/track_total_hits.rb +16 -0
  68. data/lib/chewy/search/parameters.rb +28 -8
  69. data/lib/chewy/search/query_proxy.rb +9 -2
  70. data/lib/chewy/search/request.rb +207 -157
  71. data/lib/chewy/search/response.rb +5 -5
  72. data/lib/chewy/search/scoping.rb +7 -8
  73. data/lib/chewy/search/scrolling.rb +14 -13
  74. data/lib/chewy/search.rb +7 -26
  75. data/lib/chewy/stash.rb +27 -29
  76. data/lib/chewy/strategy/active_job.rb +2 -2
  77. data/lib/chewy/strategy/atomic.rb +1 -1
  78. data/lib/chewy/strategy/atomic_no_refresh.rb +18 -0
  79. data/lib/chewy/strategy/base.rb +10 -0
  80. data/lib/chewy/strategy/delayed_sidekiq/scheduler.rb +148 -0
  81. data/lib/chewy/strategy/delayed_sidekiq/worker.rb +52 -0
  82. data/lib/chewy/strategy/delayed_sidekiq.rb +17 -0
  83. data/lib/chewy/strategy/lazy_sidekiq.rb +64 -0
  84. data/lib/chewy/strategy/sidekiq.rb +3 -2
  85. data/lib/chewy/strategy.rb +6 -19
  86. data/lib/chewy/version.rb +1 -1
  87. data/lib/chewy.rb +37 -80
  88. data/lib/generators/chewy/install_generator.rb +1 -1
  89. data/lib/tasks/chewy.rake +26 -32
  90. data/migration_guide.md +56 -0
  91. data/spec/chewy/config_spec.rb +27 -57
  92. data/spec/chewy/fields/base_spec.rb +457 -174
  93. data/spec/chewy/fields/root_spec.rb +24 -32
  94. data/spec/chewy/fields/time_fields_spec.rb +5 -5
  95. data/spec/chewy/index/actions_spec.rb +425 -60
  96. data/spec/chewy/{type → index}/adapter/active_record_spec.rb +110 -44
  97. data/spec/chewy/{type → index}/adapter/object_spec.rb +21 -6
  98. data/spec/chewy/index/aliases_spec.rb +3 -3
  99. data/spec/chewy/index/import/bulk_builder_spec.rb +494 -0
  100. data/spec/chewy/{type → index}/import/bulk_request_spec.rb +5 -12
  101. data/spec/chewy/{type → index}/import/journal_builder_spec.rb +22 -30
  102. data/spec/chewy/{type → index}/import/routine_spec.rb +19 -19
  103. data/spec/chewy/{type → index}/import_spec.rb +154 -95
  104. data/spec/chewy/index/mapping_spec.rb +135 -0
  105. data/spec/chewy/index/observe/active_record_methods_spec.rb +68 -0
  106. data/spec/chewy/index/observe/callback_spec.rb +139 -0
  107. data/spec/chewy/index/observe_spec.rb +143 -0
  108. data/spec/chewy/index/settings_spec.rb +3 -1
  109. data/spec/chewy/index/specification_spec.rb +32 -33
  110. data/spec/chewy/{type → index}/syncer_spec.rb +14 -19
  111. data/spec/chewy/{type → index}/witchcraft_spec.rb +34 -21
  112. data/spec/chewy/index/wrapper_spec.rb +100 -0
  113. data/spec/chewy/index_spec.rb +99 -114
  114. data/spec/chewy/journal_spec.rb +56 -101
  115. data/spec/chewy/minitest/helpers_spec.rb +122 -14
  116. data/spec/chewy/minitest/search_index_receiver_spec.rb +24 -26
  117. data/spec/chewy/multi_search_spec.rb +84 -0
  118. data/spec/chewy/rake_helper_spec.rb +325 -101
  119. data/spec/chewy/rspec/build_query_spec.rb +34 -0
  120. data/spec/chewy/rspec/helpers_spec.rb +61 -0
  121. data/spec/chewy/rspec/update_index_spec.rb +106 -102
  122. data/spec/chewy/runtime_spec.rb +2 -2
  123. data/spec/chewy/search/loader_spec.rb +19 -53
  124. data/spec/chewy/search/pagination/kaminari_examples.rb +3 -5
  125. data/spec/chewy/search/pagination/kaminari_spec.rb +1 -1
  126. data/spec/chewy/search/parameters/collapse_spec.rb +5 -0
  127. data/spec/chewy/search/parameters/ignore_unavailable_spec.rb +67 -0
  128. data/spec/chewy/search/parameters/indices_spec.rb +99 -0
  129. data/spec/chewy/search/parameters/none_spec.rb +1 -1
  130. data/spec/chewy/search/parameters/order_spec.rb +18 -11
  131. data/spec/chewy/search/parameters/query_storage_examples.rb +67 -21
  132. data/spec/chewy/search/parameters/search_after_spec.rb +4 -1
  133. data/spec/chewy/search/parameters/source_spec.rb +8 -2
  134. data/spec/chewy/search/parameters/track_total_hits_spec.rb +5 -0
  135. data/spec/chewy/search/parameters_spec.rb +39 -8
  136. data/spec/chewy/search/query_proxy_spec.rb +68 -17
  137. data/spec/chewy/search/request_spec.rb +360 -149
  138. data/spec/chewy/search/response_spec.rb +35 -25
  139. data/spec/chewy/search/scrolling_spec.rb +28 -26
  140. data/spec/chewy/search_spec.rb +73 -53
  141. data/spec/chewy/stash_spec.rb +16 -26
  142. data/spec/chewy/strategy/active_job_spec.rb +23 -10
  143. data/spec/chewy/strategy/atomic_no_refresh_spec.rb +60 -0
  144. data/spec/chewy/strategy/atomic_spec.rb +9 -10
  145. data/spec/chewy/strategy/delayed_sidekiq_spec.rb +190 -0
  146. data/spec/chewy/strategy/lazy_sidekiq_spec.rb +214 -0
  147. data/spec/chewy/strategy/sidekiq_spec.rb +14 -10
  148. data/spec/chewy/strategy_spec.rb +19 -15
  149. data/spec/chewy_spec.rb +17 -110
  150. data/spec/spec_helper.rb +7 -22
  151. data/spec/support/active_record.rb +43 -5
  152. metadata +123 -198
  153. data/.travis.yml +0 -53
  154. data/Appraisals +0 -79
  155. data/LEGACY_DSL.md +0 -497
  156. data/gemfiles/rails.4.0.activerecord.gemfile +0 -14
  157. data/gemfiles/rails.4.1.activerecord.gemfile +0 -14
  158. data/gemfiles/rails.4.2.activerecord.gemfile +0 -15
  159. data/gemfiles/rails.4.2.mongoid.5.1.gemfile +0 -15
  160. data/gemfiles/rails.5.0.activerecord.gemfile +0 -15
  161. data/gemfiles/rails.5.0.mongoid.6.0.gemfile +0 -15
  162. data/gemfiles/rails.5.1.activerecord.gemfile +0 -15
  163. data/gemfiles/rails.5.1.mongoid.6.1.gemfile +0 -15
  164. data/gemfiles/sequel.4.45.gemfile +0 -11
  165. data/lib/chewy/backports/deep_dup.rb +0 -46
  166. data/lib/chewy/backports/duplicable.rb +0 -91
  167. data/lib/chewy/query/compose.rb +0 -68
  168. data/lib/chewy/query/criteria.rb +0 -191
  169. data/lib/chewy/query/filters.rb +0 -227
  170. data/lib/chewy/query/loading.rb +0 -111
  171. data/lib/chewy/query/nodes/and.rb +0 -25
  172. data/lib/chewy/query/nodes/base.rb +0 -17
  173. data/lib/chewy/query/nodes/bool.rb +0 -34
  174. data/lib/chewy/query/nodes/equal.rb +0 -34
  175. data/lib/chewy/query/nodes/exists.rb +0 -20
  176. data/lib/chewy/query/nodes/expr.rb +0 -28
  177. data/lib/chewy/query/nodes/field.rb +0 -110
  178. data/lib/chewy/query/nodes/has_child.rb +0 -15
  179. data/lib/chewy/query/nodes/has_parent.rb +0 -15
  180. data/lib/chewy/query/nodes/has_relation.rb +0 -59
  181. data/lib/chewy/query/nodes/match_all.rb +0 -11
  182. data/lib/chewy/query/nodes/missing.rb +0 -20
  183. data/lib/chewy/query/nodes/not.rb +0 -25
  184. data/lib/chewy/query/nodes/or.rb +0 -25
  185. data/lib/chewy/query/nodes/prefix.rb +0 -19
  186. data/lib/chewy/query/nodes/query.rb +0 -20
  187. data/lib/chewy/query/nodes/range.rb +0 -63
  188. data/lib/chewy/query/nodes/raw.rb +0 -15
  189. data/lib/chewy/query/nodes/regexp.rb +0 -35
  190. data/lib/chewy/query/nodes/script.rb +0 -20
  191. data/lib/chewy/query/pagination.rb +0 -25
  192. data/lib/chewy/query.rb +0 -1098
  193. data/lib/chewy/search/pagination/will_paginate.rb +0 -43
  194. data/lib/chewy/search/parameters/types.rb +0 -20
  195. data/lib/chewy/strategy/resque.rb +0 -27
  196. data/lib/chewy/strategy/shoryuken.rb +0 -40
  197. data/lib/chewy/type/actions.rb +0 -43
  198. data/lib/chewy/type/adapter/mongoid.rb +0 -69
  199. data/lib/chewy/type/adapter/sequel.rb +0 -95
  200. data/lib/chewy/type/crutch.rb +0 -32
  201. data/lib/chewy/type/import/bulk_builder.rb +0 -122
  202. data/lib/chewy/type/observe.rb +0 -78
  203. data/lib/chewy/type.rb +0 -117
  204. data/lib/sequel/plugins/chewy_observe.rb +0 -78
  205. data/spec/chewy/query/criteria_spec.rb +0 -700
  206. data/spec/chewy/query/filters_spec.rb +0 -201
  207. data/spec/chewy/query/loading_spec.rb +0 -124
  208. data/spec/chewy/query/nodes/and_spec.rb +0 -12
  209. data/spec/chewy/query/nodes/bool_spec.rb +0 -14
  210. data/spec/chewy/query/nodes/equal_spec.rb +0 -32
  211. data/spec/chewy/query/nodes/exists_spec.rb +0 -18
  212. data/spec/chewy/query/nodes/has_child_spec.rb +0 -59
  213. data/spec/chewy/query/nodes/has_parent_spec.rb +0 -59
  214. data/spec/chewy/query/nodes/match_all_spec.rb +0 -11
  215. data/spec/chewy/query/nodes/missing_spec.rb +0 -16
  216. data/spec/chewy/query/nodes/not_spec.rb +0 -13
  217. data/spec/chewy/query/nodes/or_spec.rb +0 -12
  218. data/spec/chewy/query/nodes/prefix_spec.rb +0 -16
  219. data/spec/chewy/query/nodes/query_spec.rb +0 -12
  220. data/spec/chewy/query/nodes/range_spec.rb +0 -32
  221. data/spec/chewy/query/nodes/raw_spec.rb +0 -11
  222. data/spec/chewy/query/nodes/regexp_spec.rb +0 -43
  223. data/spec/chewy/query/nodes/script_spec.rb +0 -15
  224. data/spec/chewy/query/pagination/kaminari_spec.rb +0 -5
  225. data/spec/chewy/query/pagination/will_paginate_spec.rb +0 -5
  226. data/spec/chewy/query/pagination_spec.rb +0 -39
  227. data/spec/chewy/query_spec.rb +0 -636
  228. data/spec/chewy/search/pagination/will_paginate_examples.rb +0 -63
  229. data/spec/chewy/search/pagination/will_paginate_spec.rb +0 -23
  230. data/spec/chewy/search/parameters/indices_boost_spec.rb +0 -83
  231. data/spec/chewy/search/parameters/types_spec.rb +0 -5
  232. data/spec/chewy/strategy/resque_spec.rb +0 -46
  233. data/spec/chewy/strategy/shoryuken_spec.rb +0 -64
  234. data/spec/chewy/type/actions_spec.rb +0 -50
  235. data/spec/chewy/type/adapter/mongoid_spec.rb +0 -372
  236. data/spec/chewy/type/adapter/sequel_spec.rb +0 -472
  237. data/spec/chewy/type/import/bulk_builder_spec.rb +0 -279
  238. data/spec/chewy/type/mapping_spec.rb +0 -142
  239. data/spec/chewy/type/observe_spec.rb +0 -137
  240. data/spec/chewy/type/wrapper_spec.rb +0 -98
  241. data/spec/chewy/type_spec.rb +0 -55
  242. data/spec/support/mongoid.rb +0 -93
  243. data/spec/support/sequel.rb +0 -80
@@ -1,6 +1,12 @@
1
1
  require 'spec_helper'
2
2
 
3
- describe Chewy::Type::Adapter::ActiveRecord, :active_record do
3
+ RawCity = Struct.new(:id) do
4
+ def rating
5
+ id * 10
6
+ end
7
+ end
8
+
9
+ describe Chewy::Index::Adapter::ActiveRecord, :active_record do
4
10
  before do
5
11
  stub_model(:city)
6
12
  stub_model(:country)
@@ -86,7 +92,19 @@ describe Chewy::Type::Adapter::ActiveRecord, :active_record do
86
92
  .to eq([{index: cities.first(2)}, {index: cities.last(1)}])
87
93
  end
88
94
 
89
- specify { expect(import(cities)).to eq([{index: cities}]) }
95
+ specify do
96
+ cities
97
+ expects_db_queries do
98
+ expect(import(cities, direct_import: false)).to eq([{index: cities}])
99
+ end
100
+ end
101
+ specify do
102
+ cities
103
+ expects_no_query do
104
+ expect(import(cities, direct_import: true)).to eq([{index: cities}])
105
+ end
106
+ end
107
+
90
108
  specify do
91
109
  expect(import(cities, batch_size: 2))
92
110
  .to eq([{index: cities.first(2)}, {index: cities.last(1)}])
@@ -369,11 +387,21 @@ describe Chewy::Type::Adapter::ActiveRecord, :active_record do
369
387
  context 'objects' do
370
388
  specify { expect(subject.import(cities + deleted) { |_data| true }).to eq(true) }
371
389
  specify { expect(subject.import(cities + deleted) { |_data| false }).to eq(false) }
372
- specify { expect(subject.import(cities + deleted, batch_size: 1, &data_comparer.curry[cities[0].id])).to eq(false) }
373
- specify { expect(subject.import(cities + deleted, batch_size: 1, &data_comparer.curry[cities[1].id])).to eq(false) }
374
- specify { expect(subject.import(cities + deleted, batch_size: 1, &data_comparer.curry[cities[2].id])).to eq(false) }
375
- specify { expect(subject.import(cities + deleted, batch_size: 1, &data_comparer.curry[deleted[0].id])).to eq(false) }
376
- specify { expect(subject.import(cities + deleted, batch_size: 1, &data_comparer.curry[deleted[1].id])).to eq(false) }
390
+ specify do
391
+ expect(subject.import(cities + deleted, batch_size: 1, &data_comparer.curry[cities[0].id])).to eq(false)
392
+ end
393
+ specify do
394
+ expect(subject.import(cities + deleted, batch_size: 1, &data_comparer.curry[cities[1].id])).to eq(false)
395
+ end
396
+ specify do
397
+ expect(subject.import(cities + deleted, batch_size: 1, &data_comparer.curry[cities[2].id])).to eq(false)
398
+ end
399
+ specify do
400
+ expect(subject.import(cities + deleted, batch_size: 1, &data_comparer.curry[deleted[0].id])).to eq(false)
401
+ end
402
+ specify do
403
+ expect(subject.import(cities + deleted, batch_size: 1, &data_comparer.curry[deleted[1].id])).to eq(false)
404
+ end
377
405
  end
378
406
 
379
407
  context 'ids' do
@@ -415,7 +443,10 @@ describe Chewy::Type::Adapter::ActiveRecord, :active_record do
415
443
  subject { described_class.new(Country.joins(:cities)) }
416
444
 
417
445
  specify { expect(subject.import_fields(Country.where('rating < 2'))).to match([contain_exactly(1, 2)]) }
418
- specify { expect(subject.import_fields(Country.where('rating < 2'), fields: [:rating])).to match([contain_exactly([1, 0], [2, 1])]) }
446
+ specify do
447
+ expect(subject.import_fields(Country.where('rating < 2'), fields: [:rating]))
448
+ .to match([contain_exactly([1, 0], [2, 1])])
449
+ end
419
450
  end
420
451
  end
421
452
 
@@ -424,21 +455,36 @@ describe Chewy::Type::Adapter::ActiveRecord, :active_record do
424
455
  specify { expect(subject.import_fields(1, 2, fields: [:rating])).to match([contain_exactly([1, 0], [2, 1])]) }
425
456
 
426
457
  specify { expect(subject.import_fields(countries.first(2))).to match([contain_exactly(1, 2)]) }
427
- specify { expect(subject.import_fields(countries.first(2), fields: [:rating])).to match([contain_exactly([1, 0], [2, 1])]) }
458
+ specify do
459
+ expect(subject.import_fields(countries.first(2), fields: [:rating]))
460
+ .to match([contain_exactly([1, 0], [2, 1])])
461
+ end
428
462
  end
429
463
 
430
464
  context 'batch_size' do
431
465
  specify { expect(subject.import_fields(batch_size: 2)).to match([contain_exactly(1, 2), [3]]) }
432
- specify { expect(subject.import_fields(batch_size: 2, fields: [:rating])).to match([contain_exactly([1, 0], [2, 1]), [[3, 2]]]) }
466
+ specify do
467
+ expect(subject.import_fields(batch_size: 2, fields: [:rating]))
468
+ .to match([contain_exactly([1, 0], [2, 1]), [[3, 2]]])
469
+ end
433
470
 
434
- specify { expect(subject.import_fields(Country.where('rating < 2'), batch_size: 2)).to match([contain_exactly(1, 2)]) }
435
- specify { expect(subject.import_fields(Country.where('rating < 2'), batch_size: 2, fields: [:rating])).to match([contain_exactly([1, 0], [2, 1])]) }
471
+ specify do
472
+ expect(subject.import_fields(Country.where('rating < 2'), batch_size: 2))
473
+ .to match([contain_exactly(1, 2)])
474
+ end
475
+ specify do
476
+ expect(subject.import_fields(Country.where('rating < 2'), batch_size: 2, fields: [:rating]))
477
+ .to match([contain_exactly([1, 0], [2, 1])])
478
+ end
436
479
 
437
480
  specify { expect(subject.import_fields(1, 2, batch_size: 1)).to match([[1], [2]]) }
438
481
  specify { expect(subject.import_fields(1, 2, batch_size: 1, fields: [:rating])).to match([[[1, 0]], [[2, 1]]]) }
439
482
 
440
483
  specify { expect(subject.import_fields(countries.first(2), batch_size: 1)).to match([[1], [2]]) }
441
- specify { expect(subject.import_fields(countries.first(2), batch_size: 1, fields: [:rating])).to match([[[1, 0]], [[2, 1]]]) }
484
+ specify do
485
+ expect(subject.import_fields(countries.first(2), batch_size: 1, fields: [:rating]))
486
+ .to match([[[1, 0]], [[2, 1]]])
487
+ end
442
488
  end
443
489
 
444
490
  context 'typecast' do
@@ -454,9 +500,9 @@ describe Chewy::Type::Adapter::ActiveRecord, :active_record do
454
500
  specify do
455
501
  expect(subject.import_fields(fields: [:updated_at], typecast: false))
456
502
  .to match([contain_exactly(
457
- [1, match(/#{Time.now.strftime('%Y-%m-%d')}/)],
458
- [2, match(/#{Time.now.strftime('%Y-%m-%d')}/)],
459
- [3, match(/#{Time.now.strftime('%Y-%m-%d')}/)]
503
+ [1, match(/#{Time.now.utc.strftime('%Y-%m-%d')}/)],
504
+ [2, match(/#{Time.now.utc.strftime('%Y-%m-%d')}/)],
505
+ [3, match(/#{Time.now.utc.strftime('%Y-%m-%d')}/)]
460
506
  )])
461
507
  end
462
508
  end
@@ -469,31 +515,29 @@ describe Chewy::Type::Adapter::ActiveRecord, :active_record do
469
515
  let(:city_ids) { cities.map(&:id) }
470
516
  let(:deleted_ids) { deleted.map(&:id) }
471
517
 
472
- let(:type) { double(type_name: 'user') }
473
-
474
518
  subject { described_class.new(City) }
475
519
 
476
- specify { expect(subject.load(city_ids, _type: type)).to eq(cities) }
477
- specify { expect(subject.load(city_ids.reverse, _type: type)).to eq(cities.reverse) }
478
- specify { expect(subject.load(deleted_ids, _type: type)).to eq([nil, nil]) }
479
- specify { expect(subject.load(city_ids + deleted_ids, _type: type)).to eq([*cities, nil, nil]) }
520
+ specify { expect(subject.load(city_ids, _index: 'users')).to eq(cities) }
521
+ specify { expect(subject.load(city_ids.reverse, _index: 'users')).to eq(cities.reverse) }
522
+ specify { expect(subject.load(deleted_ids, _index: 'users')).to eq([nil, nil]) }
523
+ specify { expect(subject.load(city_ids + deleted_ids, _index: 'users')).to eq([*cities, nil, nil]) }
480
524
  specify do
481
- expect(subject.load(city_ids, _type: type, scope: -> { where(rating: 0) }))
525
+ expect(subject.load(city_ids, _index: 'users', scope: -> { where(rating: 0) }))
482
526
  .to eq(cities.first(2) + [nil])
483
527
  end
484
528
  specify do
485
- expect(subject.load(city_ids,
486
- _type: type, scope: -> { where(rating: 0) }, user: {scope: -> { where(rating: 1) }}))
487
- .to eq([nil, nil] + cities.last(1))
529
+ expect(
530
+ subject.load(city_ids, _index: 'users', scope: -> { where(rating: 0) }, users: {scope: -> { where(rating: 1) }})
531
+ ).to eq([nil, nil] + cities.last(1))
488
532
  end
489
533
  specify do
490
- expect(subject.load(city_ids, _type: type, scope: City.where(rating: 1)))
534
+ expect(subject.load(city_ids, _index: 'users', scope: City.where(rating: 1)))
491
535
  .to eq([nil, nil] + cities.last(1))
492
536
  end
493
537
  specify do
494
- expect(subject.load(city_ids,
495
- _type: type, scope: City.where(rating: 1), user: {scope: -> { where(rating: 0) }}))
496
- .to eq(cities.first(2) + [nil])
538
+ expect(
539
+ subject.load(city_ids, _index: 'users', scope: City.where(rating: 1), users: {scope: -> { where(rating: 0) }})
540
+ ).to eq(cities.first(2) + [nil])
497
541
  end
498
542
  end
499
543
 
@@ -504,31 +548,53 @@ describe Chewy::Type::Adapter::ActiveRecord, :active_record do
504
548
  let(:city_ids) { cities.map(&:rating) }
505
549
  let(:deleted_ids) { deleted.map(&:rating) }
506
550
 
507
- let(:type) { double(type_name: 'user') }
508
-
509
551
  subject { described_class.new(City) }
510
552
 
511
- specify { expect(subject.load(city_ids, _type: type)).to eq(cities) }
512
- specify { expect(subject.load(city_ids.reverse, _type: type)).to eq(cities.reverse) }
513
- specify { expect(subject.load(deleted_ids, _type: type)).to eq([nil, nil]) }
514
- specify { expect(subject.load(city_ids + deleted_ids, _type: type)).to eq([*cities, nil, nil]) }
553
+ specify { expect(subject.load(city_ids, _index: 'users')).to eq(cities) }
554
+ specify { expect(subject.load(city_ids.reverse, _index: 'users')).to eq(cities.reverse) }
555
+ specify { expect(subject.load(deleted_ids, _index: 'users')).to eq([nil, nil]) }
556
+ specify { expect(subject.load(city_ids + deleted_ids, _index: 'users')).to eq([*cities, nil, nil]) }
515
557
  specify do
516
- expect(subject.load(city_ids, _type: type, scope: -> { where(country_id: 0) }))
558
+ expect(subject.load(city_ids, _index: 'users', scope: -> { where(country_id: 0) }))
517
559
  .to eq(cities.first(2) + [nil])
518
560
  end
519
561
  specify do
520
- expect(subject.load(city_ids,
521
- _type: type, scope: -> { where(country_id: 0) }, user: {scope: -> { where(country_id: 1) }}))
522
- .to eq([nil, nil] + cities.last(1))
562
+ expect(
563
+ subject.load(
564
+ city_ids, _index: 'users', scope: -> { where(country_id: 0) }, users: {scope: -> { where(country_id: 1) }}
565
+ )
566
+ ).to eq([nil, nil] + cities.last(1))
523
567
  end
524
568
  specify do
525
- expect(subject.load(city_ids, _type: type, scope: City.where(country_id: 1)))
569
+ expect(subject.load(city_ids, _index: 'users', scope: City.where(country_id: 1)))
526
570
  .to eq([nil, nil] + cities.last(1))
527
571
  end
528
572
  specify do
529
- expect(subject.load(city_ids,
530
- _type: type, scope: City.where(country_id: 1), user: {scope: -> { where(country_id: 0) }}))
531
- .to eq(cities.first(2) + [nil])
573
+ expect(
574
+ subject.load(
575
+ city_ids, _index: 'users', scope: City.where(country_id: 1), users: {scope: -> { where(country_id: 0) }}
576
+ )
577
+ ).to eq(cities.first(2) + [nil])
578
+ end
579
+ end
580
+
581
+ context 'with raw_import option' do
582
+ subject { described_class.new(City) }
583
+
584
+ let!(:cities) { Array.new(3) { |i| City.create!(rating: i / 2) } }
585
+ let(:city_ids) { cities.map(&:id) }
586
+
587
+ let(:raw_import) { ->(hash) { RawCity.new(hash['id']) } }
588
+ it 'uses the custom loader' do
589
+ raw_cities = subject.load(city_ids, _index: 'cities', raw_import: raw_import).map do |c|
590
+ {id: c.id, rating: c.rating}
591
+ end
592
+
593
+ expect(raw_cities).to eq([
594
+ {id: 1, rating: 10},
595
+ {id: 2, rating: 20},
596
+ {id: 3, rating: 30}
597
+ ])
532
598
  end
533
599
  end
534
600
  end
@@ -1,6 +1,6 @@
1
1
  require 'spec_helper'
2
2
 
3
- describe Chewy::Type::Adapter::Object do
3
+ describe Chewy::Index::Adapter::Object do
4
4
  before { stub_class(:product) }
5
5
  subject { described_class.new(:product) }
6
6
 
@@ -104,7 +104,13 @@ describe Chewy::Type::Adapter::Object do
104
104
  end
105
105
 
106
106
  context 'error handling' do
107
- let(:products) { Array.new(3) { |i| double.tap { |product| allow(product).to receive_messages(rating: i.next) } } }
107
+ let(:products) do
108
+ Array.new(3) do |i|
109
+ double.tap do |product|
110
+ allow(product).to receive_messages(rating: i.next)
111
+ end
112
+ end
113
+ end
108
114
  let(:deleted) { Array.new(2) { |i| double(destroyed?: true, rating: i + 4) } }
109
115
  subject { described_class.new('product') }
110
116
 
@@ -135,13 +141,18 @@ describe Chewy::Type::Adapter::Object do
135
141
  context do
136
142
  subject { described_class.new(-> { objects }) }
137
143
  specify { expect(subject.import_fields(batch_size: 2)).to match([[1, 2], [3]]) }
138
- specify { expect(subject.import_fields(fields: [:name], batch_size: 2)).to match([[[1, 'Name0'], [2, 'Name1']], [[3, 'Name2']]]) }
144
+ specify do
145
+ expect(subject.import_fields(fields: [:name], batch_size: 2))
146
+ .to match([[[1, 'Name0'], [2, 'Name1']], [[3, 'Name2']]])
147
+ end
139
148
  end
140
149
 
141
150
  context do
142
151
  subject { described_class.new(-> { objects }) }
143
152
  specify { expect(subject.import_fields(objects.first(2))).to match([[1, 2]]) }
144
- specify { expect(subject.import_fields(objects.first(2), fields: [:name])).to match([[[1, 'Name0'], [2, 'Name1']]]) }
153
+ specify do
154
+ expect(subject.import_fields(objects.first(2), fields: [:name])).to match([[[1, 'Name0'], [2, 'Name1']]])
155
+ end
145
156
  end
146
157
 
147
158
  context do
@@ -178,7 +189,9 @@ describe Chewy::Type::Adapter::Object do
178
189
  context do
179
190
  subject { described_class.new(Product) }
180
191
  specify { expect(subject.import_fields(objects.first(2))).to match([[1, 2]]) }
181
- specify { expect(subject.import_fields(objects.first(2), fields: [:name])).to match([[[1, 'Name0'], [2, 'Name1']]]) }
192
+ specify do
193
+ expect(subject.import_fields(objects.first(2), fields: [:name])).to match([[[1, 'Name0'], [2, 'Name1']]])
194
+ end
182
195
  end
183
196
 
184
197
  context 'batch_size' do
@@ -196,7 +209,9 @@ describe Chewy::Type::Adapter::Object do
196
209
  specify { expect(subject.import_references).to match([objects]) }
197
210
  specify { expect(subject.import_references(batch_size: 2)).to match([objects.first(2), objects.last(1)]) }
198
211
  specify { expect(subject.import_references(objects.first(2))).to match([objects.first(2)]) }
199
- specify { expect(subject.import_references(objects.first(2), batch_size: 1)).to match([objects.first(1), [objects[1]]]) }
212
+ specify do
213
+ expect(subject.import_references(objects.first(2), batch_size: 1)).to match([objects.first(1), [objects[1]]])
214
+ end
200
215
  end
201
216
 
202
217
  describe '#load' do
@@ -10,13 +10,13 @@ describe Chewy::Index::Aliases do
10
10
 
11
11
  context do
12
12
  before { DummiesIndex.create! }
13
- specify { expect(DummiesIndex.indexes).to eq([]) }
13
+ specify { expect(DummiesIndex.indexes).to eq(['dummies']) }
14
14
  end
15
15
 
16
16
  context do
17
17
  before { DummiesIndex.create! }
18
18
  before { Chewy.client.indices.put_alias index: 'dummies', name: 'dummies_2013' }
19
- specify { expect(DummiesIndex.indexes).to eq([]) }
19
+ specify { expect(DummiesIndex.indexes).to eq(['dummies']) }
20
20
  end
21
21
 
22
22
  context do
@@ -43,7 +43,7 @@ describe Chewy::Index::Aliases do
43
43
 
44
44
  context do
45
45
  before { DummiesIndex.create! '2013' }
46
- specify { expect(DummiesIndex.aliases).to eq([]) }
46
+ specify { expect(DummiesIndex.aliases).to eq(['dummies']) }
47
47
  end
48
48
  end
49
49
  end