chewy 0.9.0 → 0.10.0

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