chewy 0.8.4 → 7.3.4

Sign up to get free protection for your applications and to get access to all the features.
Files changed (340) hide show
  1. checksums.yaml +5 -5
  2. data/.github/CODEOWNERS +1 -0
  3. data/.github/ISSUE_TEMPLATE/bug_report.md +39 -0
  4. data/.github/ISSUE_TEMPLATE/feature_request.md +20 -0
  5. data/.github/PULL_REQUEST_TEMPLATE.md +16 -0
  6. data/.github/workflows/ruby.yml +74 -0
  7. data/.gitignore +1 -0
  8. data/.rubocop.yml +61 -0
  9. data/.rubocop_todo.yml +132 -0
  10. data/.yardopts +5 -0
  11. data/CHANGELOG.md +554 -245
  12. data/CODE_OF_CONDUCT.md +14 -0
  13. data/CONTRIBUTING.md +63 -0
  14. data/Gemfile +14 -11
  15. data/Guardfile +8 -6
  16. data/LICENSE.txt +1 -1
  17. data/README.md +748 -623
  18. data/Rakefile +11 -1
  19. data/chewy.gemspec +15 -19
  20. data/gemfiles/rails.5.2.activerecord.gemfile +11 -0
  21. data/gemfiles/rails.6.0.activerecord.gemfile +11 -0
  22. data/gemfiles/rails.6.1.activerecord.gemfile +13 -0
  23. data/gemfiles/rails.7.0.activerecord.gemfile +13 -0
  24. data/lib/chewy/config.rb +64 -50
  25. data/lib/chewy/errors.rb +10 -16
  26. data/lib/chewy/fields/base.rb +122 -32
  27. data/lib/chewy/fields/root.rb +48 -23
  28. data/lib/chewy/index/actions.rb +140 -54
  29. data/lib/chewy/index/adapter/active_record.rb +112 -0
  30. data/lib/chewy/{type → index}/adapter/base.rb +31 -12
  31. data/lib/chewy/index/adapter/object.rb +249 -0
  32. data/lib/chewy/index/adapter/orm.rb +194 -0
  33. data/lib/chewy/index/aliases.rb +14 -4
  34. data/lib/chewy/index/crutch.rb +40 -0
  35. data/lib/chewy/index/import/bulk_builder.rb +311 -0
  36. data/lib/chewy/index/import/bulk_request.rb +77 -0
  37. data/lib/chewy/index/import/journal_builder.rb +44 -0
  38. data/lib/chewy/index/import/routine.rb +139 -0
  39. data/lib/chewy/index/import.rb +243 -0
  40. data/lib/chewy/{type → index}/mapping.rb +79 -68
  41. data/lib/chewy/index/observe/active_record_methods.rb +87 -0
  42. data/lib/chewy/index/observe/callback.rb +34 -0
  43. data/lib/chewy/index/observe.rb +17 -0
  44. data/lib/chewy/index/settings.rb +10 -5
  45. data/lib/chewy/index/specification.rb +61 -0
  46. data/lib/chewy/index/syncer.rb +221 -0
  47. data/lib/chewy/{type → index}/witchcraft.rb +100 -39
  48. data/lib/chewy/index/wrapper.rb +95 -0
  49. data/lib/chewy/index.rb +216 -140
  50. data/lib/chewy/journal.rb +66 -0
  51. data/lib/chewy/log_subscriber.rb +8 -8
  52. data/lib/chewy/minitest/helpers.rb +150 -0
  53. data/lib/chewy/minitest/search_index_receiver.rb +76 -0
  54. data/lib/chewy/minitest.rb +1 -0
  55. data/lib/chewy/multi_search.rb +62 -0
  56. data/lib/chewy/railtie.rb +12 -25
  57. data/lib/chewy/rake_helper.rb +335 -37
  58. data/lib/chewy/repository.rb +2 -2
  59. data/lib/chewy/rspec/build_query.rb +12 -0
  60. data/lib/chewy/rspec/helpers.rb +55 -0
  61. data/lib/chewy/rspec/update_index.rb +106 -90
  62. data/lib/chewy/rspec.rb +3 -1
  63. data/lib/chewy/runtime/version.rb +4 -4
  64. data/lib/chewy/runtime.rb +1 -1
  65. data/lib/chewy/search/loader.rb +61 -0
  66. data/lib/chewy/{query → search}/pagination/kaminari.rb +13 -5
  67. data/lib/chewy/search/parameters/aggs.rb +16 -0
  68. data/lib/chewy/search/parameters/allow_partial_search_results.rb +27 -0
  69. data/lib/chewy/search/parameters/collapse.rb +16 -0
  70. data/lib/chewy/search/parameters/concerns/bool_storage.rb +24 -0
  71. data/lib/chewy/search/parameters/concerns/hash_storage.rb +23 -0
  72. data/lib/chewy/search/parameters/concerns/integer_storage.rb +14 -0
  73. data/lib/chewy/search/parameters/concerns/query_storage.rb +238 -0
  74. data/lib/chewy/search/parameters/concerns/string_array_storage.rb +23 -0
  75. data/lib/chewy/search/parameters/concerns/string_storage.rb +14 -0
  76. data/lib/chewy/search/parameters/docvalue_fields.rb +12 -0
  77. data/lib/chewy/search/parameters/explain.rb +16 -0
  78. data/lib/chewy/search/parameters/filter.rb +47 -0
  79. data/lib/chewy/search/parameters/highlight.rb +16 -0
  80. data/lib/chewy/search/parameters/ignore_unavailable.rb +27 -0
  81. data/lib/chewy/search/parameters/indices.rb +78 -0
  82. data/lib/chewy/search/parameters/indices_boost.rb +52 -0
  83. data/lib/chewy/search/parameters/limit.rb +17 -0
  84. data/lib/chewy/search/parameters/load.rb +32 -0
  85. data/lib/chewy/search/parameters/min_score.rb +16 -0
  86. data/lib/chewy/search/parameters/none.rb +25 -0
  87. data/lib/chewy/search/parameters/offset.rb +17 -0
  88. data/lib/chewy/search/parameters/order.rb +51 -0
  89. data/lib/chewy/search/parameters/post_filter.rb +19 -0
  90. data/lib/chewy/search/parameters/preference.rb +16 -0
  91. data/lib/chewy/search/parameters/profile.rb +16 -0
  92. data/lib/chewy/search/parameters/query.rb +19 -0
  93. data/lib/chewy/search/parameters/request_cache.rb +27 -0
  94. data/lib/chewy/search/parameters/rescore.rb +29 -0
  95. data/lib/chewy/search/parameters/script_fields.rb +16 -0
  96. data/lib/chewy/search/parameters/search_after.rb +20 -0
  97. data/lib/chewy/search/parameters/search_type.rb +16 -0
  98. data/lib/chewy/search/parameters/source.rb +77 -0
  99. data/lib/chewy/search/parameters/storage.rb +95 -0
  100. data/lib/chewy/search/parameters/stored_fields.rb +63 -0
  101. data/lib/chewy/search/parameters/suggest.rb +16 -0
  102. data/lib/chewy/search/parameters/terminate_after.rb +16 -0
  103. data/lib/chewy/search/parameters/timeout.rb +16 -0
  104. data/lib/chewy/search/parameters/track_scores.rb +16 -0
  105. data/lib/chewy/search/parameters/track_total_hits.rb +16 -0
  106. data/lib/chewy/search/parameters/version.rb +16 -0
  107. data/lib/chewy/search/parameters.rb +170 -0
  108. data/lib/chewy/search/query_proxy.rb +264 -0
  109. data/lib/chewy/search/request.rb +1071 -0
  110. data/lib/chewy/search/response.rb +119 -0
  111. data/lib/chewy/search/scoping.rb +49 -0
  112. data/lib/chewy/search/scrolling.rb +137 -0
  113. data/lib/chewy/search.rb +68 -28
  114. data/lib/chewy/stash.rb +68 -0
  115. data/lib/chewy/strategy/active_job.rb +3 -2
  116. data/lib/chewy/strategy/atomic.rb +2 -4
  117. data/lib/chewy/strategy/atomic_no_refresh.rb +18 -0
  118. data/lib/chewy/strategy/base.rb +13 -3
  119. data/lib/chewy/strategy/bypass.rb +1 -2
  120. data/lib/chewy/strategy/delayed_sidekiq/scheduler.rb +148 -0
  121. data/lib/chewy/strategy/delayed_sidekiq/worker.rb +52 -0
  122. data/lib/chewy/strategy/delayed_sidekiq.rb +17 -0
  123. data/lib/chewy/strategy/lazy_sidekiq.rb +64 -0
  124. data/lib/chewy/strategy/sidekiq.rb +15 -2
  125. data/lib/chewy/strategy/urgent.rb +1 -1
  126. data/lib/chewy/strategy.rb +16 -20
  127. data/lib/chewy/version.rb +1 -1
  128. data/lib/chewy.rb +81 -82
  129. data/lib/generators/chewy/install_generator.rb +3 -3
  130. data/lib/tasks/chewy.rake +99 -32
  131. data/migration_guide.md +56 -0
  132. data/spec/chewy/config_spec.rb +87 -15
  133. data/spec/chewy/fields/base_spec.rb +542 -233
  134. data/spec/chewy/fields/root_spec.rb +115 -17
  135. data/spec/chewy/fields/time_fields_spec.rb +13 -12
  136. data/spec/chewy/index/actions_spec.rb +595 -77
  137. data/spec/chewy/index/adapter/active_record_spec.rb +601 -0
  138. data/spec/chewy/index/adapter/object_spec.rb +243 -0
  139. data/spec/chewy/index/aliases_spec.rb +5 -5
  140. data/spec/chewy/index/import/bulk_builder_spec.rb +494 -0
  141. data/spec/chewy/index/import/bulk_request_spec.rb +95 -0
  142. data/spec/chewy/index/import/journal_builder_spec.rb +87 -0
  143. data/spec/chewy/index/import/routine_spec.rb +110 -0
  144. data/spec/chewy/index/import_spec.rb +615 -0
  145. data/spec/chewy/index/mapping_spec.rb +135 -0
  146. data/spec/chewy/index/observe/active_record_methods_spec.rb +68 -0
  147. data/spec/chewy/index/observe/callback_spec.rb +139 -0
  148. data/spec/chewy/index/observe_spec.rb +143 -0
  149. data/spec/chewy/index/settings_spec.rb +103 -50
  150. data/spec/chewy/index/specification_spec.rb +159 -0
  151. data/spec/chewy/index/syncer_spec.rb +118 -0
  152. data/spec/chewy/index/witchcraft_spec.rb +245 -0
  153. data/spec/chewy/index/wrapper_spec.rb +100 -0
  154. data/spec/chewy/index_spec.rb +149 -121
  155. data/spec/chewy/journal_spec.rb +223 -0
  156. data/spec/chewy/minitest/helpers_spec.rb +198 -0
  157. data/spec/chewy/minitest/search_index_receiver_spec.rb +118 -0
  158. data/spec/chewy/multi_search_spec.rb +84 -0
  159. data/spec/chewy/rake_helper_spec.rb +656 -0
  160. data/spec/chewy/repository_spec.rb +8 -8
  161. data/spec/chewy/rspec/build_query_spec.rb +34 -0
  162. data/spec/chewy/rspec/helpers_spec.rb +61 -0
  163. data/spec/chewy/rspec/update_index_spec.rb +220 -114
  164. data/spec/chewy/runtime_spec.rb +2 -2
  165. data/spec/chewy/search/loader_spec.rb +83 -0
  166. data/spec/chewy/search/pagination/kaminari_examples.rb +69 -0
  167. data/spec/chewy/search/pagination/kaminari_spec.rb +21 -0
  168. data/spec/chewy/search/parameters/aggs_spec.rb +5 -0
  169. data/spec/chewy/search/parameters/bool_storage_examples.rb +53 -0
  170. data/spec/chewy/search/parameters/collapse_spec.rb +5 -0
  171. data/spec/chewy/search/parameters/docvalue_fields_spec.rb +5 -0
  172. data/spec/chewy/search/parameters/explain_spec.rb +5 -0
  173. data/spec/chewy/search/parameters/filter_spec.rb +5 -0
  174. data/spec/chewy/search/parameters/hash_storage_examples.rb +59 -0
  175. data/spec/chewy/search/parameters/highlight_spec.rb +5 -0
  176. data/spec/chewy/search/parameters/ignore_unavailable_spec.rb +67 -0
  177. data/spec/chewy/search/parameters/indices_spec.rb +99 -0
  178. data/spec/chewy/search/parameters/integer_storage_examples.rb +32 -0
  179. data/spec/chewy/search/parameters/limit_spec.rb +5 -0
  180. data/spec/chewy/search/parameters/load_spec.rb +60 -0
  181. data/spec/chewy/search/parameters/min_score_spec.rb +32 -0
  182. data/spec/chewy/search/parameters/none_spec.rb +5 -0
  183. data/spec/chewy/search/parameters/offset_spec.rb +5 -0
  184. data/spec/chewy/search/parameters/order_spec.rb +72 -0
  185. data/spec/chewy/search/parameters/post_filter_spec.rb +5 -0
  186. data/spec/chewy/search/parameters/preference_spec.rb +5 -0
  187. data/spec/chewy/search/parameters/profile_spec.rb +5 -0
  188. data/spec/chewy/search/parameters/query_spec.rb +5 -0
  189. data/spec/chewy/search/parameters/query_storage_examples.rb +434 -0
  190. data/spec/chewy/search/parameters/request_cache_spec.rb +67 -0
  191. data/spec/chewy/search/parameters/rescore_spec.rb +62 -0
  192. data/spec/chewy/search/parameters/script_fields_spec.rb +5 -0
  193. data/spec/chewy/search/parameters/search_after_spec.rb +35 -0
  194. data/spec/chewy/search/parameters/search_type_spec.rb +5 -0
  195. data/spec/chewy/search/parameters/source_spec.rb +162 -0
  196. data/spec/chewy/search/parameters/storage_spec.rb +60 -0
  197. data/spec/chewy/search/parameters/stored_fields_spec.rb +126 -0
  198. data/spec/chewy/search/parameters/string_array_storage_examples.rb +63 -0
  199. data/spec/chewy/search/parameters/string_storage_examples.rb +32 -0
  200. data/spec/chewy/search/parameters/suggest_spec.rb +5 -0
  201. data/spec/chewy/search/parameters/terminate_after_spec.rb +5 -0
  202. data/spec/chewy/search/parameters/timeout_spec.rb +5 -0
  203. data/spec/chewy/search/parameters/track_scores_spec.rb +5 -0
  204. data/spec/chewy/search/parameters/track_total_hits_spec.rb +5 -0
  205. data/spec/chewy/search/parameters/version_spec.rb +5 -0
  206. data/spec/chewy/search/parameters_spec.rb +161 -0
  207. data/spec/chewy/search/query_proxy_spec.rb +119 -0
  208. data/spec/chewy/search/request_spec.rb +880 -0
  209. data/spec/chewy/search/response_spec.rb +202 -0
  210. data/spec/chewy/search/scrolling_spec.rb +171 -0
  211. data/spec/chewy/search_spec.rb +82 -55
  212. data/spec/chewy/stash_spec.rb +85 -0
  213. data/spec/chewy/strategy/active_job_spec.rb +27 -8
  214. data/spec/chewy/strategy/atomic_no_refresh_spec.rb +60 -0
  215. data/spec/chewy/strategy/atomic_spec.rb +13 -11
  216. data/spec/chewy/strategy/delayed_sidekiq_spec.rb +190 -0
  217. data/spec/chewy/strategy/lazy_sidekiq_spec.rb +214 -0
  218. data/spec/chewy/strategy/sidekiq_spec.rb +19 -7
  219. data/spec/chewy/strategy_spec.rb +19 -15
  220. data/spec/chewy_spec.rb +65 -88
  221. data/spec/spec_helper.rb +11 -20
  222. data/spec/support/active_record.rb +48 -6
  223. data/spec/support/class_helpers.rb +4 -19
  224. metadata +299 -183
  225. data/.travis.yml +0 -76
  226. data/Appraisals +0 -76
  227. data/gemfiles/rails.3.2.activerecord.gemfile +0 -15
  228. data/gemfiles/rails.3.2.activerecord.kaminari.gemfile +0 -14
  229. data/gemfiles/rails.3.2.activerecord.will_paginate.gemfile +0 -14
  230. data/gemfiles/rails.4.0.activerecord.gemfile +0 -15
  231. data/gemfiles/rails.4.0.activerecord.kaminari.gemfile +0 -14
  232. data/gemfiles/rails.4.0.activerecord.will_paginate.gemfile +0 -14
  233. data/gemfiles/rails.4.0.mongoid.4.0.0.gemfile +0 -15
  234. data/gemfiles/rails.4.0.mongoid.4.0.0.kaminari.gemfile +0 -14
  235. data/gemfiles/rails.4.0.mongoid.4.0.0.will_paginate.gemfile +0 -14
  236. data/gemfiles/rails.4.0.mongoid.5.1.0.gemfile +0 -15
  237. data/gemfiles/rails.4.0.mongoid.5.1.0.kaminari.gemfile +0 -14
  238. data/gemfiles/rails.4.0.mongoid.5.1.0.will_paginate.gemfile +0 -14
  239. data/gemfiles/rails.4.1.activerecord.gemfile +0 -15
  240. data/gemfiles/rails.4.1.activerecord.kaminari.gemfile +0 -14
  241. data/gemfiles/rails.4.1.activerecord.will_paginate.gemfile +0 -14
  242. data/gemfiles/rails.4.1.mongoid.4.0.0.gemfile +0 -15
  243. data/gemfiles/rails.4.1.mongoid.4.0.0.kaminari.gemfile +0 -14
  244. data/gemfiles/rails.4.1.mongoid.4.0.0.will_paginate.gemfile +0 -14
  245. data/gemfiles/rails.4.1.mongoid.5.1.0.gemfile +0 -15
  246. data/gemfiles/rails.4.1.mongoid.5.1.0.kaminari.gemfile +0 -14
  247. data/gemfiles/rails.4.1.mongoid.5.1.0.will_paginate.gemfile +0 -14
  248. data/gemfiles/rails.4.2.activerecord.gemfile +0 -16
  249. data/gemfiles/rails.4.2.activerecord.kaminari.gemfile +0 -15
  250. data/gemfiles/rails.4.2.activerecord.will_paginate.gemfile +0 -15
  251. data/gemfiles/rails.4.2.mongoid.4.0.0.gemfile +0 -15
  252. data/gemfiles/rails.4.2.mongoid.4.0.0.kaminari.gemfile +0 -14
  253. data/gemfiles/rails.4.2.mongoid.4.0.0.will_paginate.gemfile +0 -14
  254. data/gemfiles/rails.4.2.mongoid.5.1.0.gemfile +0 -15
  255. data/gemfiles/rails.4.2.mongoid.5.1.0.kaminari.gemfile +0 -14
  256. data/gemfiles/rails.4.2.mongoid.5.1.0.will_paginate.gemfile +0 -14
  257. data/gemfiles/rails.5.0.0.beta3.activerecord.gemfile +0 -16
  258. data/gemfiles/rails.5.0.0.beta3.activerecord.kaminari.gemfile +0 -16
  259. data/gemfiles/rails.5.0.0.beta3.activerecord.will_paginate.gemfile +0 -15
  260. data/gemfiles/sequel.4.31.gemfile +0 -13
  261. data/lib/chewy/backports/deep_dup.rb +0 -46
  262. data/lib/chewy/backports/duplicable.rb +0 -90
  263. data/lib/chewy/query/compose.rb +0 -69
  264. data/lib/chewy/query/criteria.rb +0 -181
  265. data/lib/chewy/query/filters.rb +0 -227
  266. data/lib/chewy/query/loading.rb +0 -111
  267. data/lib/chewy/query/nodes/and.rb +0 -25
  268. data/lib/chewy/query/nodes/base.rb +0 -17
  269. data/lib/chewy/query/nodes/bool.rb +0 -32
  270. data/lib/chewy/query/nodes/equal.rb +0 -34
  271. data/lib/chewy/query/nodes/exists.rb +0 -20
  272. data/lib/chewy/query/nodes/expr.rb +0 -28
  273. data/lib/chewy/query/nodes/field.rb +0 -106
  274. data/lib/chewy/query/nodes/has_child.rb +0 -14
  275. data/lib/chewy/query/nodes/has_parent.rb +0 -14
  276. data/lib/chewy/query/nodes/has_relation.rb +0 -61
  277. data/lib/chewy/query/nodes/match_all.rb +0 -11
  278. data/lib/chewy/query/nodes/missing.rb +0 -20
  279. data/lib/chewy/query/nodes/not.rb +0 -25
  280. data/lib/chewy/query/nodes/or.rb +0 -25
  281. data/lib/chewy/query/nodes/prefix.rb +0 -18
  282. data/lib/chewy/query/nodes/query.rb +0 -20
  283. data/lib/chewy/query/nodes/range.rb +0 -63
  284. data/lib/chewy/query/nodes/raw.rb +0 -15
  285. data/lib/chewy/query/nodes/regexp.rb +0 -31
  286. data/lib/chewy/query/nodes/script.rb +0 -20
  287. data/lib/chewy/query/pagination/will_paginate.rb +0 -27
  288. data/lib/chewy/query/pagination.rb +0 -16
  289. data/lib/chewy/query/scoping.rb +0 -20
  290. data/lib/chewy/query.rb +0 -1026
  291. data/lib/chewy/strategy/resque.rb +0 -26
  292. data/lib/chewy/type/actions.rb +0 -19
  293. data/lib/chewy/type/adapter/active_record.rb +0 -72
  294. data/lib/chewy/type/adapter/mongoid.rb +0 -58
  295. data/lib/chewy/type/adapter/object.rb +0 -89
  296. data/lib/chewy/type/adapter/orm.rb +0 -156
  297. data/lib/chewy/type/adapter/sequel.rb +0 -75
  298. data/lib/chewy/type/crutch.rb +0 -31
  299. data/lib/chewy/type/import.rb +0 -224
  300. data/lib/chewy/type/observe.rb +0 -76
  301. data/lib/chewy/type/wrapper.rb +0 -53
  302. data/lib/chewy/type.rb +0 -89
  303. data/lib/sequel/plugins/chewy_observe.rb +0 -78
  304. data/spec/chewy/query/criteria_spec.rb +0 -433
  305. data/spec/chewy/query/filters_spec.rb +0 -173
  306. data/spec/chewy/query/loading_spec.rb +0 -86
  307. data/spec/chewy/query/nodes/and_spec.rb +0 -16
  308. data/spec/chewy/query/nodes/bool_spec.rb +0 -22
  309. data/spec/chewy/query/nodes/equal_spec.rb +0 -32
  310. data/spec/chewy/query/nodes/exists_spec.rb +0 -18
  311. data/spec/chewy/query/nodes/has_child_spec.rb +0 -40
  312. data/spec/chewy/query/nodes/has_parent_spec.rb +0 -40
  313. data/spec/chewy/query/nodes/match_all_spec.rb +0 -11
  314. data/spec/chewy/query/nodes/missing_spec.rb +0 -15
  315. data/spec/chewy/query/nodes/not_spec.rb +0 -16
  316. data/spec/chewy/query/nodes/or_spec.rb +0 -16
  317. data/spec/chewy/query/nodes/prefix_spec.rb +0 -16
  318. data/spec/chewy/query/nodes/query_spec.rb +0 -12
  319. data/spec/chewy/query/nodes/range_spec.rb +0 -32
  320. data/spec/chewy/query/nodes/raw_spec.rb +0 -11
  321. data/spec/chewy/query/nodes/regexp_spec.rb +0 -31
  322. data/spec/chewy/query/nodes/script_spec.rb +0 -15
  323. data/spec/chewy/query/pagination/kaminari_spec.rb +0 -57
  324. data/spec/chewy/query/pagination/will_paginage_spec.rb +0 -60
  325. data/spec/chewy/query/pagination_spec.rb +0 -36
  326. data/spec/chewy/query_spec.rb +0 -632
  327. data/spec/chewy/strategy/resque_spec.rb +0 -40
  328. data/spec/chewy/type/actions_spec.rb +0 -31
  329. data/spec/chewy/type/adapter/active_record_spec.rb +0 -317
  330. data/spec/chewy/type/adapter/mongoid_spec.rb +0 -253
  331. data/spec/chewy/type/adapter/object_spec.rb +0 -139
  332. data/spec/chewy/type/adapter/sequel_spec.rb +0 -320
  333. data/spec/chewy/type/import_spec.rb +0 -433
  334. data/spec/chewy/type/mapping_spec.rb +0 -106
  335. data/spec/chewy/type/observe_spec.rb +0 -127
  336. data/spec/chewy/type/witchcraft_spec.rb +0 -154
  337. data/spec/chewy/type/wrapper_spec.rb +0 -58
  338. data/spec/chewy/type_spec.rb +0 -33
  339. data/spec/support/mongoid.rb +0 -81
  340. data/spec/support/sequel.rb +0 -75
@@ -1,111 +0,0 @@
1
- module Chewy
2
- class Query
3
- module Loading
4
- extend ActiveSupport::Concern
5
-
6
- # Lazily loads actual ORM/ODM objects for search result.
7
- # Returns scope marked to return loaded objects array instead of
8
- # chewy wrappers. In case when object can not be loaded because it
9
- # was deleted or don't satisfy given scope or options - the
10
- # result collection will contain nil value in the place of this
11
- # object. Use `compact` method to avoid this if necessary.
12
- #
13
- # UsersIndex.query(...).load #=> [#<User id: 42...>, ...]
14
- # UsersIndex.query(...).load.filter(...) #=> [#<User id: 42...>, ...]
15
- #
16
- # Possible options:
17
- #
18
- # <tt>:scope</tt> - used to give a scope for _every_ loaded type.
19
- #
20
- # PlacesIndex.query(...).load(scope: ->{ includes(:testimonials) })
21
- #
22
- # If places here contain cities and countries then preload will be
23
- # done like this:
24
- #
25
- # City.where(id: [...]).includes(:testimonials)
26
- # Country.where(id: [...]).includes(:testimonials)
27
- #
28
- # It is also possible to pass own scope for every loaded type:
29
- #
30
- # PlacesIndex.query(...).load(
31
- # city: { scope: ->{ includes(:testimonials, :country) }}
32
- # country: { scope: ->{ includes(:testimonials, :cities) }}
33
- # )
34
- #
35
- # And loading will be performed as:
36
- #
37
- # City.where(id: [...]).includes(:testimonials, :country)
38
- # Country.where(id: [...]).includes(:testimonials, :cities)
39
- #
40
- # In case of ActiveRecord objects loading the same result
41
- # will be reached using ActiveRecord scopes instead of
42
- # lambdas. But it works only with per-type scopes,
43
- # and doesn't work with the common scope.
44
- #
45
- # PlacesIndex.query(...).load(
46
- # city: { scope: City.includes(:testimonials, :country) }
47
- # country: { scope: Country.includes(:testimonials, :cities) }
48
- # )
49
- #
50
- # <tt>:only</tt> - loads objects for the specified types
51
- #
52
- # PlacesIndex.query(...).load(only: :city)
53
- # PlacesIndex.query(...).load(only: [:city])
54
- # PlacesIndex.query(...).load(only: [:city, :country])
55
- #
56
- # <tt>:except</tt> - doesn't load listed types
57
- #
58
- # PlacesIndex.query(...).load(except: :city)
59
- # PlacesIndex.query(...).load(except: [:city])
60
- # PlacesIndex.query(...).load(except: [:city, :country])
61
- #
62
- def load(options = {})
63
- chain { criteria.update_options preload: options, loaded_objects: true }
64
- end
65
-
66
- # This methods is just convenient way to preload some ORM/ODM
67
- # objects and continue to work with Chewy wrappers. Returns
68
- # Chewy query scope. Note that `load` method performs ES request
69
- # so preload method should also be the last in scope methods chain.
70
- # Takes the same options as the `load` method
71
- #
72
- # PlacesIndex.query(...).preload(only: :city)
73
- #
74
- # Loaded objects are also attached to corresponding Chewy
75
- # type wrapper objects and available with `_object` accessor.
76
- #
77
- # scope = PlacesIndex.query(...)
78
- # preload_scope = scope.preload
79
- # preload_scope.first #=> PlacesIndex::City wrapper instance
80
- # preload_scope.first._object #=> City model instance
81
- # scope.load == preload_scope.map(&:_object) #=> true
82
- #
83
- def preload(options = {})
84
- chain { criteria.update_options preload: options, loaded_objects: false }
85
- end
86
-
87
- private
88
-
89
- def _load_objects!
90
- options = criteria.options[:preload]
91
- only = Array.wrap(options[:only]).map(&:to_s)
92
- except = Array.wrap(options[:except]).map(&:to_s)
93
-
94
- loaded_objects = Hash[_results.group_by(&:class).map do |type, objects|
95
- next if except.include?(type.type_name)
96
- next if only.present? && !only.include?(type.type_name)
97
-
98
- loaded = type.adapter.load(objects, options.merge(_type: type))
99
- [type, loaded.index_by.with_index do |loaded, i|
100
- objects[i]._object = loaded
101
- objects[i]
102
- end]
103
- end.compact]
104
-
105
- _results.map do |result|
106
- loaded_objects[result.class][result] if loaded_objects[result.class]
107
- end
108
- end
109
- end
110
- end
111
- end
@@ -1,25 +0,0 @@
1
- module Chewy
2
- class Query
3
- module Nodes
4
- class And < Expr
5
- def initialize *nodes
6
- @options = nodes.extract_options!
7
- @nodes = nodes.flatten.map { |node| node.is_a?(self.class) ? node.__nodes__ : node }.flatten
8
- end
9
-
10
- def __nodes__
11
- @nodes
12
- end
13
-
14
- def __render__
15
- nodes = @nodes.map(&:__render__)
16
- if @options.key?(:cache)
17
- {and: {filters: nodes, _cache: !!@options[:cache]}}
18
- else
19
- {and: nodes}
20
- end
21
- end
22
- end
23
- end
24
- end
25
- end
@@ -1,17 +0,0 @@
1
- module Chewy
2
- class Query
3
- module Nodes
4
- class Base
5
- def render
6
- raise NotImplementedError
7
- end
8
-
9
- def eql? other
10
- other.is_a?(self.class) && instance_variables.all? do |ivar|
11
- instance_variable_get(ivar).eql? other.instance_variable_get(ivar)
12
- end
13
- end
14
- end
15
- end
16
- end
17
- end
@@ -1,32 +0,0 @@
1
- module Chewy
2
- class Query
3
- module Nodes
4
- class Bool < Expr
5
- METHODS = %w(must must_not should)
6
-
7
- def initialize options = {}
8
- @options = options
9
- @must, @must_not, @should = [], [], []
10
- end
11
-
12
- METHODS.each do |method|
13
- define_method method do |*exprs|
14
- instance_variable_get("@#{method}").push(*exprs)
15
- self
16
- end
17
- end
18
-
19
- def __render__
20
- bool = {
21
- bool: Hash[METHODS.map do |method|
22
- value = instance_variable_get("@#{method}")
23
- [method.to_sym, value.map(&:__render__)] if value.present?
24
- end.compact]
25
- }
26
- bool[:bool][:_cache] = !!@options[:cache] if @options.key?(:cache)
27
- bool
28
- end
29
- end
30
- end
31
- end
32
- end
@@ -1,34 +0,0 @@
1
- module Chewy
2
- class Query
3
- module Nodes
4
- class Equal < Expr
5
- EXECUTION = {
6
- :| => :or,
7
- :or => :or,
8
- :& => :and,
9
- :and => :and,
10
- :b => :bool,
11
- :bool => :bool,
12
- :f => :fielddata,
13
- :fielddata => :fielddata,
14
- }
15
-
16
- def initialize name, value, *args
17
- @name = name.to_s
18
- @value = value
19
- @options = args.extract_options!
20
- execution = EXECUTION[args.first.to_sym] if args.first
21
- @options[:execution] = execution if execution
22
- end
23
-
24
- def __render__
25
- filter = (@value.is_a?(Array) ? :terms : :term)
26
- body = {@name => @value}
27
- body.merge!(@options.slice(:execution)) if filter == :terms
28
- body.merge!(_cache: !!@options[:cache]) if @options.key?(:cache)
29
- {filter => body}
30
- end
31
- end
32
- end
33
- end
34
- end
@@ -1,20 +0,0 @@
1
- module Chewy
2
- class Query
3
- module Nodes
4
- class Exists < Expr
5
- def initialize name, options = {}
6
- @name = name.to_s
7
- @options = options
8
- end
9
-
10
- def !
11
- Nodes::Missing.new @name, null_value: true
12
- end
13
-
14
- def __render__
15
- {exists: {field: @name}}
16
- end
17
- end
18
- end
19
- end
20
- end
@@ -1,28 +0,0 @@
1
- module Chewy
2
- class Query
3
- module Nodes
4
- class Expr < Base
5
- def & other
6
- Nodes::And.new self, other
7
- end
8
-
9
- def | other
10
- Nodes::Or.new self, other
11
- end
12
-
13
- def !
14
- Nodes::Not.new self
15
- end
16
-
17
- def ~
18
- @options[:cache] = true
19
- self
20
- end
21
-
22
- def __render__
23
- raise NotImplementedError
24
- end
25
- end
26
- end
27
- end
28
- end
@@ -1,106 +0,0 @@
1
- module Chewy
2
- class Query
3
- module Nodes
4
- class Field < Base
5
- def initialize name, *args
6
- @name = name.to_s
7
- @args = args
8
- end
9
-
10
- def !
11
- Nodes::Missing.new @name
12
- end
13
-
14
- def ~
15
- __options_merge__!(cache: true)
16
- self
17
- end
18
-
19
- def > value
20
- Nodes::Range.new @name, *__options_merge__(gt: value)
21
- end
22
-
23
- def < value
24
- Nodes::Range.new @name, *__options_merge__(lt: value)
25
- end
26
-
27
- def >= value
28
- Nodes::Range.new @name, *__options_merge__(gt: value, left_closed: true)
29
- end
30
-
31
- def <= value
32
- Nodes::Range.new @name, *__options_merge__(lt: value, right_closed: true)
33
- end
34
-
35
- def == value
36
- case value
37
- when nil
38
- Nodes::Missing.new @name, existence: false, null_value: true
39
- when ::Regexp
40
- Nodes::Regexp.new @name, value, *@args
41
- when ::Range
42
- Nodes::Range.new @name, *__options_merge__(gt: value.first, lt: value.last)
43
- else
44
- if value.is_a?(Array) && value.first.is_a?(::Range)
45
- Nodes::Range.new @name, *__options_merge__(
46
- gt: value.first.first, lt: value.first.last,
47
- left_closed: true, right_closed: true
48
- )
49
- else
50
- Nodes::Equal.new @name, value, *@args
51
- end
52
- end
53
- end
54
-
55
- def != value
56
- case value
57
- when nil
58
- Nodes::Exists.new @name
59
- else
60
- Nodes::Not.new self == value
61
- end
62
- end
63
-
64
- def =~ value
65
- case value
66
- when ::Regexp
67
- Nodes::Regexp.new @name, value, *@args
68
- else
69
- Nodes::Prefix.new @name, value, @args.extract_options!
70
- end
71
- end
72
-
73
- def !~ value
74
- Not.new(self =~ value)
75
- end
76
-
77
- def method_missing method, *args, &block
78
- method = method.to_s
79
- if method =~ /\?\Z/
80
- Nodes::Exists.new [@name, method.gsub(/\?\Z/, '')].join(?.)
81
- else
82
- self.class.new [@name, method].join(?.), *args
83
- end
84
- end
85
-
86
- def to_ary
87
- nil
88
- end
89
-
90
- private
91
-
92
- def __options_merge__! additional = {}
93
- options = @args.extract_options!
94
- options = options.merge(additional)
95
- @args.push(options)
96
- end
97
-
98
- def __options_merge__ additional = {}
99
- options = @args.extract_options!
100
- options = options.merge(additional)
101
- @args + [options]
102
- end
103
- end
104
- end
105
- end
106
- end
@@ -1,14 +0,0 @@
1
- require 'chewy/query/nodes/has_relation'
2
-
3
- module Chewy
4
- class Query
5
- module Nodes
6
- class HasChild < HasRelation
7
- private
8
- def _relation
9
- :has_child
10
- end
11
- end
12
- end
13
- end
14
- end
@@ -1,14 +0,0 @@
1
- require 'chewy/query/nodes/has_relation'
2
-
3
- module Chewy
4
- class Query
5
- module Nodes
6
- class HasParent < HasRelation
7
- private
8
- def _relation
9
- :has_parent
10
- end
11
- end
12
- end
13
- end
14
- end
@@ -1,61 +0,0 @@
1
- require 'chewy/query/compose'
2
-
3
- module Chewy
4
- class Query
5
- module Nodes
6
- class HasRelation < Expr
7
- include Compose
8
-
9
- def initialize type, outer = nil
10
- @type = type.to_s
11
- @outer = outer
12
- @query_mode = :must
13
- @filter_mode = :and
14
- @queries = []
15
- @filters = []
16
- end
17
-
18
- def query_mode mode
19
- @query_mode = mode
20
- self
21
- end
22
-
23
- def filter_mode mode
24
- @filter_mode = mode
25
- self
26
- end
27
-
28
- def query params = nil, &block
29
- if block
30
- raise 'Query DLS is not supported yet'
31
- else
32
- @queries.push(params)
33
- end
34
- self
35
- end
36
-
37
- def filter params = nil, &block
38
- if block
39
- @filters.push(Chewy::Query::Filters.new(@outer, &block).__render__)
40
- else
41
- @filters.push(params)
42
- end
43
- self
44
- end
45
-
46
- def __render__
47
- queries = _queries_join @queries, @query_mode
48
- filters = _filters_join @filters, @filter_mode
49
-
50
- body = if filters && !queries
51
- {filter: filters}
52
- else
53
- _filtered_query(queries, filters)
54
- end || {}
55
-
56
- {_relation => body.merge(type: @type)} if body
57
- end
58
- end
59
- end
60
- end
61
- end
@@ -1,11 +0,0 @@
1
- module Chewy
2
- class Query
3
- module Nodes
4
- class MatchAll < Expr
5
- def __render__
6
- {match_all: {}}
7
- end
8
- end
9
- end
10
- end
11
- end
@@ -1,20 +0,0 @@
1
- module Chewy
2
- class Query
3
- module Nodes
4
- class Missing < Expr
5
- def initialize name, options = {}
6
- @name = name.to_s
7
- @options = options.reverse_merge(existence: true, null_value: false)
8
- end
9
-
10
- def !
11
- Nodes::Exists.new @name
12
- end
13
-
14
- def __render__
15
- {missing: {field: @name}.merge(@options.slice(:existence, :null_value))}
16
- end
17
- end
18
- end
19
- end
20
- end
@@ -1,25 +0,0 @@
1
- module Chewy
2
- class Query
3
- module Nodes
4
- class Not < Expr
5
- def initialize expr, options = {}
6
- @expr = expr
7
- @options = options
8
- end
9
-
10
- def !
11
- @expr
12
- end
13
-
14
- def __render__
15
- expr = @expr.__render__
16
- if @options.key?(:cache)
17
- {not: {filter: expr, _cache: !!@options[:cache]}}
18
- else
19
- {not: expr}
20
- end
21
- end
22
- end
23
- end
24
- end
25
- end
@@ -1,25 +0,0 @@
1
- module Chewy
2
- class Query
3
- module Nodes
4
- class Or < Expr
5
- def initialize *nodes
6
- @options = nodes.extract_options!
7
- @nodes = nodes.flatten.map { |node| node.is_a?(self.class) ? node.__nodes__ : node }.flatten
8
- end
9
-
10
- def __nodes__
11
- @nodes
12
- end
13
-
14
- def __render__
15
- nodes = @nodes.map(&:__render__)
16
- if @options.key?(:cache)
17
- {or: {filters: nodes, _cache: !!@options[:cache]}}
18
- else
19
- {or: nodes}
20
- end
21
- end
22
- end
23
- end
24
- end
25
- end
@@ -1,18 +0,0 @@
1
- module Chewy
2
- class Query
3
- module Nodes
4
- class Prefix < Expr
5
- def initialize name, value, options = {}
6
- @name = name.to_s
7
- @value, @options = value, options
8
- end
9
-
10
- def __render__
11
- filter = {prefix: {@name => @value}}
12
- filter[:prefix][:_cache] = !!@options[:cache] if @options.key?(:cache)
13
- filter
14
- end
15
- end
16
- end
17
- end
18
- end
@@ -1,20 +0,0 @@
1
- module Chewy
2
- class Query
3
- module Nodes
4
- class Query < Expr
5
- def initialize query, options = {}
6
- @query = query
7
- @options = options
8
- end
9
-
10
- def __render__
11
- if @options.key?(:cache)
12
- {fquery: {query: @query, _cache: !!@options[:cache]}}
13
- else
14
- {query: @query}
15
- end
16
- end
17
- end
18
- end
19
- end
20
- end
@@ -1,63 +0,0 @@
1
- module Chewy
2
- class Query
3
- module Nodes
4
- class Range < Expr
5
- EXECUTION = {
6
- :i => :index,
7
- :index => :index,
8
- :f => :fielddata,
9
- :fielddata => :fielddata,
10
- }
11
-
12
- def initialize name, *args
13
- @name = name.to_s
14
- @options = args.extract_options!
15
- @range = @options.reject { |k, v| ![:gt, :lt].include?(k) }
16
- @bounds = @options.reject { |k, v| ![:left_closed, :right_closed].include?(k) }
17
- execution = EXECUTION[args.first.to_sym] if args.first
18
- @options[:execution] = execution if execution
19
- end
20
-
21
- def & other
22
- if other.is_a?(self.class) && other.__name__ == @name
23
- state = __state__.merge(other.__state__)
24
-
25
- cache = other.__options__[:cache] || @options[:cache]
26
- state[:cache] = cache unless cache.nil?
27
-
28
- execution = other.__options__[:execution] || @options[:execution]
29
- state[:execution] = execution unless execution.nil?
30
-
31
- self.class.new(@name, state)
32
- else
33
- super
34
- end
35
- end
36
-
37
- def __name__
38
- @name
39
- end
40
-
41
- def __state__
42
- @range.merge(@bounds)
43
- end
44
-
45
- def __options__
46
- @options
47
- end
48
-
49
- def __render__
50
- body = {}
51
- body[@bounds[:left_closed] ? :gte : :gt] = @range[:gt] if @range.key?(:gt)
52
- body[@bounds[:right_closed] ? :lte : :lt] = @range[:lt] if @range.key?(:lt)
53
-
54
- filter = {@name => body}
55
- filter[:_cache] = !!@options[:cache] if @options.key?(:cache)
56
- filter.merge!(@options.slice(:execution))
57
-
58
- {range: filter}
59
- end
60
- end
61
- end
62
- end
63
- end
@@ -1,15 +0,0 @@
1
- module Chewy
2
- class Query
3
- module Nodes
4
- class Raw < Expr
5
- def initialize raw
6
- @raw = raw
7
- end
8
-
9
- def __render__
10
- @raw
11
- end
12
- end
13
- end
14
- end
15
- end