chewy 0.9.0 → 5.2.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (275) hide show
  1. checksums.yaml +5 -5
  2. data/.circleci/config.yml +214 -0
  3. data/.gitignore +1 -0
  4. data/.rubocop.yml +41 -19
  5. data/.rubocop_todo.yml +2 -2
  6. data/.yardopts +5 -0
  7. data/Appraisals +58 -28
  8. data/CHANGELOG.md +153 -12
  9. data/Gemfile +20 -12
  10. data/LEGACY_DSL.md +497 -0
  11. data/LICENSE.txt +1 -1
  12. data/README.md +338 -528
  13. data/chewy.gemspec +11 -12
  14. data/gemfiles/rails.5.2.activerecord.gemfile +17 -0
  15. data/gemfiles/rails.5.2.mongoid.6.4.gemfile +17 -0
  16. data/gemfiles/rails.6.0.activerecord.gemfile +17 -0
  17. data/gemfiles/rails.6.1.activerecord.gemfile +19 -0
  18. data/gemfiles/ruby3.gemfile +10 -0
  19. data/gemfiles/sequel.4.45.gemfile +11 -0
  20. data/lib/chewy.rb +79 -44
  21. data/lib/chewy/backports/duplicable.rb +1 -1
  22. data/lib/chewy/config.rb +43 -17
  23. data/lib/chewy/errors.rb +2 -2
  24. data/lib/chewy/fields/base.rb +56 -31
  25. data/lib/chewy/fields/root.rb +44 -11
  26. data/lib/chewy/index.rb +237 -149
  27. data/lib/chewy/index/actions.rb +100 -35
  28. data/lib/chewy/index/aliases.rb +2 -1
  29. data/lib/chewy/index/settings.rb +11 -5
  30. data/lib/chewy/index/specification.rb +60 -0
  31. data/lib/chewy/journal.rb +40 -92
  32. data/lib/chewy/minitest/helpers.rb +6 -6
  33. data/lib/chewy/minitest/search_index_receiver.rb +17 -17
  34. data/lib/chewy/query.rb +182 -122
  35. data/lib/chewy/query/compose.rb +13 -13
  36. data/lib/chewy/query/criteria.rb +13 -13
  37. data/lib/chewy/query/filters.rb +21 -4
  38. data/lib/chewy/query/loading.rb +1 -2
  39. data/lib/chewy/query/nodes/and.rb +2 -2
  40. data/lib/chewy/query/nodes/bool.rb +1 -1
  41. data/lib/chewy/query/nodes/equal.rb +2 -2
  42. data/lib/chewy/query/nodes/exists.rb +1 -1
  43. data/lib/chewy/query/nodes/field.rb +1 -1
  44. data/lib/chewy/query/nodes/has_relation.rb +2 -2
  45. data/lib/chewy/query/nodes/match_all.rb +1 -1
  46. data/lib/chewy/query/nodes/missing.rb +1 -1
  47. data/lib/chewy/query/nodes/not.rb +2 -2
  48. data/lib/chewy/query/nodes/or.rb +2 -2
  49. data/lib/chewy/query/nodes/prefix.rb +1 -1
  50. data/lib/chewy/query/nodes/query.rb +2 -2
  51. data/lib/chewy/query/nodes/range.rb +4 -4
  52. data/lib/chewy/query/nodes/regexp.rb +4 -4
  53. data/lib/chewy/query/nodes/script.rb +3 -3
  54. data/lib/chewy/query/pagination.rb +10 -1
  55. data/lib/chewy/railtie.rb +4 -3
  56. data/lib/chewy/rake_helper.rb +265 -48
  57. data/lib/chewy/rspec/update_index.rb +33 -27
  58. data/lib/chewy/search.rb +79 -26
  59. data/lib/chewy/search/loader.rb +83 -0
  60. data/lib/chewy/{query → search}/pagination/kaminari.rb +13 -5
  61. data/lib/chewy/search/pagination/will_paginate.rb +43 -0
  62. data/lib/chewy/search/parameters.rb +168 -0
  63. data/lib/chewy/search/parameters/aggs.rb +16 -0
  64. data/lib/chewy/search/parameters/allow_partial_search_results.rb +27 -0
  65. data/lib/chewy/search/parameters/concerns/bool_storage.rb +24 -0
  66. data/lib/chewy/search/parameters/concerns/hash_storage.rb +23 -0
  67. data/lib/chewy/search/parameters/concerns/integer_storage.rb +14 -0
  68. data/lib/chewy/search/parameters/concerns/query_storage.rb +238 -0
  69. data/lib/chewy/search/parameters/concerns/string_array_storage.rb +23 -0
  70. data/lib/chewy/search/parameters/concerns/string_storage.rb +14 -0
  71. data/lib/chewy/search/parameters/docvalue_fields.rb +12 -0
  72. data/lib/chewy/search/parameters/explain.rb +16 -0
  73. data/lib/chewy/search/parameters/filter.rb +47 -0
  74. data/lib/chewy/search/parameters/highlight.rb +16 -0
  75. data/lib/chewy/search/parameters/indices.rb +123 -0
  76. data/lib/chewy/search/parameters/indices_boost.rb +52 -0
  77. data/lib/chewy/search/parameters/limit.rb +17 -0
  78. data/lib/chewy/search/parameters/load.rb +32 -0
  79. data/lib/chewy/search/parameters/min_score.rb +16 -0
  80. data/lib/chewy/search/parameters/none.rb +27 -0
  81. data/lib/chewy/search/parameters/offset.rb +17 -0
  82. data/lib/chewy/search/parameters/order.rb +64 -0
  83. data/lib/chewy/search/parameters/post_filter.rb +19 -0
  84. data/lib/chewy/search/parameters/preference.rb +16 -0
  85. data/lib/chewy/search/parameters/profile.rb +16 -0
  86. data/lib/chewy/search/parameters/query.rb +19 -0
  87. data/lib/chewy/search/parameters/request_cache.rb +27 -0
  88. data/lib/chewy/search/parameters/rescore.rb +29 -0
  89. data/lib/chewy/search/parameters/script_fields.rb +16 -0
  90. data/lib/chewy/search/parameters/search_after.rb +20 -0
  91. data/lib/chewy/search/parameters/search_type.rb +16 -0
  92. data/lib/chewy/search/parameters/source.rb +73 -0
  93. data/lib/chewy/search/parameters/storage.rb +95 -0
  94. data/lib/chewy/search/parameters/stored_fields.rb +63 -0
  95. data/lib/chewy/search/parameters/suggest.rb +16 -0
  96. data/lib/chewy/search/parameters/terminate_after.rb +16 -0
  97. data/lib/chewy/search/parameters/timeout.rb +16 -0
  98. data/lib/chewy/search/parameters/track_scores.rb +16 -0
  99. data/lib/chewy/search/parameters/types.rb +20 -0
  100. data/lib/chewy/search/parameters/version.rb +16 -0
  101. data/lib/chewy/search/query_proxy.rb +257 -0
  102. data/lib/chewy/search/request.rb +1046 -0
  103. data/lib/chewy/search/response.rb +119 -0
  104. data/lib/chewy/search/scoping.rb +50 -0
  105. data/lib/chewy/search/scrolling.rb +134 -0
  106. data/lib/chewy/stash.rb +79 -0
  107. data/lib/chewy/strategy.rb +10 -3
  108. data/lib/chewy/strategy/active_job.rb +2 -1
  109. data/lib/chewy/strategy/atomic.rb +2 -4
  110. data/lib/chewy/strategy/bypass.rb +1 -1
  111. data/lib/chewy/strategy/resque.rb +1 -0
  112. data/lib/chewy/strategy/shoryuken.rb +40 -0
  113. data/lib/chewy/strategy/sidekiq.rb +13 -3
  114. data/lib/chewy/type.rb +29 -7
  115. data/lib/chewy/type/actions.rb +26 -2
  116. data/lib/chewy/type/adapter/active_record.rb +44 -29
  117. data/lib/chewy/type/adapter/base.rb +27 -7
  118. data/lib/chewy/type/adapter/mongoid.rb +19 -10
  119. data/lib/chewy/type/adapter/object.rb +187 -26
  120. data/lib/chewy/type/adapter/orm.rb +59 -32
  121. data/lib/chewy/type/adapter/sequel.rb +33 -19
  122. data/lib/chewy/type/crutch.rb +1 -1
  123. data/lib/chewy/type/import.rb +146 -191
  124. data/lib/chewy/type/import/bulk_builder.rb +122 -0
  125. data/lib/chewy/type/import/bulk_request.rb +78 -0
  126. data/lib/chewy/type/import/journal_builder.rb +45 -0
  127. data/lib/chewy/type/import/routine.rb +138 -0
  128. data/lib/chewy/type/mapping.rb +51 -35
  129. data/lib/chewy/type/observe.rb +17 -13
  130. data/lib/chewy/type/syncer.rb +222 -0
  131. data/lib/chewy/type/witchcraft.rb +32 -16
  132. data/lib/chewy/type/wrapper.rb +30 -4
  133. data/lib/chewy/version.rb +1 -1
  134. data/lib/sequel/plugins/chewy_observe.rb +4 -19
  135. data/lib/tasks/chewy.rake +84 -26
  136. data/spec/chewy/config_spec.rb +98 -1
  137. data/spec/chewy/fields/base_spec.rb +170 -135
  138. data/spec/chewy/fields/root_spec.rb +124 -20
  139. data/spec/chewy/fields/time_fields_spec.rb +2 -3
  140. data/spec/chewy/index/actions_spec.rb +214 -52
  141. data/spec/chewy/index/aliases_spec.rb +2 -2
  142. data/spec/chewy/index/settings_spec.rb +67 -38
  143. data/spec/chewy/index/specification_spec.rb +169 -0
  144. data/spec/chewy/index_spec.rb +108 -64
  145. data/spec/chewy/journal_spec.rb +150 -55
  146. data/spec/chewy/minitest/helpers_spec.rb +4 -4
  147. data/spec/chewy/minitest/search_index_receiver_spec.rb +1 -1
  148. data/spec/chewy/query/criteria_spec.rb +179 -179
  149. data/spec/chewy/query/filters_spec.rb +16 -16
  150. data/spec/chewy/query/loading_spec.rb +22 -20
  151. data/spec/chewy/query/nodes/and_spec.rb +2 -2
  152. data/spec/chewy/query/nodes/bool_spec.rb +4 -4
  153. data/spec/chewy/query/nodes/equal_spec.rb +19 -19
  154. data/spec/chewy/query/nodes/exists_spec.rb +6 -6
  155. data/spec/chewy/query/nodes/has_child_spec.rb +19 -19
  156. data/spec/chewy/query/nodes/has_parent_spec.rb +19 -19
  157. data/spec/chewy/query/nodes/missing_spec.rb +5 -5
  158. data/spec/chewy/query/nodes/not_spec.rb +4 -2
  159. data/spec/chewy/query/nodes/or_spec.rb +2 -2
  160. data/spec/chewy/query/nodes/prefix_spec.rb +5 -5
  161. data/spec/chewy/query/nodes/query_spec.rb +2 -2
  162. data/spec/chewy/query/nodes/range_spec.rb +18 -18
  163. data/spec/chewy/query/nodes/raw_spec.rb +1 -1
  164. data/spec/chewy/query/nodes/regexp_spec.rb +14 -14
  165. data/spec/chewy/query/nodes/script_spec.rb +4 -4
  166. data/spec/chewy/query/pagination/kaminari_spec.rb +3 -55
  167. data/spec/chewy/query/pagination/will_paginate_spec.rb +5 -0
  168. data/spec/chewy/query/pagination_spec.rb +25 -21
  169. data/spec/chewy/query_spec.rb +503 -561
  170. data/spec/chewy/rake_helper_spec.rb +381 -0
  171. data/spec/chewy/repository_spec.rb +4 -4
  172. data/spec/chewy/rspec/update_index_spec.rb +89 -56
  173. data/spec/chewy/runtime_spec.rb +2 -2
  174. data/spec/chewy/search/loader_spec.rb +117 -0
  175. data/spec/chewy/search/pagination/kaminari_examples.rb +71 -0
  176. data/spec/chewy/search/pagination/kaminari_spec.rb +21 -0
  177. data/spec/chewy/search/pagination/will_paginate_examples.rb +63 -0
  178. data/spec/chewy/search/pagination/will_paginate_spec.rb +23 -0
  179. data/spec/chewy/search/parameters/aggs_spec.rb +5 -0
  180. data/spec/chewy/search/parameters/bool_storage_examples.rb +53 -0
  181. data/spec/chewy/search/parameters/docvalue_fields_spec.rb +5 -0
  182. data/spec/chewy/search/parameters/explain_spec.rb +5 -0
  183. data/spec/chewy/search/parameters/filter_spec.rb +5 -0
  184. data/spec/chewy/search/parameters/hash_storage_examples.rb +59 -0
  185. data/spec/chewy/search/parameters/highlight_spec.rb +5 -0
  186. data/spec/chewy/search/parameters/indices_spec.rb +191 -0
  187. data/spec/chewy/search/parameters/integer_storage_examples.rb +32 -0
  188. data/spec/chewy/search/parameters/limit_spec.rb +5 -0
  189. data/spec/chewy/search/parameters/load_spec.rb +60 -0
  190. data/spec/chewy/search/parameters/min_score_spec.rb +32 -0
  191. data/spec/chewy/search/parameters/none_spec.rb +5 -0
  192. data/spec/chewy/search/parameters/offset_spec.rb +5 -0
  193. data/spec/chewy/search/parameters/order_spec.rb +65 -0
  194. data/spec/chewy/search/parameters/post_filter_spec.rb +5 -0
  195. data/spec/chewy/search/parameters/preference_spec.rb +5 -0
  196. data/spec/chewy/search/parameters/profile_spec.rb +5 -0
  197. data/spec/chewy/search/parameters/query_spec.rb +5 -0
  198. data/spec/chewy/search/parameters/query_storage_examples.rb +388 -0
  199. data/spec/chewy/search/parameters/request_cache_spec.rb +67 -0
  200. data/spec/chewy/search/parameters/rescore_spec.rb +62 -0
  201. data/spec/chewy/search/parameters/script_fields_spec.rb +5 -0
  202. data/spec/chewy/search/parameters/search_after_spec.rb +32 -0
  203. data/spec/chewy/search/parameters/search_type_spec.rb +5 -0
  204. data/spec/chewy/search/parameters/source_spec.rb +156 -0
  205. data/spec/chewy/search/parameters/storage_spec.rb +60 -0
  206. data/spec/chewy/search/parameters/stored_fields_spec.rb +126 -0
  207. data/spec/chewy/search/parameters/string_array_storage_examples.rb +63 -0
  208. data/spec/chewy/search/parameters/string_storage_examples.rb +32 -0
  209. data/spec/chewy/search/parameters/suggest_spec.rb +5 -0
  210. data/spec/chewy/search/parameters/terminate_after_spec.rb +5 -0
  211. data/spec/chewy/search/parameters/timeout_spec.rb +5 -0
  212. data/spec/chewy/search/parameters/track_scores_spec.rb +5 -0
  213. data/spec/chewy/search/parameters/types_spec.rb +5 -0
  214. data/spec/chewy/search/parameters/version_spec.rb +5 -0
  215. data/spec/chewy/search/parameters_spec.rb +147 -0
  216. data/spec/chewy/search/query_proxy_spec.rb +68 -0
  217. data/spec/chewy/search/request_spec.rb +685 -0
  218. data/spec/chewy/search/response_spec.rb +198 -0
  219. data/spec/chewy/search/scrolling_spec.rb +169 -0
  220. data/spec/chewy/search_spec.rb +33 -16
  221. data/spec/chewy/stash_spec.rb +95 -0
  222. data/spec/chewy/strategy/active_job_spec.rb +21 -2
  223. data/spec/chewy/strategy/resque_spec.rb +6 -0
  224. data/spec/chewy/strategy/shoryuken_spec.rb +70 -0
  225. data/spec/chewy/strategy/sidekiq_spec.rb +13 -1
  226. data/spec/chewy/strategy_spec.rb +6 -6
  227. data/spec/chewy/type/actions_spec.rb +29 -10
  228. data/spec/chewy/type/adapter/active_record_spec.rb +203 -91
  229. data/spec/chewy/type/adapter/mongoid_spec.rb +112 -54
  230. data/spec/chewy/type/adapter/object_spec.rb +101 -28
  231. data/spec/chewy/type/adapter/sequel_spec.rb +149 -82
  232. data/spec/chewy/type/import/bulk_builder_spec.rb +279 -0
  233. data/spec/chewy/type/import/bulk_request_spec.rb +102 -0
  234. data/spec/chewy/type/import/journal_builder_spec.rb +95 -0
  235. data/spec/chewy/type/import/routine_spec.rb +110 -0
  236. data/spec/chewy/type/import_spec.rb +356 -271
  237. data/spec/chewy/type/mapping_spec.rb +96 -29
  238. data/spec/chewy/type/observe_spec.rb +9 -5
  239. data/spec/chewy/type/syncer_spec.rb +123 -0
  240. data/spec/chewy/type/witchcraft_spec.rb +61 -29
  241. data/spec/chewy/type/wrapper_spec.rb +63 -23
  242. data/spec/chewy/type_spec.rb +28 -7
  243. data/spec/chewy_spec.rb +75 -7
  244. data/spec/spec_helper.rb +17 -3
  245. data/spec/support/active_record.rb +5 -1
  246. data/spec/support/class_helpers.rb +0 -14
  247. data/spec/support/mongoid.rb +15 -3
  248. data/spec/support/sequel.rb +6 -1
  249. metadata +219 -58
  250. data/.travis.yml +0 -36
  251. data/gemfiles/rails.3.2.activerecord.gemfile +0 -16
  252. data/gemfiles/rails.3.2.activerecord.kaminari.gemfile +0 -15
  253. data/gemfiles/rails.3.2.activerecord.will_paginate.gemfile +0 -15
  254. data/gemfiles/rails.4.2.activerecord.gemfile +0 -17
  255. data/gemfiles/rails.4.2.activerecord.kaminari.gemfile +0 -16
  256. data/gemfiles/rails.4.2.activerecord.will_paginate.gemfile +0 -16
  257. data/gemfiles/rails.4.2.mongoid.4.0.gemfile +0 -16
  258. data/gemfiles/rails.4.2.mongoid.4.0.kaminari.gemfile +0 -15
  259. data/gemfiles/rails.4.2.mongoid.4.0.will_paginate.gemfile +0 -15
  260. data/gemfiles/rails.4.2.mongoid.5.1.gemfile +0 -16
  261. data/gemfiles/rails.4.2.mongoid.5.1.kaminari.gemfile +0 -15
  262. data/gemfiles/rails.4.2.mongoid.5.1.will_paginate.gemfile +0 -15
  263. data/gemfiles/rails.5.0.activerecord.gemfile +0 -17
  264. data/gemfiles/rails.5.0.activerecord.kaminari.gemfile +0 -16
  265. data/gemfiles/rails.5.0.activerecord.will_paginate.gemfile +0 -16
  266. data/gemfiles/sequel.4.38.gemfile +0 -14
  267. data/lib/chewy/journal/apply.rb +0 -31
  268. data/lib/chewy/journal/clean.rb +0 -24
  269. data/lib/chewy/journal/entry.rb +0 -83
  270. data/lib/chewy/journal/query.rb +0 -87
  271. data/lib/chewy/query/pagination/will_paginate.rb +0 -27
  272. data/lib/chewy/query/scoping.rb +0 -20
  273. data/spec/chewy/journal/apply_spec.rb +0 -120
  274. data/spec/chewy/journal/entry_spec.rb +0 -237
  275. data/spec/chewy/query/pagination/will_paginage_spec.rb +0 -59
@@ -0,0 +1,381 @@
1
+ require 'spec_helper'
2
+
3
+ describe Chewy::RakeHelper, :orm do
4
+ before { Chewy.massacre }
5
+
6
+ before do
7
+ stub_model(:city)
8
+ stub_model(:country)
9
+
10
+ stub_index(:places) do
11
+ define_type City do
12
+ field :name
13
+ field :updated_at, type: 'date'
14
+ end
15
+ define_type Country
16
+ end
17
+ stub_index(:users)
18
+
19
+ allow(described_class).to receive(:all_indexes) { [PlacesIndex, UsersIndex] }
20
+ end
21
+
22
+ let!(:cities) { Array.new(3) { |i| City.create!(name: "Name#{i + 1}") } }
23
+ let!(:countries) { Array.new(2) { |i| Country.create!(name: "Name#{i + 1}") } }
24
+ let(:journal) do
25
+ Chewy::Stash::Journal.import([
26
+ {
27
+ index_name: 'places',
28
+ type_name: 'city',
29
+ action: 'index',
30
+ references: cities.first(2).map(&:id).map(&:to_s)
31
+ .map(&:to_json).map(&Base64.method(:encode64)),
32
+ created_at: 2.minutes.since
33
+ },
34
+ {
35
+ index_name: 'places',
36
+ type_name: 'country',
37
+ action: 'index',
38
+ references: [Base64.encode64(countries.first.id.to_s.to_json)],
39
+ created_at: 4.minutes.since
40
+ }
41
+ ])
42
+ end
43
+
44
+ describe '.reset' do
45
+ before { journal }
46
+
47
+ specify do
48
+ output = StringIO.new
49
+ expect { described_class.reset(output: output) }
50
+ .to update_index(PlacesIndex::City)
51
+ expect(output.string).to match(Regexp.new(<<-OUTPUT, Regexp::MULTILINE))
52
+ \\AResetting PlacesIndex
53
+ Imported PlacesIndex::City in \\d+s, stats: index 3
54
+ Imported PlacesIndex::Country in \\d+s, stats: index 2
55
+ Applying journal to \\[PlacesIndex::City, PlacesIndex::Country\\], 3 entries, stage 1
56
+ Imported PlacesIndex::City in \\d+s, stats: index 2
57
+ Imported PlacesIndex::Country in \\d+s, stats: index 1
58
+ Imported Chewy::Stash::Specification::Specification in \\d+s, stats: index 1
59
+ Resetting UsersIndex
60
+ Imported Chewy::Stash::Specification::Specification in \\d+s, stats: index 1
61
+ Total: \\d+s\\Z
62
+ OUTPUT
63
+ end
64
+
65
+ specify do
66
+ output = StringIO.new
67
+ expect { described_class.reset(only: 'places', output: output) }
68
+ .to update_index(PlacesIndex::City)
69
+ expect(output.string).to match(Regexp.new(<<-OUTPUT, Regexp::MULTILINE))
70
+ \\AResetting PlacesIndex
71
+ Imported PlacesIndex::City in \\d+s, stats: index 3
72
+ Imported PlacesIndex::Country in \\d+s, stats: index 2
73
+ Applying journal to \\[PlacesIndex::City, PlacesIndex::Country\\], 3 entries, stage 1
74
+ Imported PlacesIndex::City in \\d+s, stats: index 2
75
+ Imported PlacesIndex::Country in \\d+s, stats: index 1
76
+ Imported Chewy::Stash::Specification::Specification in \\d+s, stats: index 1
77
+ Total: \\d+s\\Z
78
+ OUTPUT
79
+ end
80
+
81
+ specify do
82
+ output = StringIO.new
83
+ expect { described_class.reset(except: PlacesIndex, output: output) }
84
+ .not_to update_index(PlacesIndex::City)
85
+ expect(output.string).to match(Regexp.new(<<-OUTPUT, Regexp::MULTILINE))
86
+ \\AResetting UsersIndex
87
+ Imported Chewy::Stash::Specification::Specification in \\d+s, stats: index 1
88
+ Total: \\d+s\\Z
89
+ OUTPUT
90
+ end
91
+ end
92
+
93
+ describe '.upgrade' do
94
+ specify do
95
+ output = StringIO.new
96
+ expect { described_class.upgrade(output: output) }
97
+ .to update_index(PlacesIndex::City)
98
+ expect(output.string).to match(Regexp.new(<<-OUTPUT, Regexp::MULTILINE))
99
+ \\AResetting PlacesIndex
100
+ Imported PlacesIndex::City in \\d+s, stats: index 3
101
+ Imported PlacesIndex::Country in \\d+s, stats: index 2
102
+ Imported Chewy::Stash::Specification::Specification in \\d+s, stats: index 1
103
+ Resetting UsersIndex
104
+ Imported Chewy::Stash::Specification::Specification in \\d+s, stats: index 1
105
+ Total: \\d+s\\Z
106
+ OUTPUT
107
+ end
108
+
109
+ context do
110
+ before { PlacesIndex.reset! }
111
+
112
+ specify do
113
+ output = StringIO.new
114
+ expect { described_class.upgrade(output: output) }
115
+ .not_to update_index(PlacesIndex::City)
116
+ expect(output.string).to match(Regexp.new(<<-OUTPUT, Regexp::MULTILINE))
117
+ \\ASkipping PlacesIndex, the specification didn't change
118
+ Resetting UsersIndex
119
+ Imported Chewy::Stash::Specification::Specification in \\d+s, stats: index 1
120
+ Total: \\d+s\\Z
121
+ OUTPUT
122
+ end
123
+
124
+ specify do
125
+ output = StringIO.new
126
+ expect { described_class.upgrade(except: PlacesIndex, output: output) }
127
+ .not_to update_index(PlacesIndex::City)
128
+ expect(output.string).to match(Regexp.new(<<-OUTPUT, Regexp::MULTILINE))
129
+ \\AResetting UsersIndex
130
+ Imported Chewy::Stash::Specification::Specification in \\d+s, stats: index 1
131
+ Total: \\d+s\\Z
132
+ OUTPUT
133
+ end
134
+
135
+ context do
136
+ before { UsersIndex.reset! }
137
+
138
+ specify do
139
+ output = StringIO.new
140
+ expect { described_class.upgrade(except: ['places'], output: output) }
141
+ .not_to update_index(PlacesIndex::City)
142
+ expect(output.string).to match(Regexp.new(<<-OUTPUT, Regexp::MULTILINE))
143
+ \\ANo index specification was changed
144
+ Total: \\d+s\\Z
145
+ OUTPUT
146
+ end
147
+ end
148
+ end
149
+ end
150
+
151
+ describe '.update' do
152
+ specify do
153
+ output = StringIO.new
154
+ expect { described_class.update(output: output) }
155
+ .not_to update_index(PlacesIndex::City)
156
+ expect(output.string).to match(Regexp.new(<<-OUTPUT, Regexp::MULTILINE))
157
+ \\ASkipping PlacesIndex, it does not exists \\(use rake chewy:reset\\[places\\] to create and update it\\)
158
+ OUTPUT
159
+ end
160
+
161
+ context do
162
+ before { PlacesIndex.reset! }
163
+
164
+ specify do
165
+ output = StringIO.new
166
+ expect { described_class.update(output: output) }
167
+ .to update_index(PlacesIndex::City)
168
+ expect(output.string).to match(Regexp.new(<<-OUTPUT, Regexp::MULTILINE))
169
+ \\AUpdating PlacesIndex
170
+ Imported PlacesIndex::City in \\d+s, stats: index 3
171
+ Imported PlacesIndex::Country in \\d+s, stats: index 2
172
+ Total: \\d+s\\Z
173
+ OUTPUT
174
+ end
175
+
176
+ specify do
177
+ output = StringIO.new
178
+ expect { described_class.update(only: 'places#country', output: output) }
179
+ .not_to update_index(PlacesIndex::City)
180
+ expect(output.string).to match(Regexp.new(<<-OUTPUT, Regexp::MULTILINE))
181
+ \\AUpdating PlacesIndex
182
+ Imported PlacesIndex::Country in \\d+s, stats: index 2
183
+ Total: \\d+s\\Z
184
+ OUTPUT
185
+ end
186
+
187
+ specify do
188
+ output = StringIO.new
189
+ expect { described_class.update(except: PlacesIndex::Country, output: output) }
190
+ .to update_index(PlacesIndex::City)
191
+ expect(output.string).to match(Regexp.new(<<-OUTPUT, Regexp::MULTILINE))
192
+ \\AUpdating PlacesIndex
193
+ Imported PlacesIndex::City in \\d+s, stats: index 3
194
+ Total: \\d+s\\Z
195
+ OUTPUT
196
+ end
197
+ end
198
+ end
199
+
200
+ describe '.sync' do
201
+ specify do
202
+ output = StringIO.new
203
+ expect { described_class.sync(output: output) }
204
+ .to update_index(PlacesIndex::City)
205
+ expect(output.string).to match(Regexp.new(<<-OUTPUT, Regexp::MULTILINE))
206
+ \\ASynchronizing PlacesIndex::City
207
+ Imported PlacesIndex::City in \\d+s, stats: index 3
208
+ Missing documents: \\[[^\\]]+\\]
209
+ Took \\d+s
210
+ Synchronizing PlacesIndex::Country
211
+ PlacesIndex::Country doesn't support outdated synchronization
212
+ Imported PlacesIndex::Country in \\d+s, stats: index 2
213
+ Missing documents: \\[[^\\]]+\\]
214
+ Took \\d+s
215
+ Total: \\d+s\\Z
216
+ OUTPUT
217
+ end
218
+
219
+ context do
220
+ before do
221
+ PlacesIndex::City.import(cities.first(2))
222
+ PlacesIndex::Country.import
223
+
224
+ sleep(1) if ActiveSupport::VERSION::STRING < '4.1.0'
225
+ cities.first.update(name: 'Name5')
226
+ end
227
+
228
+ specify do
229
+ output = StringIO.new
230
+ expect { described_class.sync(output: output) }
231
+ .to update_index(PlacesIndex::City)
232
+ expect(output.string).to match(Regexp.new(<<-OUTPUT, Regexp::MULTILINE))
233
+ \\ASynchronizing PlacesIndex::City
234
+ Imported PlacesIndex::City in \\d+s, stats: index 2
235
+ Missing documents: \\["#{cities.last.id}"\\]
236
+ Outdated documents: \\["#{cities.first.id}"\\]
237
+ Took \\d+s
238
+ Synchronizing PlacesIndex::Country
239
+ PlacesIndex::Country doesn't support outdated synchronization
240
+ Skipping PlacesIndex::Country, up to date
241
+ Took \\d+s
242
+ Total: \\d+s\\Z
243
+ OUTPUT
244
+ end
245
+
246
+ specify do
247
+ output = StringIO.new
248
+ expect { described_class.sync(only: PlacesIndex::City, output: output) }
249
+ .to update_index(PlacesIndex::City)
250
+ expect(output.string).to match(Regexp.new(<<-OUTPUT, Regexp::MULTILINE))
251
+ \\ASynchronizing PlacesIndex::City
252
+ Imported PlacesIndex::City in \\d+s, stats: index 2
253
+ Missing documents: \\["#{cities.last.id}"\\]
254
+ Outdated documents: \\["#{cities.first.id}"\\]
255
+ Took \\d+s
256
+ Total: \\d+s\\Z
257
+ OUTPUT
258
+ end
259
+
260
+ specify do
261
+ output = StringIO.new
262
+ expect { described_class.sync(except: ['places#city'], output: output) }
263
+ .not_to update_index(PlacesIndex::City)
264
+ expect(output.string).to match(Regexp.new(<<-OUTPUT, Regexp::MULTILINE))
265
+ \\ASynchronizing PlacesIndex::Country
266
+ PlacesIndex::Country doesn't support outdated synchronization
267
+ Skipping PlacesIndex::Country, up to date
268
+ Took \\d+s
269
+ Total: \\d+s\\Z
270
+ OUTPUT
271
+ end
272
+ end
273
+ end
274
+
275
+ describe '.journal_apply' do
276
+ specify { expect { described_class.journal_apply }.to raise_error ArgumentError }
277
+ specify do
278
+ output = StringIO.new
279
+ described_class.journal_apply(time: Time.now, output: output)
280
+ expect(output.string).to match(Regexp.new(<<-OUTPUT, Regexp::MULTILINE))
281
+ \\AApplying journal entries created after [+-:\\d\\s]+
282
+ No journal entries were created after the specified time
283
+ Total: \\d+s\\Z
284
+ OUTPUT
285
+ end
286
+
287
+ context do
288
+ before { journal }
289
+
290
+ specify do
291
+ output = StringIO.new
292
+ expect { described_class.journal_apply(time: Time.now, output: output) }
293
+ .to update_index(PlacesIndex::City)
294
+ expect(output.string).to match(Regexp.new(<<-OUTPUT, Regexp::MULTILINE))
295
+ \\AApplying journal entries created after [+-:\\d\\s]+
296
+ Applying journal to \\[PlacesIndex::City, PlacesIndex::Country\\], 3 entries, stage 1
297
+ Imported PlacesIndex::City in \\d+s, stats: index 2
298
+ Imported PlacesIndex::Country in \\d+s, stats: index 1
299
+ Total: \\d+s\\Z
300
+ OUTPUT
301
+ end
302
+
303
+ specify do
304
+ output = StringIO.new
305
+ expect { described_class.journal_apply(time: 3.minutes.since, output: output) }
306
+ .not_to update_index(PlacesIndex::City)
307
+ expect(output.string).to match(Regexp.new(<<-OUTPUT, Regexp::MULTILINE))
308
+ \\AApplying journal entries created after [+-:\\d\\s]+
309
+ Applying journal to \\[PlacesIndex::Country\\], 1 entries, stage 1
310
+ Imported PlacesIndex::Country in \\d+s, stats: index 1
311
+ Total: \\d+s\\Z
312
+ OUTPUT
313
+ end
314
+
315
+ specify do
316
+ output = StringIO.new
317
+ expect { described_class.journal_apply(time: Time.now, only: PlacesIndex::City, output: output) }
318
+ .to update_index(PlacesIndex::City)
319
+ expect(output.string).to match(Regexp.new(<<-OUTPUT, Regexp::MULTILINE))
320
+ \\AApplying journal entries created after [+-:\\d\\s]+
321
+ Applying journal to \\[PlacesIndex::City\\], 2 entries, stage 1
322
+ Imported PlacesIndex::City in \\d+s, stats: index 2
323
+ Total: \\d+s\\Z
324
+ OUTPUT
325
+ end
326
+
327
+ specify do
328
+ output = StringIO.new
329
+ expect { described_class.journal_apply(time: Time.now, except: PlacesIndex::City, output: output) }
330
+ .not_to update_index(PlacesIndex::City)
331
+ expect(output.string).to match(Regexp.new(<<-OUTPUT, Regexp::MULTILINE))
332
+ \\AApplying journal entries created after [+-:\\d\\s]+
333
+ Applying journal to \\[PlacesIndex::Country\\], 1 entries, stage 1
334
+ Imported PlacesIndex::Country in \\d+s, stats: index 1
335
+ Total: \\d+s\\Z
336
+ OUTPUT
337
+ end
338
+ end
339
+ end
340
+
341
+ describe '.journal_clean' do
342
+ before { journal }
343
+
344
+ specify do
345
+ output = StringIO.new
346
+ described_class.journal_clean(output: output)
347
+ expect(output.string).to match(Regexp.new(<<-OUTPUT, Regexp::MULTILINE))
348
+ \\ACleaned up 2 journal entries
349
+ Total: \\d+s\\Z
350
+ OUTPUT
351
+ end
352
+
353
+ specify do
354
+ output = StringIO.new
355
+ described_class.journal_clean(time: 3.minutes.since, output: output)
356
+ expect(output.string).to match(Regexp.new(<<-OUTPUT, Regexp::MULTILINE))
357
+ \\ACleaning journal entries created before [+-:\\d\\s]+
358
+ Cleaned up 1 journal entries
359
+ Total: \\d+s\\Z
360
+ OUTPUT
361
+ end
362
+
363
+ specify do
364
+ output = StringIO.new
365
+ described_class.journal_clean(only: PlacesIndex::City, output: output)
366
+ expect(output.string).to match(Regexp.new(<<-OUTPUT, Regexp::MULTILINE))
367
+ \\ACleaned up 1 journal entries
368
+ Total: \\d+s\\Z
369
+ OUTPUT
370
+ end
371
+
372
+ specify do
373
+ output = StringIO.new
374
+ described_class.journal_clean(except: PlacesIndex::City, output: output)
375
+ expect(output.string).to match(Regexp.new(<<-OUTPUT, Regexp::MULTILINE))
376
+ \\ACleaned up 1 journal entries
377
+ Total: \\d+s\\Z
378
+ OUTPUT
379
+ end
380
+ end
381
+ end
@@ -14,7 +14,7 @@ describe Chewy::Repository do
14
14
  context do
15
15
  before { subject.analyzer(:name, option: :foo) }
16
16
  specify { expect(subject.analyzer(:name)).to eq(option: :foo) }
17
- specify { expect(subject.analyzers).to eq(name: { option: :foo }) }
17
+ specify { expect(subject.analyzers).to eq(name: {option: :foo}) }
18
18
  end
19
19
  end
20
20
 
@@ -24,7 +24,7 @@ describe Chewy::Repository do
24
24
  context do
25
25
  before { subject.tokenizer(:name, option: :foo) }
26
26
  specify { expect(subject.tokenizer(:name)).to eq(option: :foo) }
27
- specify { expect(subject.tokenizers).to eq(name: { option: :foo }) }
27
+ specify { expect(subject.tokenizers).to eq(name: {option: :foo}) }
28
28
  end
29
29
  end
30
30
 
@@ -34,7 +34,7 @@ describe Chewy::Repository do
34
34
  context do
35
35
  before { subject.filter(:name, option: :foo) }
36
36
  specify { expect(subject.filter(:name)).to eq(option: :foo) }
37
- specify { expect(subject.filters).to eq(name: { option: :foo }) }
37
+ specify { expect(subject.filters).to eq(name: {option: :foo}) }
38
38
  end
39
39
  end
40
40
 
@@ -44,7 +44,7 @@ describe Chewy::Repository do
44
44
  context do
45
45
  before { subject.char_filter(:name, option: :foo) }
46
46
  specify { expect(subject.char_filter(:name)).to eq(option: :foo) }
47
- specify { expect(subject.char_filters).to eq(name: { option: :foo }) }
47
+ specify { expect(subject.char_filters).to eq(name: {option: :foo}) }
48
48
  end
49
49
  end
50
50
  end
@@ -1,70 +1,103 @@
1
1
  require 'spec_helper'
2
2
 
3
3
  describe :update_index do
4
- before { Chewy.massacre }
5
-
6
4
  before do
7
5
  stub_index(:dummies) do
8
- define_type :dummy do
9
- root value: ->(_o) { {} }
10
- end
6
+ define_type :dummy
7
+ define_type :dummy2
11
8
  end
12
9
  end
13
10
 
11
+ before do
12
+ Chewy.massacre
13
+ DummiesIndex.create!
14
+ end
15
+
14
16
  specify { expect {}.not_to update_index(DummiesIndex::Dummy) }
15
17
  specify { expect { DummiesIndex::Dummy.bulk body: [] }.not_to update_index(DummiesIndex::Dummy) }
16
18
 
17
19
  specify do
18
- expect { expect { DummiesIndex::Dummy.bulk body: [{ index: { _id: 42 } }] }.not_to update_index(DummiesIndex::Dummy) }
20
+ expect { expect { DummiesIndex::Dummy.bulk body: [{index: {_id: 42}}] }.not_to update_index(DummiesIndex::Dummy) }
19
21
  .to fail_with(/Expected index .* not to be updated, but it was with/)
20
22
  end
21
23
 
24
+ specify do
25
+ expect do
26
+ DummiesIndex::Dummy.bulk body: [{index: {_id: 42, data: {}}}, {index: {_id: 41, data: {}}}]
27
+ DummiesIndex::Dummy2.bulk body: [{index: {_id: 43, data: {}}}]
28
+ end.to update_index(DummiesIndex::Dummy).and_reindex(41, 42).only
29
+ end
30
+
22
31
  context do
23
32
  let(:expectation) do
24
33
  expect do
25
34
  expect do
26
- DummiesIndex::Dummy.bulk body: [{ index: { _id: 42 } }, { index: { _id: 41 } }, { index: { _id: 42 } }]
27
- end.not_to update_index(DummiesIndex::Dummy) end
35
+ DummiesIndex::Dummy.bulk body: [{index: {_id: 42}}, {index: {_id: 41}}, {index: {_id: 42}}]
36
+ end.not_to update_index(DummiesIndex::Dummy)
37
+ end
28
38
  end
29
39
 
30
40
  specify { expectation.to fail_matching 'document id `42` (2 times)' }
31
41
  specify { expectation.to fail_matching 'document id `41` (1 times)' }
32
42
  end
33
43
 
44
+ context 'compound matchers' do
45
+ specify do
46
+ expect do
47
+ DummiesIndex::Dummy.bulk body: [{index: {_id: 42, data: {}}}, {index: {_id: 41, data: {}}}]
48
+ DummiesIndex::Dummy2.bulk body: [{index: {_id: 43, data: {}}}]
49
+ end.to update_index(DummiesIndex::Dummy).and_reindex(41, 42).only
50
+ .and update_index(DummiesIndex::Dummy2).and_reindex(43).only
51
+ end
52
+
53
+ context do
54
+ let(:expectation) do
55
+ expect do
56
+ expect do
57
+ DummiesIndex::Dummy2.bulk body: [{index: {_id: 43, data: {}}}]
58
+ end.to update_index(DummiesIndex::Dummy).and_reindex(41, 42).only
59
+ .and update_index(DummiesIndex::Dummy2).and_reindex(43).only
60
+ end
61
+ end
62
+
63
+ specify { expectation.to fail_matching 'Expected index `DummiesIndex::Dummy` to be updated' }
64
+ end
65
+ end
66
+
34
67
  context '#only' do
35
68
  specify do
36
- expect { DummiesIndex::Dummy.bulk body: [{ index: { _id: 42, data: {} } }, { index: { _id: 41, data: {} } }] }
69
+ expect { DummiesIndex::Dummy.bulk body: [{index: {_id: 42, data: {}}}, {index: {_id: 41, data: {}}}] }
37
70
  .to update_index(DummiesIndex::Dummy).and_reindex(41, 42).only
38
71
  end
39
72
  specify do
40
73
  expect do
41
- expect { DummiesIndex::Dummy.bulk body: [{ index: { _id: 42, data: {} } }, { index: { _id: 41, data: {} } }] }
74
+ expect { DummiesIndex::Dummy.bulk body: [{index: {_id: 42, data: {}}}, {index: {_id: 41, data: {}}}] }
42
75
  .to update_index(DummiesIndex::Dummy).and_reindex(41).only
43
76
  end
44
77
  .to fail_matching 'to update documents ["41"] only, but ["42"] was updated also'
45
78
  end
46
79
  specify do
47
80
  expect do
48
- expect { DummiesIndex::Dummy.bulk body: [{ index: { _id: 42, data: {} } }, { index: { _id: 41, data: {} } }] }
81
+ expect { DummiesIndex::Dummy.bulk body: [{index: {_id: 42, data: {}}}, {index: {_id: 41, data: {}}}] }
49
82
  .to update_index(DummiesIndex::Dummy).and_reindex(41, times: 2).only
50
83
  end
51
84
  .to fail_matching 'to update documents ["41"] only, but ["42"] was updated also'
52
85
  end
53
86
 
54
87
  specify do
55
- expect { DummiesIndex::Dummy.bulk body: [{ delete: { _id: 42 } }, { delete: { _id: 41 } }] }
88
+ expect { DummiesIndex::Dummy.bulk body: [{delete: {_id: 42}}, {delete: {_id: 41}}] }
56
89
  .to update_index(DummiesIndex::Dummy).and_delete(41, 42).only
57
90
  end
58
91
  specify do
59
92
  expect do
60
- expect { DummiesIndex::Dummy.bulk body: [{ delete: { _id: 42 } }, { delete: { _id: 41 } }] }
93
+ expect { DummiesIndex::Dummy.bulk body: [{delete: {_id: 42}}, {delete: {_id: 41}}] }
61
94
  .to update_index(DummiesIndex::Dummy).and_delete(41).only
62
95
  end
63
96
  .to fail_matching 'to delete documents ["41"] only, but ["42"] was deleted also'
64
97
  end
65
98
  specify do
66
99
  expect do
67
- expect { DummiesIndex::Dummy.bulk body: [{ delete: { _id: 42 } }, { delete: { _id: 41 } }] }
100
+ expect { DummiesIndex::Dummy.bulk body: [{delete: {_id: 42}}, {delete: {_id: 41}}] }
68
101
  .to update_index(DummiesIndex::Dummy).and_delete(41, times: 2).only
69
102
  end
70
103
  .to fail_matching 'to delete documents ["41"] only, but ["42"] was deleted also'
@@ -72,28 +105,28 @@ describe :update_index do
72
105
 
73
106
  specify do
74
107
  expect do
75
- expect { DummiesIndex::Dummy.bulk body: [{ index: { _id: 42, data: {} } }, { delete: { _id: 41 } }] }
108
+ expect { DummiesIndex::Dummy.bulk body: [{index: {_id: 42, data: {}}}, {delete: {_id: 41}}] }
76
109
  .to update_index(DummiesIndex::Dummy).and_reindex(42).only
77
110
  end
78
111
  .to fail_matching 'to update documents ["42"] only, but ["41"] was deleted also'
79
112
  end
80
113
  specify do
81
114
  expect do
82
- expect { DummiesIndex::Dummy.bulk body: [{ index: { _id: 42, data: {} } }, { index: { _id: 43, data: {} } }, { delete: { _id: 41 } }] }
115
+ expect { DummiesIndex::Dummy.bulk body: [{index: {_id: 42, data: {}}}, {index: {_id: 43, data: {}}}, {delete: {_id: 41}}] }
83
116
  .to update_index(DummiesIndex::Dummy).and_reindex(42).only
84
117
  end
85
118
  .to fail_matching 'to update documents ["42"] only, but ["43"] was updated and ["41"] was deleted also'
86
119
  end
87
120
  specify do
88
121
  expect do
89
- expect { DummiesIndex::Dummy.bulk body: [{ index: { _id: 42, data: {} } }, { delete: { _id: 41 } }] }
122
+ expect { DummiesIndex::Dummy.bulk body: [{index: {_id: 42, data: {}}}, {delete: {_id: 41}}] }
90
123
  .to update_index(DummiesIndex::Dummy).and_delete(41).only
91
124
  end
92
125
  .to fail_matching 'to delete documents ["41"] only, but ["42"] was updated also'
93
126
  end
94
127
  specify do
95
128
  expect do
96
- expect { DummiesIndex::Dummy.bulk body: [{ index: { _id: 42, data: {} } }, { delete: { _id: 41 } }, { delete: { _id: 43 } }] }
129
+ expect { DummiesIndex::Dummy.bulk body: [{index: {_id: 42, data: {}}}, {delete: {_id: 41}}, {delete: {_id: 43}}] }
97
130
  .to update_index(DummiesIndex::Dummy).and_delete(41).only
98
131
  end
99
132
  .to fail_matching 'to delete documents ["41"] only, but ["42"] was updated and ["43"] was deleted also'
@@ -101,28 +134,28 @@ describe :update_index do
101
134
  end
102
135
 
103
136
  context '#and_reindex' do
104
- specify { expect { DummiesIndex::Dummy.bulk body: [{ index: { _id: 42 } }] }.to update_index(DummiesIndex::Dummy) }
137
+ specify { expect { DummiesIndex::Dummy.bulk body: [{index: {_id: 42}}] }.to update_index(DummiesIndex::Dummy) }
105
138
  specify do
106
- expect { DummiesIndex::Dummy.bulk body: [{ index: { _id: 42, data: {} } }] }
139
+ expect { DummiesIndex::Dummy.bulk body: [{index: {_id: 42, data: {}}}] }
107
140
  .to update_index(DummiesIndex::Dummy).and_reindex(42)
108
141
  end
109
142
  specify do
110
- expect { DummiesIndex::Dummy.bulk body: [{ index: { _id: 42, data: {} } }, { index: { _id: 43, data: {} } }] }
143
+ expect { DummiesIndex::Dummy.bulk body: [{index: {_id: 42, data: {}}}, {index: {_id: 43, data: {}}}] }
111
144
  .to update_index(DummiesIndex::Dummy).and_reindex(double(id: 42))
112
145
  end
113
146
  specify do
114
- expect { DummiesIndex::Dummy.bulk body: [{ index: { _id: 42, data: {} } }, { index: { _id: 43, data: {} } }] }
147
+ expect { DummiesIndex::Dummy.bulk body: [{index: {_id: 42, data: {}}}, {index: {_id: 43, data: {}}}] }
115
148
  .to update_index(DummiesIndex::Dummy).and_reindex(double(id: 42), double(id: 43))
116
149
  end
117
150
  specify do
118
- expect { DummiesIndex::Dummy.bulk body: [{ index: { _id: 42, data: {} } }, { index: { _id: 43, data: {} } }] }
151
+ expect { DummiesIndex::Dummy.bulk body: [{index: {_id: 42, data: {}}}, {index: {_id: 43, data: {}}}] }
119
152
  .to update_index(DummiesIndex::Dummy).and_reindex([double(id: 42), 43])
120
153
  end
121
154
 
122
155
  specify do
123
156
  expect do
124
157
  expect do
125
- DummiesIndex::Dummy.bulk body: [{ index: { _id: 42, data: {} } }, { index: { _id: 43, data: {} } }]
158
+ DummiesIndex::Dummy.bulk body: [{index: {_id: 42, data: {}}}, {index: {_id: 43, data: {}}}]
126
159
  end.to update_index(DummiesIndex::Dummy).and_reindex([44, 43])
127
160
  end.to fail_matching 'Expected document with id `44` to be reindexed, but it was not'
128
161
  end
@@ -131,7 +164,7 @@ describe :update_index do
131
164
  let(:expectation) do
132
165
  expect do
133
166
  expect do
134
- DummiesIndex::Dummy.bulk body: [{ index: { _id: 42, data: {} } }, { index: { _id: 43, data: {} } }]
167
+ DummiesIndex::Dummy.bulk body: [{index: {_id: 42, data: {}}}, {index: {_id: 43, data: {}}}]
135
168
  end.to update_index(DummiesIndex::Dummy).and_reindex(44, double(id: 47)) end
136
169
  end
137
170
 
@@ -142,14 +175,14 @@ describe :update_index do
142
175
  context ':times' do
143
176
  specify do
144
177
  expect do
145
- DummiesIndex::Dummy.bulk body: [{ index: { _id: 42, data: {} } }, { index: { _id: 43, data: {} } }]
146
- DummiesIndex::Dummy.bulk body: [{ index: { _id: 43, data: {} } }, { index: { _id: 44, data: {} } }]
178
+ DummiesIndex::Dummy.bulk body: [{index: {_id: 42, data: {}}}, {index: {_id: 43, data: {}}}]
179
+ DummiesIndex::Dummy.bulk body: [{index: {_id: 43, data: {}}}, {index: {_id: 44, data: {}}}]
147
180
  end.to update_index(DummiesIndex::Dummy).and_reindex(42, 44, times: 1).and_reindex(43, times: 2) end
148
181
 
149
182
  specify do
150
183
  expect do
151
184
  expect do
152
- DummiesIndex::Dummy.bulk body: [{ index: { _id: 43, data: { a: '1' } } }]
185
+ DummiesIndex::Dummy.bulk body: [{index: {_id: 43, data: {a: '1'}}}]
153
186
  end.to update_index(DummiesIndex::Dummy).and_reindex(42, times: 3)
154
187
  end.to fail_matching('Expected document with id `42` to be reindexed, but it was not') end
155
188
 
@@ -157,8 +190,8 @@ describe :update_index do
157
190
  let(:expectation) do
158
191
  expect do
159
192
  expect do
160
- DummiesIndex::Dummy.bulk body: [{ index: { _id: 42, data: {} } }, { index: { _id: 43, data: {} } }]
161
- DummiesIndex::Dummy.bulk body: [{ index: { _id: 43, data: {} } }, { index: { _id: 44, data: {} } }]
193
+ DummiesIndex::Dummy.bulk body: [{index: {_id: 42, data: {}}}, {index: {_id: 43, data: {}}}]
194
+ DummiesIndex::Dummy.bulk body: [{index: {_id: 43, data: {}}}, {index: {_id: 44, data: {}}}]
162
195
  end.to update_index(DummiesIndex::Dummy).and_reindex(42, times: 3).and_reindex(44, 43, times: 4) end
163
196
  end
164
197
 
@@ -172,45 +205,45 @@ describe :update_index do
172
205
  context ':with' do
173
206
  specify do
174
207
  expect do
175
- DummiesIndex::Dummy.bulk body: [{ index: { _id: 42, data: { a: '1' } } }, { index: { _id: 42, data: { 'a' => 2 } } }]
176
- end.to update_index(DummiesIndex::Dummy).and_reindex(42, with: { a: 2 }) end
208
+ DummiesIndex::Dummy.bulk body: [{index: {_id: 42, data: {a: '1'}}}, {index: {_id: 42, data: {'a' => 2}}}]
209
+ end.to update_index(DummiesIndex::Dummy).and_reindex(42, with: {a: 2}) end
177
210
 
178
211
  specify do
179
212
  expect do
180
- DummiesIndex::Dummy.bulk body: [{ index: { _id: 42, data: { a: '1' } } }, { index: { _id: 42, data: { 'b' => 2 } } }]
181
- end.to update_index(DummiesIndex::Dummy).and_reindex(42, with: { a: '1', b: 2 }) end
213
+ DummiesIndex::Dummy.bulk body: [{index: {_id: 42, data: {a: '1'}}}, {index: {_id: 42, data: {'b' => 2}}}]
214
+ end.to update_index(DummiesIndex::Dummy).and_reindex(42, with: {a: '1', b: 2}) end
182
215
 
183
216
  specify do
184
217
  expect do
185
218
  expect do
186
- DummiesIndex::Dummy.bulk body: [{ index: { _id: 43, data: { a: '1' } } }]
187
- end.to update_index(DummiesIndex::Dummy).and_reindex(42, with: { a: 1 })
219
+ DummiesIndex::Dummy.bulk body: [{index: {_id: 43, data: {a: '1'}}}]
220
+ end.to update_index(DummiesIndex::Dummy).and_reindex(42, with: {a: 1})
188
221
  end.to fail_matching('Expected document with id `42` to be reindexed, but it was not') end
189
222
 
190
223
  [
191
- [{ a: %w(one two) }, { a: %w(one two) }],
192
- [{ a: %w(one two) }, { a: %w(two one) }],
193
- [{ a: %w(one one two) }, { a: %w(one two one) }],
194
- [{ a: { b: %w(one one two) } }, { a: { b: %w(one two one) } }],
195
- [{ a: 1, b: 1 }, { a: 1 }]
224
+ [{a: %w[one two]}, {a: %w[one two]}],
225
+ [{a: %w[one two]}, {a: %w[two one]}],
226
+ [{a: %w[one one two]}, {a: %w[one two one]}],
227
+ [{a: {b: %w[one one two]}}, {a: {b: %w[one two one]}}],
228
+ [{a: 1, b: 1}, {a: 1}]
196
229
  ].each do |(data, with)|
197
230
  specify do
198
231
  expect do
199
- DummiesIndex::Dummy.bulk body: [{ index: { _id: 42, data: data } }]
232
+ DummiesIndex::Dummy.bulk body: [{index: {_id: 42, data: data}}]
200
233
  end.to update_index(DummiesIndex::Dummy).and_reindex(42, with: with) end
201
234
  end
202
235
 
203
236
  [
204
- [{ a: %w(one two) }, { a: %w(one one two) }],
205
- [{ a: %w(one one two) }, { a: %w(one two) }],
206
- [{ a: %w(one two) }, { a: 1 }],
207
- [{ a: 1 }, { a: %w(one two) }],
208
- [{ a: 1 }, { a: 1, b: 1 }]
237
+ [{a: %w[one two]}, {a: %w[one one two]}],
238
+ [{a: %w[one one two]}, {a: %w[one two]}],
239
+ [{a: %w[one two]}, {a: 1}],
240
+ [{a: 1}, {a: %w[one two]}],
241
+ [{a: 1}, {a: 1, b: 1}]
209
242
  ].each do |(data, with)|
210
243
  specify do
211
244
  expect do
212
245
  expect do
213
- DummiesIndex::Dummy.bulk body: [{ index: { _id: 42, data: data } }]
246
+ DummiesIndex::Dummy.bulk body: [{index: {_id: 42, data: data}}]
214
247
  end.to update_index(DummiesIndex::Dummy).and_reindex(42, with: with)
215
248
  end.to fail_matching('Expected document with id `42` to be reindexed') end
216
249
  end
@@ -219,8 +252,8 @@ describe :update_index do
219
252
  let(:expectation) do
220
253
  expect do
221
254
  expect do
222
- DummiesIndex::Dummy.bulk body: [{ index: { _id: 43, data: { a: '1' } } }, { index: { _id: 42, data: { 'a' => 2 } } }]
223
- end.to update_index(DummiesIndex::Dummy).and_reindex(43, times: 2, with: { a: 2 }) end
255
+ DummiesIndex::Dummy.bulk body: [{index: {_id: 43, data: {a: '1'}}}, {index: {_id: 42, data: {'a' => 2}}}]
256
+ end.to update_index(DummiesIndex::Dummy).and_reindex(43, times: 2, with: {a: 2}) end
224
257
  end
225
258
 
226
259
  specify { expectation.to fail_matching 'Expected document with id `43` to be reindexed' }
@@ -232,26 +265,26 @@ describe :update_index do
232
265
 
233
266
  context '#and_delete' do
234
267
  specify do
235
- expect { DummiesIndex::Dummy.bulk body: [{ index: { _id: 42, data: {} } }, { delete: { _id: 43 } }] }
268
+ expect { DummiesIndex::Dummy.bulk body: [{index: {_id: 42, data: {}}}, {delete: {_id: 43}}] }
236
269
  .to update_index(DummiesIndex::Dummy).and_reindex(42).and_delete(double(id: 43))
237
270
  end
238
271
  specify do
239
- expect { DummiesIndex::Dummy.bulk body: [{ delete: { _id: 42 } }, { delete: { _id: 43 } }] }
272
+ expect { DummiesIndex::Dummy.bulk body: [{delete: {_id: 42}}, {delete: {_id: 43}}] }
240
273
  .to update_index(DummiesIndex::Dummy).and_delete(42).and_delete(double(id: 43))
241
274
  end
242
275
  specify do
243
- expect { DummiesIndex::Dummy.bulk body: [{ delete: { _id: 42 } }, { delete: { _id: 43 } }] }
276
+ expect { DummiesIndex::Dummy.bulk body: [{delete: {_id: 42}}, {delete: {_id: 43}}] }
244
277
  .to update_index(DummiesIndex::Dummy).and_delete(42, double(id: 43))
245
278
  end
246
279
  specify do
247
- expect { DummiesIndex::Dummy.bulk body: [{ delete: { _id: 42 } }, { delete: { _id: 43 } }] }
280
+ expect { DummiesIndex::Dummy.bulk body: [{delete: {_id: 42}}, {delete: {_id: 43}}] }
248
281
  .to update_index(DummiesIndex::Dummy).and_delete([43, double(id: 42)])
249
282
  end
250
283
 
251
284
  context do
252
285
  let(:expectation) do
253
286
  expect do
254
- expect { DummiesIndex::Dummy.bulk body: [{ index: { _id: 42, data: {} } }, { delete: { _id: 43 } }] }
287
+ expect { DummiesIndex::Dummy.bulk body: [{index: {_id: 42, data: {}}}, {delete: {_id: 43}}] }
255
288
  .to update_index(DummiesIndex::Dummy).and_reindex(43).and_delete(double(id: 42))
256
289
  end
257
290
  end
@@ -263,7 +296,7 @@ describe :update_index do
263
296
  context do
264
297
  let(:expectation) do
265
298
  expect do
266
- expect { DummiesIndex::Dummy.bulk body: [{ delete: { _id: 42, data: {} } }, { delete: { _id: 42 } }] }
299
+ expect { DummiesIndex::Dummy.bulk body: [{delete: {_id: 42, data: {}}}, {delete: {_id: 42}}] }
267
300
  .to update_index(DummiesIndex::Dummy).and_delete(44, times: 2).and_delete(double(id: 42), times: 3)
268
301
  end
269
302
  end