sequel 5.29.0 → 5.30.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (323) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG +8 -1922
  3. data/doc/release_notes/5.30.0.txt +20 -0
  4. data/lib/sequel/adapters/shared/sqlite.rb +7 -1
  5. data/lib/sequel/database/transactions.rb +5 -9
  6. data/lib/sequel/version.rb +1 -1
  7. metadata +4 -368
  8. data/Rakefile +0 -151
  9. data/doc/release_notes/4.0.0.txt +0 -262
  10. data/doc/release_notes/4.1.0.txt +0 -85
  11. data/doc/release_notes/4.10.0.txt +0 -226
  12. data/doc/release_notes/4.11.0.txt +0 -147
  13. data/doc/release_notes/4.12.0.txt +0 -105
  14. data/doc/release_notes/4.13.0.txt +0 -169
  15. data/doc/release_notes/4.14.0.txt +0 -68
  16. data/doc/release_notes/4.15.0.txt +0 -56
  17. data/doc/release_notes/4.16.0.txt +0 -36
  18. data/doc/release_notes/4.17.0.txt +0 -38
  19. data/doc/release_notes/4.18.0.txt +0 -36
  20. data/doc/release_notes/4.19.0.txt +0 -45
  21. data/doc/release_notes/4.2.0.txt +0 -129
  22. data/doc/release_notes/4.20.0.txt +0 -79
  23. data/doc/release_notes/4.21.0.txt +0 -94
  24. data/doc/release_notes/4.22.0.txt +0 -72
  25. data/doc/release_notes/4.23.0.txt +0 -65
  26. data/doc/release_notes/4.24.0.txt +0 -99
  27. data/doc/release_notes/4.25.0.txt +0 -181
  28. data/doc/release_notes/4.26.0.txt +0 -44
  29. data/doc/release_notes/4.27.0.txt +0 -78
  30. data/doc/release_notes/4.28.0.txt +0 -57
  31. data/doc/release_notes/4.29.0.txt +0 -41
  32. data/doc/release_notes/4.3.0.txt +0 -40
  33. data/doc/release_notes/4.30.0.txt +0 -37
  34. data/doc/release_notes/4.31.0.txt +0 -57
  35. data/doc/release_notes/4.32.0.txt +0 -132
  36. data/doc/release_notes/4.33.0.txt +0 -88
  37. data/doc/release_notes/4.34.0.txt +0 -86
  38. data/doc/release_notes/4.35.0.txt +0 -130
  39. data/doc/release_notes/4.36.0.txt +0 -116
  40. data/doc/release_notes/4.37.0.txt +0 -50
  41. data/doc/release_notes/4.38.0.txt +0 -67
  42. data/doc/release_notes/4.39.0.txt +0 -127
  43. data/doc/release_notes/4.4.0.txt +0 -92
  44. data/doc/release_notes/4.40.0.txt +0 -179
  45. data/doc/release_notes/4.41.0.txt +0 -77
  46. data/doc/release_notes/4.42.0.txt +0 -221
  47. data/doc/release_notes/4.43.0.txt +0 -87
  48. data/doc/release_notes/4.44.0.txt +0 -125
  49. data/doc/release_notes/4.45.0.txt +0 -370
  50. data/doc/release_notes/4.46.0.txt +0 -404
  51. data/doc/release_notes/4.47.0.txt +0 -56
  52. data/doc/release_notes/4.48.0.txt +0 -293
  53. data/doc/release_notes/4.49.0.txt +0 -222
  54. data/doc/release_notes/4.5.0.txt +0 -34
  55. data/doc/release_notes/4.6.0.txt +0 -30
  56. data/doc/release_notes/4.7.0.txt +0 -103
  57. data/doc/release_notes/4.8.0.txt +0 -175
  58. data/doc/release_notes/4.9.0.txt +0 -190
  59. data/spec/adapter_spec.rb +0 -4
  60. data/spec/adapters/db2_spec.rb +0 -170
  61. data/spec/adapters/mssql_spec.rb +0 -828
  62. data/spec/adapters/mysql_spec.rb +0 -1060
  63. data/spec/adapters/oracle_spec.rb +0 -371
  64. data/spec/adapters/postgres_spec.rb +0 -4476
  65. data/spec/adapters/spec_helper.rb +0 -44
  66. data/spec/adapters/sqlanywhere_spec.rb +0 -97
  67. data/spec/adapters/sqlite_spec.rb +0 -652
  68. data/spec/bin_spec.rb +0 -278
  69. data/spec/core/connection_pool_spec.rb +0 -1250
  70. data/spec/core/database_spec.rb +0 -2915
  71. data/spec/core/dataset_spec.rb +0 -5544
  72. data/spec/core/deprecated_spec.rb +0 -70
  73. data/spec/core/expression_filters_spec.rb +0 -1498
  74. data/spec/core/mock_adapter_spec.rb +0 -722
  75. data/spec/core/object_graph_spec.rb +0 -336
  76. data/spec/core/placeholder_literalizer_spec.rb +0 -166
  77. data/spec/core/schema_generator_spec.rb +0 -214
  78. data/spec/core/schema_spec.rb +0 -1844
  79. data/spec/core/spec_helper.rb +0 -24
  80. data/spec/core/version_spec.rb +0 -14
  81. data/spec/core_extensions_spec.rb +0 -763
  82. data/spec/core_model_spec.rb +0 -2
  83. data/spec/core_spec.rb +0 -1
  84. data/spec/deprecation_helper.rb +0 -30
  85. data/spec/extensions/accessed_columns_spec.rb +0 -51
  86. data/spec/extensions/active_model_spec.rb +0 -99
  87. data/spec/extensions/after_initialize_spec.rb +0 -28
  88. data/spec/extensions/any_not_empty_spec.rb +0 -23
  89. data/spec/extensions/arbitrary_servers_spec.rb +0 -109
  90. data/spec/extensions/association_dependencies_spec.rb +0 -125
  91. data/spec/extensions/association_multi_add_remove_spec.rb +0 -1041
  92. data/spec/extensions/association_pks_spec.rb +0 -423
  93. data/spec/extensions/association_proxies_spec.rb +0 -100
  94. data/spec/extensions/auto_literal_strings_spec.rb +0 -205
  95. data/spec/extensions/auto_validations_spec.rb +0 -229
  96. data/spec/extensions/blacklist_security_spec.rb +0 -95
  97. data/spec/extensions/blank_spec.rb +0 -69
  98. data/spec/extensions/boolean_readers_spec.rb +0 -93
  99. data/spec/extensions/boolean_subsets_spec.rb +0 -47
  100. data/spec/extensions/caching_spec.rb +0 -273
  101. data/spec/extensions/caller_logging_spec.rb +0 -52
  102. data/spec/extensions/class_table_inheritance_spec.rb +0 -750
  103. data/spec/extensions/column_conflicts_spec.rb +0 -75
  104. data/spec/extensions/column_select_spec.rb +0 -129
  105. data/spec/extensions/columns_introspection_spec.rb +0 -90
  106. data/spec/extensions/columns_updated_spec.rb +0 -35
  107. data/spec/extensions/composition_spec.rb +0 -248
  108. data/spec/extensions/connection_expiration_spec.rb +0 -151
  109. data/spec/extensions/connection_validator_spec.rb +0 -144
  110. data/spec/extensions/constant_sql_override_spec.rb +0 -24
  111. data/spec/extensions/constraint_validations_plugin_spec.rb +0 -300
  112. data/spec/extensions/constraint_validations_spec.rb +0 -439
  113. data/spec/extensions/core_refinements_spec.rb +0 -528
  114. data/spec/extensions/csv_serializer_spec.rb +0 -183
  115. data/spec/extensions/current_datetime_timestamp_spec.rb +0 -27
  116. data/spec/extensions/dataset_associations_spec.rb +0 -365
  117. data/spec/extensions/dataset_source_alias_spec.rb +0 -51
  118. data/spec/extensions/date_arithmetic_spec.rb +0 -181
  119. data/spec/extensions/datetime_parse_to_time_spec.rb +0 -169
  120. data/spec/extensions/def_dataset_method_spec.rb +0 -100
  121. data/spec/extensions/defaults_setter_spec.rb +0 -150
  122. data/spec/extensions/delay_add_association_spec.rb +0 -73
  123. data/spec/extensions/dirty_spec.rb +0 -222
  124. data/spec/extensions/duplicate_columns_handler_spec.rb +0 -104
  125. data/spec/extensions/eager_each_spec.rb +0 -62
  126. data/spec/extensions/eager_graph_eager_spec.rb +0 -100
  127. data/spec/extensions/empty_array_consider_nulls_spec.rb +0 -24
  128. data/spec/extensions/empty_failure_backtraces_spec.rb +0 -60
  129. data/spec/extensions/error_splitter_spec.rb +0 -18
  130. data/spec/extensions/error_sql_spec.rb +0 -20
  131. data/spec/extensions/escaped_like_spec.rb +0 -40
  132. data/spec/extensions/eval_inspect_spec.rb +0 -81
  133. data/spec/extensions/exclude_or_null_spec.rb +0 -15
  134. data/spec/extensions/finder_spec.rb +0 -260
  135. data/spec/extensions/force_encoding_spec.rb +0 -126
  136. data/spec/extensions/freeze_datasets_spec.rb +0 -31
  137. data/spec/extensions/graph_each_spec.rb +0 -113
  138. data/spec/extensions/hook_class_methods_spec.rb +0 -402
  139. data/spec/extensions/identifier_mangling_spec.rb +0 -201
  140. data/spec/extensions/implicit_subquery_spec.rb +0 -58
  141. data/spec/extensions/index_caching_spec.rb +0 -66
  142. data/spec/extensions/inflector_spec.rb +0 -183
  143. data/spec/extensions/input_transformer_spec.rb +0 -69
  144. data/spec/extensions/insert_conflict_spec.rb +0 -103
  145. data/spec/extensions/insert_returning_select_spec.rb +0 -72
  146. data/spec/extensions/instance_filters_spec.rb +0 -79
  147. data/spec/extensions/instance_hooks_spec.rb +0 -246
  148. data/spec/extensions/integer64_spec.rb +0 -22
  149. data/spec/extensions/inverted_subsets_spec.rb +0 -33
  150. data/spec/extensions/json_serializer_spec.rb +0 -346
  151. data/spec/extensions/lazy_attributes_spec.rb +0 -183
  152. data/spec/extensions/list_spec.rb +0 -291
  153. data/spec/extensions/looser_typecasting_spec.rb +0 -43
  154. data/spec/extensions/many_through_many_spec.rb +0 -2177
  155. data/spec/extensions/migration_spec.rb +0 -864
  156. data/spec/extensions/modification_detection_spec.rb +0 -93
  157. data/spec/extensions/mssql_optimistic_locking_spec.rb +0 -92
  158. data/spec/extensions/named_timezones_spec.rb +0 -218
  159. data/spec/extensions/nested_attributes_spec.rb +0 -815
  160. data/spec/extensions/null_dataset_spec.rb +0 -85
  161. data/spec/extensions/optimistic_locking_spec.rb +0 -127
  162. data/spec/extensions/pagination_spec.rb +0 -116
  163. data/spec/extensions/pg_array_associations_spec.rb +0 -802
  164. data/spec/extensions/pg_array_ops_spec.rb +0 -144
  165. data/spec/extensions/pg_array_spec.rb +0 -398
  166. data/spec/extensions/pg_auto_constraint_validations_spec.rb +0 -209
  167. data/spec/extensions/pg_enum_spec.rb +0 -118
  168. data/spec/extensions/pg_extended_date_support_spec.rb +0 -126
  169. data/spec/extensions/pg_hstore_ops_spec.rb +0 -238
  170. data/spec/extensions/pg_hstore_spec.rb +0 -219
  171. data/spec/extensions/pg_inet_ops_spec.rb +0 -102
  172. data/spec/extensions/pg_inet_spec.rb +0 -72
  173. data/spec/extensions/pg_interval_spec.rb +0 -103
  174. data/spec/extensions/pg_json_ops_spec.rb +0 -356
  175. data/spec/extensions/pg_json_spec.rb +0 -451
  176. data/spec/extensions/pg_loose_count_spec.rb +0 -23
  177. data/spec/extensions/pg_range_ops_spec.rb +0 -60
  178. data/spec/extensions/pg_range_spec.rb +0 -600
  179. data/spec/extensions/pg_row_ops_spec.rb +0 -61
  180. data/spec/extensions/pg_row_plugin_spec.rb +0 -60
  181. data/spec/extensions/pg_row_spec.rb +0 -363
  182. data/spec/extensions/pg_static_cache_updater_spec.rb +0 -93
  183. data/spec/extensions/pg_timestamptz_spec.rb +0 -17
  184. data/spec/extensions/prepared_statements_safe_spec.rb +0 -66
  185. data/spec/extensions/prepared_statements_spec.rb +0 -177
  186. data/spec/extensions/pretty_table_spec.rb +0 -123
  187. data/spec/extensions/query_spec.rb +0 -94
  188. data/spec/extensions/rcte_tree_spec.rb +0 -387
  189. data/spec/extensions/round_timestamps_spec.rb +0 -39
  190. data/spec/extensions/s_spec.rb +0 -60
  191. data/spec/extensions/schema_caching_spec.rb +0 -64
  192. data/spec/extensions/schema_dumper_spec.rb +0 -870
  193. data/spec/extensions/select_remove_spec.rb +0 -38
  194. data/spec/extensions/sequel_4_dataset_methods_spec.rb +0 -121
  195. data/spec/extensions/serialization_modification_detection_spec.rb +0 -98
  196. data/spec/extensions/serialization_spec.rb +0 -365
  197. data/spec/extensions/server_block_spec.rb +0 -135
  198. data/spec/extensions/server_logging_spec.rb +0 -45
  199. data/spec/extensions/sharding_spec.rb +0 -197
  200. data/spec/extensions/shared_caching_spec.rb +0 -151
  201. data/spec/extensions/single_table_inheritance_spec.rb +0 -347
  202. data/spec/extensions/singular_table_names_spec.rb +0 -22
  203. data/spec/extensions/skip_create_refresh_spec.rb +0 -18
  204. data/spec/extensions/spec_helper.rb +0 -70
  205. data/spec/extensions/split_array_nil_spec.rb +0 -24
  206. data/spec/extensions/split_values_spec.rb +0 -57
  207. data/spec/extensions/sql_comments_spec.rb +0 -33
  208. data/spec/extensions/sql_expr_spec.rb +0 -59
  209. data/spec/extensions/static_cache_cache_spec.rb +0 -35
  210. data/spec/extensions/static_cache_spec.rb +0 -471
  211. data/spec/extensions/string_agg_spec.rb +0 -90
  212. data/spec/extensions/string_date_time_spec.rb +0 -95
  213. data/spec/extensions/string_stripper_spec.rb +0 -68
  214. data/spec/extensions/subclasses_spec.rb +0 -79
  215. data/spec/extensions/subset_conditions_spec.rb +0 -38
  216. data/spec/extensions/symbol_aref_refinement_spec.rb +0 -28
  217. data/spec/extensions/symbol_as_refinement_spec.rb +0 -21
  218. data/spec/extensions/synchronize_sql_spec.rb +0 -124
  219. data/spec/extensions/table_select_spec.rb +0 -83
  220. data/spec/extensions/tactical_eager_loading_spec.rb +0 -402
  221. data/spec/extensions/thread_local_timezones_spec.rb +0 -67
  222. data/spec/extensions/throw_failures_spec.rb +0 -74
  223. data/spec/extensions/timestamps_spec.rb +0 -209
  224. data/spec/extensions/to_dot_spec.rb +0 -153
  225. data/spec/extensions/touch_spec.rb +0 -226
  226. data/spec/extensions/tree_spec.rb +0 -334
  227. data/spec/extensions/typecast_on_load_spec.rb +0 -86
  228. data/spec/extensions/unlimited_update_spec.rb +0 -21
  229. data/spec/extensions/update_or_create_spec.rb +0 -83
  230. data/spec/extensions/update_primary_key_spec.rb +0 -105
  231. data/spec/extensions/update_refresh_spec.rb +0 -59
  232. data/spec/extensions/uuid_spec.rb +0 -101
  233. data/spec/extensions/validate_associated_spec.rb +0 -52
  234. data/spec/extensions/validation_class_methods_spec.rb +0 -1040
  235. data/spec/extensions/validation_contexts_spec.rb +0 -31
  236. data/spec/extensions/validation_helpers_spec.rb +0 -525
  237. data/spec/extensions/whitelist_security_spec.rb +0 -157
  238. data/spec/extensions/xml_serializer_spec.rb +0 -213
  239. data/spec/files/bad_down_migration/001_create_alt_basic.rb +0 -4
  240. data/spec/files/bad_down_migration/002_create_alt_advanced.rb +0 -4
  241. data/spec/files/bad_timestamped_migrations/1273253849_create_sessions.rb +0 -9
  242. data/spec/files/bad_timestamped_migrations/1273253851_create_nodes.rb +0 -9
  243. data/spec/files/bad_timestamped_migrations/1273253853_3_create_users.rb +0 -3
  244. data/spec/files/bad_up_migration/001_create_alt_basic.rb +0 -4
  245. data/spec/files/bad_up_migration/002_create_alt_advanced.rb +0 -3
  246. data/spec/files/convert_to_timestamp_migrations/001_create_sessions.rb +0 -9
  247. data/spec/files/convert_to_timestamp_migrations/002_create_nodes.rb +0 -9
  248. data/spec/files/convert_to_timestamp_migrations/003_3_create_users.rb +0 -4
  249. data/spec/files/convert_to_timestamp_migrations/1273253850_create_artists.rb +0 -9
  250. data/spec/files/convert_to_timestamp_migrations/1273253852_create_albums.rb +0 -9
  251. data/spec/files/double_migration/001_create_sessions.rb +0 -9
  252. data/spec/files/double_migration/002_create_nodes.rb +0 -19
  253. data/spec/files/double_migration/003_3_create_users.rb +0 -4
  254. data/spec/files/duplicate_integer_migrations/001_create_alt_advanced.rb +0 -4
  255. data/spec/files/duplicate_integer_migrations/001_create_alt_basic.rb +0 -4
  256. data/spec/files/duplicate_timestamped_migrations/1273253849_create_sessions.rb +0 -9
  257. data/spec/files/duplicate_timestamped_migrations/1273253853_create_nodes.rb +0 -9
  258. data/spec/files/duplicate_timestamped_migrations/1273253853_create_users.rb +0 -4
  259. data/spec/files/empty_migration/001_create_sessions.rb +0 -9
  260. data/spec/files/empty_migration/002_create_nodes.rb +0 -0
  261. data/spec/files/empty_migration/003_3_create_users.rb +0 -4
  262. data/spec/files/integer_migrations/001_create_sessions.rb +0 -9
  263. data/spec/files/integer_migrations/002_create_nodes.rb +0 -9
  264. data/spec/files/integer_migrations/003_3_create_users.rb +0 -4
  265. data/spec/files/interleaved_timestamped_migrations/1273253849_create_sessions.rb +0 -9
  266. data/spec/files/interleaved_timestamped_migrations/1273253850_create_artists.rb +0 -9
  267. data/spec/files/interleaved_timestamped_migrations/1273253851_create_nodes.rb +0 -9
  268. data/spec/files/interleaved_timestamped_migrations/1273253852_create_albums.rb +0 -9
  269. data/spec/files/interleaved_timestamped_migrations/1273253853_3_create_users.rb +0 -4
  270. data/spec/files/missing_integer_migrations/001_create_alt_basic.rb +0 -4
  271. data/spec/files/missing_integer_migrations/003_create_alt_advanced.rb +0 -4
  272. data/spec/files/missing_timestamped_migrations/1273253849_create_sessions.rb +0 -9
  273. data/spec/files/missing_timestamped_migrations/1273253853_3_create_users.rb +0 -4
  274. data/spec/files/reversible_migrations/001_reversible.rb +0 -5
  275. data/spec/files/reversible_migrations/002_reversible.rb +0 -5
  276. data/spec/files/reversible_migrations/003_reversible.rb +0 -5
  277. data/spec/files/reversible_migrations/004_reversible.rb +0 -5
  278. data/spec/files/reversible_migrations/005_reversible.rb +0 -10
  279. data/spec/files/reversible_migrations/006_reversible.rb +0 -10
  280. data/spec/files/reversible_migrations/007_reversible.rb +0 -10
  281. data/spec/files/timestamped_migrations/1273253849_create_sessions.rb +0 -9
  282. data/spec/files/timestamped_migrations/1273253851_create_nodes.rb +0 -9
  283. data/spec/files/timestamped_migrations/1273253853_3_create_users.rb +0 -4
  284. data/spec/files/transaction_specified_migrations/001_create_alt_basic.rb +0 -4
  285. data/spec/files/transaction_specified_migrations/002_create_basic.rb +0 -4
  286. data/spec/files/transaction_unspecified_migrations/001_create_alt_basic.rb +0 -3
  287. data/spec/files/transaction_unspecified_migrations/002_create_basic.rb +0 -3
  288. data/spec/files/uppercase_timestamped_migrations/1273253849_CREATE_SESSIONS.RB +0 -9
  289. data/spec/files/uppercase_timestamped_migrations/1273253851_CREATE_NODES.RB +0 -9
  290. data/spec/files/uppercase_timestamped_migrations/1273253853_3_CREATE_USERS.RB +0 -4
  291. data/spec/guards_helper.rb +0 -59
  292. data/spec/integration/associations_test.rb +0 -2597
  293. data/spec/integration/database_test.rb +0 -113
  294. data/spec/integration/dataset_test.rb +0 -2037
  295. data/spec/integration/eager_loader_test.rb +0 -687
  296. data/spec/integration/migrator_test.rb +0 -262
  297. data/spec/integration/model_test.rb +0 -203
  298. data/spec/integration/plugin_test.rb +0 -2423
  299. data/spec/integration/prepared_statement_test.rb +0 -405
  300. data/spec/integration/schema_test.rb +0 -903
  301. data/spec/integration/spec_helper.rb +0 -71
  302. data/spec/integration/timezone_test.rb +0 -86
  303. data/spec/integration/transaction_test.rb +0 -603
  304. data/spec/integration/type_test.rb +0 -127
  305. data/spec/model/association_reflection_spec.rb +0 -803
  306. data/spec/model/associations_spec.rb +0 -4738
  307. data/spec/model/base_spec.rb +0 -875
  308. data/spec/model/class_dataset_methods_spec.rb +0 -146
  309. data/spec/model/dataset_methods_spec.rb +0 -198
  310. data/spec/model/eager_loading_spec.rb +0 -2377
  311. data/spec/model/hooks_spec.rb +0 -370
  312. data/spec/model/inflector_spec.rb +0 -26
  313. data/spec/model/model_spec.rb +0 -956
  314. data/spec/model/plugins_spec.rb +0 -429
  315. data/spec/model/record_spec.rb +0 -2118
  316. data/spec/model/spec_helper.rb +0 -46
  317. data/spec/model/validations_spec.rb +0 -220
  318. data/spec/model_no_assoc_spec.rb +0 -1
  319. data/spec/model_spec.rb +0 -1
  320. data/spec/plugin_spec.rb +0 -1
  321. data/spec/sequel_coverage.rb +0 -15
  322. data/spec/sequel_warning.rb +0 -5
  323. data/spec/spec_config.rb +0 -12
@@ -1,83 +0,0 @@
1
- require_relative "spec_helper"
2
-
3
- describe "Sequel::Plugins::TableSelect" do
4
- before do
5
- @Album = Class.new(Sequel::Model(Sequel.mock[:albums]))
6
- end
7
-
8
- it "should add a table.* selection to existing dataset without explicit selection" do
9
- @Album.plugin :table_select
10
- @Album.dataset.sql.must_equal 'SELECT albums.* FROM albums'
11
-
12
- @Album.dataset = :albs
13
- @Album.dataset.sql.must_equal 'SELECT albs.* FROM albs'
14
-
15
- @Album.dataset = Sequel.identifier(:albs)
16
- @Album.dataset.sql.must_equal 'SELECT albs.* FROM albs'
17
- end
18
-
19
- it "should handle qualified tables" do
20
- @Album.dataset = Sequel.qualify(:s2, :albums)
21
- @Album.plugin :table_select
22
- @Album.dataset.sql.must_equal 'SELECT s2.albums.* FROM s2.albums'
23
- end
24
-
25
- it "should handle aliases" do
26
- @Album.dataset = Sequel.as(:albums, :b)
27
- @Album.plugin :table_select
28
- @Album.dataset.sql.must_equal 'SELECT b.* FROM albums AS b'
29
-
30
- @Album.dataset = @Album.db[:albums].from_self
31
- @Album.dataset.sql.must_equal 'SELECT t1.* FROM (SELECT * FROM albums) AS t1'
32
-
33
- @Album.dataset = Sequel.as(@Album.db[:albums], :b)
34
- @Album.dataset.sql.must_equal 'SELECT b.* FROM (SELECT * FROM albums) AS b'
35
- end
36
-
37
- with_symbol_splitting "should handle splittable symbols" do
38
- @Album.dataset = :albums___a
39
- @Album.plugin :table_select
40
- @Album.dataset.sql.must_equal 'SELECT a.* FROM albums AS a'
41
-
42
- @Album.dataset = :s__albums___a
43
- @Album.dataset.sql.must_equal 'SELECT a.* FROM s.albums AS a'
44
-
45
- @Album.dataset = :s__albums
46
- @Album.dataset.sql.must_equal 'SELECT s.albums.* FROM s.albums'
47
- end
48
-
49
- it "should not add a table.* selection on existing dataset with explicit selection" do
50
- @Album.dataset = @Album.dataset.select(:name)
51
- @Album.plugin :table_select
52
- @Album.dataset.sql.must_equal 'SELECT name FROM albums'
53
-
54
- @Album.dataset = @Album.dataset.select(:name, :artist)
55
- @Album.dataset.sql.must_equal 'SELECT name, artist FROM albums'
56
- end
57
-
58
- it "should add a table.* selection on existing dataset with subquery" do
59
- @Album.dataset = @Album.db.from(:a1, :a2).from_self(:alias=>:foo)
60
- @Album.plugin :table_select
61
- @Album.dataset.sql.must_equal 'SELECT foo.* FROM (SELECT * FROM a1, a2) AS foo'
62
-
63
- @Album.dataset = @Album.db.from(:a1).cross_join(:a2).from_self(:alias=>:foo)
64
- @Album.dataset.sql.must_equal 'SELECT foo.* FROM (SELECT * FROM a1 CROSS JOIN a2) AS foo'
65
- end
66
-
67
- it "should work with implicit subqueries used for joined datasets" do
68
- @Album.dataset = @Album.db.from(:a1, :a2)
69
- @Album.plugin :table_select
70
- @Album.dataset.sql.must_equal 'SELECT a1.* FROM (SELECT * FROM a1, a2) AS a1'
71
-
72
- @Album.dataset = @Album.db.from(:a1).cross_join(:a2)
73
- @Album.dataset.sql.must_equal 'SELECT a1.* FROM (SELECT * FROM a1 CROSS JOIN a2) AS a1'
74
- end
75
-
76
- it "works correctly when loaded on model without a dataset" do
77
- c = Class.new(Sequel::Model)
78
- c.plugin :table_select
79
- sc = Class.new(c)
80
- sc.dataset = :a
81
- sc.dataset.sql.must_equal "SELECT a.* FROM a"
82
- end
83
- end
@@ -1,402 +0,0 @@
1
- require_relative "spec_helper"
2
-
3
- describe "tactical_eager_loading plugin" do
4
- def sql_match(*args)
5
- sqls = DB.sqls
6
- sqls.length.must_equal args.length
7
- sqls.zip(args).each do |is, should|
8
- if should.is_a?(Regexp)
9
- is.must_match should
10
- else
11
- is.must_equal should
12
- end
13
- end
14
- end
15
-
16
- attr_reader :ts
17
-
18
- before do
19
- class ::TacticalEagerLoadingModel < Sequel::Model(:t)
20
- plugin :tactical_eager_loading
21
- columns :id, :parent_id
22
- many_to_one :parent, :class=>self
23
- one_to_many :children, :class=>self, :key=>:parent_id
24
- set_dataset dataset.with_fetch(proc do |sql|
25
- if sql !~ /WHERE/
26
- [{:id=>1, :parent_id=>101}, {:id=>2, :parent_id=>102}, {:id=>101, :parent_id=>nil}, {:id=>102, :parent_id=>nil}]
27
- elsif sql =~ /WHERE.*\bid = (\d+)/
28
- [{:id=>$1.to_i, :parent_id=>nil}]
29
- elsif sql =~ /WHERE.*\bid IN \(([\d, ]*)\)/
30
- $1.split(', ').map{|x| {:id=>x.to_i, :parent_id=>nil}}
31
- elsif sql =~ /WHERE.*\bparent_id = (\d+)/
32
- {:id=>$1.to_i - 100, :parent_id=>$1.to_i} if $1.to_i > 100
33
- elsif sql =~ /WHERE.*\bparent_id IN \(([\d, ]*)\)/
34
- $1.split(', ').map{|x| {:id=>x.to_i - 100, :parent_id=>x.to_i} if x.to_i > 100}.compact
35
- end
36
- end)
37
- end
38
- @c = ::TacticalEagerLoadingModel
39
- @ds = TacticalEagerLoadingModel.dataset
40
- DB.reset
41
- @ts = @c.all
42
- sql_match('SELECT * FROM t')
43
- end
44
- after do
45
- Object.send(:remove_const, :TacticalEagerLoadingModel)
46
- sql_match
47
- end
48
-
49
- it "Dataset#all should set the retrieved_by and retrieved_with attributes" do
50
- ts.map{|x| [x.retrieved_by, x.retrieved_with]}.must_equal [[@ds,ts], [@ds,ts], [@ds,ts], [@ds,ts]]
51
- end
52
-
53
- it "Dataset#all shouldn't raise an error if a Sequel::Model instance is not returned" do
54
- @c.naked.all
55
- sql_match('SELECT * FROM t')
56
- end
57
-
58
- it "association getter methods should eagerly load the association if the association isn't cached" do
59
- ts.map{|x| x.parent}.must_equal [ts[2], ts[3], nil, nil]
60
- sql_match(/\ASELECT \* FROM t WHERE \(t\.id IN \(10[12], 10[12]\)\)\z/)
61
- ts.map{|x| x.children}.must_equal [[], [], [ts[0]], [ts[1]]]
62
- sql_match(/\ASELECT \* FROM t WHERE \(t\.parent_id IN/)
63
- end
64
-
65
- it "association getter methods should not eagerly load the association if the association is cached" do
66
- ts.map{|x| x.parent}.must_equal [ts[2], ts[3], nil, nil]
67
- sql_match(/\ASELECT \* FROM t WHERE \(t\.id IN \(10[12], 10[12]\)\)\z/)
68
- @c.dataset = @c.dataset.with_extend{def eager_load(*) raise end}
69
- ts.map{|x| x.parent}.must_equal [ts[2], ts[3], nil, nil]
70
- end
71
-
72
- it "association getter methods should not eagerly load the association if a block is given" do
73
- ts.map{|x| x.parent{|ds| ds}}.must_equal [ts[2], ts[3], nil, nil]
74
- sql_match('SELECT * FROM t WHERE (t.id = 101) LIMIT 1', 'SELECT * FROM t WHERE (t.id = 102) LIMIT 1')
75
- end
76
-
77
- it "association getter methods should not eagerly load the association if a callback proc is given" do
78
- ts.map{|x| x.parent(:callback=>proc{|ds| ds})}.must_equal [ts[2], ts[3], nil, nil]
79
- sql_match('SELECT * FROM t WHERE (t.id = 101) LIMIT 1', 'SELECT * FROM t WHERE (t.id = 102) LIMIT 1')
80
- end
81
-
82
- it "association getter methods should not eagerly load the association if :reload=>true is passed" do
83
- ts.map{|x| x.parent(:reload=>true)}.must_equal [ts[2], ts[3], nil, nil]
84
- sql_match('SELECT * FROM t WHERE id = 101', 'SELECT * FROM t WHERE id = 102')
85
- end
86
-
87
- it "association getter methods should eagerly reload the association if :eager_reload=>true is passed" do
88
- ts.first.parent(:reload=>true)
89
- sql_match('SELECT * FROM t WHERE id = 101')
90
- ts.map{|x| x.associations.fetch(:parent, 1)}.must_equal [ts[2], 1, 1, 1]
91
- ts.first.parent(:eager_reload=>true)
92
- sql_match(/\ASELECT \* FROM t WHERE \(t\.id IN \(10[12], 10[12]\)\)\z/)
93
- ts.map{|x| x.associations.fetch(:parent, 1)}.must_equal [ts[2], ts[3], nil, nil]
94
- end
95
-
96
- it "association getter methods should support eagerly loading dependent associations via :eager" do
97
- parents = ts.map{|x| x.parent(:eager=>:children)}
98
- sql_match(/\ASELECT \* FROM t WHERE \(t\.id IN \(10[12], 10[12]\)\)\z/, /\ASELECT \* FROM t WHERE \(t\.parent_id IN/)
99
- parents.must_equal [ts[2], ts[3], nil, nil]
100
- parents[0..1].map{|x| x.children}.must_equal [[ts[0]], [ts[1]]]
101
- end
102
-
103
- it "association getter methods should support eager callbacks via :eager" do
104
- parents = ts.map{|x| x.parent(:eager=>proc{|ds| ds.where{name > 'M'}.eager(:children)})}
105
- sql_match(/\ASELECT \* FROM t WHERE \(\(t\.id IN \(10[12], 10[12]\)\) AND \(name > 'M'\)\)\z/, /\ASELECT \* FROM t WHERE \(t\.parent_id IN/)
106
- parents.must_equal [ts[2], ts[3], nil, nil]
107
- parents[0..1].map{|x| x.children}.must_equal [[ts[0]], [ts[1]]]
108
- end
109
-
110
- it "should not eager load when association uses :allow_eager=>false option" do
111
- @c.many_to_one :parent, :clone=>:parent, :allow_eager=>false
112
- @c.one_to_many :children, :clone=>:children, :allow_eager=>false
113
- ts.map{|x| x.parent}.must_equal [ts[2], ts[3], nil, nil]
114
- sql_match('SELECT * FROM t WHERE id = 101', 'SELECT * FROM t WHERE id = 102')
115
- ts.map{|x| x.children}.must_equal [[], [], [ts[0]], [ts[1]]]
116
- sql_match('SELECT * FROM t WHERE (t.parent_id = 1)', 'SELECT * FROM t WHERE (t.parent_id = 2)', 'SELECT * FROM t WHERE (t.parent_id = 101)', 'SELECT * FROM t WHERE (t.parent_id = 102)')
117
- end
118
-
119
- it "should handle case where an association is valid on an instance, but not on all instances" do
120
- c = Class.new(@c)
121
- c.many_to_one :parent2, :class=>@c, :key=>:parent_id
122
- @c.dataset.with_row_proc(proc{|r| (r[:parent_id] == 101 ? c : @c).call(r)}).all{|x| x.parent2 if x.is_a?(c)}
123
- sql_match('SELECT * FROM t', 'SELECT * FROM t WHERE id = 101')
124
- end
125
-
126
- it "association getter methods should not eagerly load the association if an instance is frozen" do
127
- ts.first.freeze
128
- ts.map{|x| x.parent}.must_equal [ts[2], ts[3], nil, nil]
129
- sql_match('SELECT * FROM t WHERE id = 101', 'SELECT * FROM t WHERE (t.id IN (102))')
130
- ts.map{|x| x.children}.must_equal [[], [], [ts[0]], [ts[1]]]
131
- sql_match('SELECT * FROM t WHERE (t.parent_id = 1)', /\ASELECT \* FROM t WHERE \(t\.parent_id IN/)
132
- ts.map{|x| x.parent}.must_equal [ts[2], ts[3], nil, nil]
133
- sql_match('SELECT * FROM t WHERE id = 101')
134
- ts.map{|x| x.children}.must_equal [[], [], [ts[0]], [ts[1]]]
135
- sql_match('SELECT * FROM t WHERE (t.parent_id = 1)')
136
- end
137
-
138
- it "#marshallable should make marshalling not fail" do
139
- Marshal.dump(ts.map{|x| x.marshallable!})
140
- end
141
- end
142
-
143
- describe "tactical_eager_loading plugin eager_graph_support" do
144
- before do
145
- @c = Class.new(Sequel::Model)
146
- @c.class_eval do
147
- set_dataset DB[:t]
148
- columns :id, :parent_id
149
- plugin :tactical_eager_loading
150
- many_to_one :parent, :class=>self
151
- one_to_many :children, :class=>self, :key=>:parent_id
152
- end
153
- DB.reset
154
- end
155
-
156
- it "should allow eager loading of associated objects from one_to_many associated objects retrieved via eager_graph" do
157
- a = @c.eager_graph(:children).
158
- with_fetch([
159
- {:id=>1, :parent_id=>nil, :children_id=>3, :children_parent_id=>1},
160
- {:id=>1, :parent_id=>nil, :children_id=>4, :children_parent_id=>1},
161
- {:id=>2, :parent_id=>nil, :children_id=>5, :children_parent_id=>2}
162
- ]).all
163
- @c.db.sqls.must_equal ["SELECT t.id, t.parent_id, children.id AS children_id, children.parent_id AS children_parent_id FROM t LEFT OUTER JOIN t AS children ON (children.parent_id = t.id)"]
164
-
165
- a.must_equal [@c.load(:id=>1, :parent_id=>nil), @c.load(:id=>2, :parent_id=>nil)]
166
- a.map(&:children).must_equal [
167
- [@c.load(:id=>3, :parent_id=>1),
168
- @c.load(:id=>4, :parent_id=>1)],
169
- [@c.load(:id=>5, :parent_id=>2)]]
170
- @c.db.sqls.must_equal []
171
-
172
- @c.dataset = @c.dataset.with_fetch([[{:id=>6, :parent_id=>3}, {:id=>7, :parent_id=>4}, {:id=>8, :parent_id=>5}],
173
- [{:id=>9, :parent_id=>6}, {:id=>10, :parent_id=>7}, {:id=>11, :parent_id=>8}]])
174
-
175
- a.map(&:children).map{|v| v.map(&:children)}.must_equal [
176
- [[@c.load(:id=>6, :parent_id=>3)],
177
- [@c.load(:id=>7, :parent_id=>4)]],
178
- [[@c.load(:id=>8, :parent_id=>5)]]]
179
- @c.db.sqls.must_equal ["SELECT * FROM t WHERE (t.parent_id IN (3, 4, 5))"]
180
-
181
- a.map(&:children).map{|v| v.map(&:children).map{|v1| v1.map(&:children)}}.must_equal [
182
- [[[@c.load(:id=>9, :parent_id=>6)]],
183
- [[@c.load(:id=>10, :parent_id=>7)]]],
184
- [[[@c.load(:id=>11, :parent_id=>8)]]]]
185
- @c.db.sqls.must_equal ["SELECT * FROM t WHERE (t.parent_id IN (6, 7, 8))"]
186
- end
187
-
188
- it "should allow eager loading of associated objects from many_to_one associated objects retrieved via eager_graph" do
189
- a = @c.eager_graph(:parent).
190
- with_fetch([
191
- {:id=>9, :parent_id=>6, :parent_id_0=>6, :parent_parent_id=>3},
192
- {:id=>10, :parent_id=>7, :parent_id_0=>7, :parent_parent_id=>4},
193
- {:id=>11, :parent_id=>8, :parent_id_0=>8, :parent_parent_id=>5}
194
- ]).all
195
- @c.db.sqls.must_equal ["SELECT t.id, t.parent_id, parent.id AS parent_id_0, parent.parent_id AS parent_parent_id FROM t LEFT OUTER JOIN t AS parent ON (parent.id = t.parent_id)"]
196
-
197
- a.must_equal [@c.load(:id=>9, :parent_id=>6), @c.load(:id=>10, :parent_id=>7), @c.load(:id=>11, :parent_id=>8)]
198
- a.map(&:parent).must_equal [@c.load(:id=>6, :parent_id=>3), @c.load(:id=>7, :parent_id=>4), @c.load(:id=>8, :parent_id=>5)]
199
- @c.db.sqls.must_equal []
200
-
201
- @c.dataset = @c.dataset.with_fetch([[{:id=>5, :parent_id=>2}, {:id=>4, :parent_id=>nil}, {:id=>3, :parent_id=>1}],
202
- [{:id=>2, :parent_id=>nil}, {:id=>1, :parent_id=>nil}]])
203
-
204
- a.map(&:parent).map(&:parent).must_equal [@c.load(:id=>3, :parent_id=>1), @c.load(:id=>4, :parent_id=>nil), @c.load(:id=>5, :parent_id=>2)]
205
- @c.db.sqls.must_equal ["SELECT * FROM t WHERE (t.id IN (3, 4, 5))"]
206
- a.map(&:parent).map(&:parent).map(&:parent).must_equal [@c.load(:id=>1, :parent_id=>nil), nil, @c.load(:id=>2, :parent_id=>nil)]
207
- @c.db.sqls.must_equal ["SELECT * FROM t WHERE (t.id IN (2, 1))"]
208
- end
209
-
210
- it "should allow eager loading of associated objects when using chained one_to_many associations" do
211
- a = @c.eager_graph(:children=>:children).
212
- with_fetch([
213
- {:id=>1, :parent_id=>nil, :children_id=>3, :children_parent_id=>1, :children_0_id=>6, :children_0_parent_id=>3},
214
- {:id=>1, :parent_id=>nil, :children_id=>4, :children_parent_id=>1, :children_0_id=>7, :children_0_parent_id=>4},
215
- {:id=>2, :parent_id=>nil, :children_id=>5, :children_parent_id=>2, :children_0_id=>8, :children_0_parent_id=>5}
216
- ]).all
217
- @c.db.sqls.must_equal ["SELECT t.id, t.parent_id, children.id AS children_id, children.parent_id AS children_parent_id, children_0.id AS children_0_id, children_0.parent_id AS children_0_parent_id FROM t LEFT OUTER JOIN t AS children ON (children.parent_id = t.id) LEFT OUTER JOIN t AS children_0 ON (children_0.parent_id = children.id)"]
218
-
219
- a.must_equal [@c.load(:id=>1, :parent_id=>nil), @c.load(:id=>2, :parent_id=>nil)]
220
- a.map(&:children).must_equal [
221
- [@c.load(:id=>3, :parent_id=>1),
222
- @c.load(:id=>4, :parent_id=>1)],
223
- [@c.load(:id=>5, :parent_id=>2)]]
224
-
225
- a.map(&:children).map{|v| v.map(&:children)}.must_equal [
226
- [[@c.load(:id=>6, :parent_id=>3)],
227
- [@c.load(:id=>7, :parent_id=>4)]],
228
- [[@c.load(:id=>8, :parent_id=>5)]]]
229
- @c.db.sqls.must_equal []
230
-
231
- @c.dataset = @c.dataset.with_fetch([{:id=>9, :parent_id=>6}, {:id=>10, :parent_id=>7}, {:id=>11, :parent_id=>8}])
232
- a.map(&:children).map{|v| v.map(&:children).map{|v1| v1.map(&:children)}}.must_equal [
233
- [[[@c.load(:id=>9, :parent_id=>6)]],
234
- [[@c.load(:id=>10, :parent_id=>7)]]],
235
- [[[@c.load(:id=>11, :parent_id=>8)]]]]
236
- @c.db.sqls.must_equal ["SELECT * FROM t WHERE (t.parent_id IN (6, 7, 8))"]
237
- end
238
-
239
- it "should allow eager loading of associated objects when using chained many_to_one associations" do
240
- a = @c.eager_graph(:parent=>:parent).
241
- with_fetch([
242
- {:id=>9, :parent_id=>6, :parent_id_0=>6, :parent_parent_id=>3, :parent_0_id=>3, :parent_0_parent_id=>1},
243
- {:id=>10, :parent_id=>7, :parent_id_0=>7, :parent_parent_id=>4, :parent_0_id=>4, :parent_0_parent_id=>1},
244
- {:id=>11, :parent_id=>8, :parent_id_0=>8, :parent_parent_id=>5, :parent_0_id=>5, :parent_0_parent_id=>2}
245
- ]).all
246
- @c.db.sqls.must_equal ["SELECT t.id, t.parent_id, parent.id AS parent_id_0, parent.parent_id AS parent_parent_id, parent_0.id AS parent_0_id, parent_0.parent_id AS parent_0_parent_id FROM t LEFT OUTER JOIN t AS parent ON (parent.id = t.parent_id) LEFT OUTER JOIN t AS parent_0 ON (parent_0.id = parent.parent_id)"]
247
-
248
- a.must_equal [@c.load(:id=>9, :parent_id=>6), @c.load(:id=>10, :parent_id=>7), @c.load(:id=>11, :parent_id=>8)]
249
- a.map(&:parent).must_equal [@c.load(:id=>6, :parent_id=>3), @c.load(:id=>7, :parent_id=>4), @c.load(:id=>8, :parent_id=>5)]
250
- a.map(&:parent).map(&:parent).must_equal [@c.load(:id=>3, :parent_id=>1), @c.load(:id=>4, :parent_id=>1), @c.load(:id=>5, :parent_id=>2)]
251
- @c.db.sqls.must_equal []
252
-
253
- @c.dataset = @c.dataset.with_fetch([{:id=>2, :parent_id=>nil}, {:id=>1, :parent_id=>nil}])
254
- a.map(&:parent).map(&:parent).map(&:parent).must_equal [@c.load(:id=>1, :parent_id=>nil), @c.load(:id=>1, :parent_id=>nil), @c.load(:id=>2, :parent_id=>nil)]
255
- @c.db.sqls.must_equal ["SELECT * FROM t WHERE (t.id IN (1, 2))"]
256
- end
257
-
258
- it "should allow eager loading of associated objects when using chained many_to_one=>one_to_many associations" do
259
- a = @c.eager_graph(:parent=>:children).
260
- with_fetch([
261
- {:id=>9, :parent_id=>6, :parent_id_0=>6, :parent_parent_id=>3, :children_id=>9, :children_parent_id=>6},
262
- {:id=>10, :parent_id=>7, :parent_id_0=>7, :parent_parent_id=>4, :children_id=>10, :children_parent_id=>7},
263
- {:id=>11, :parent_id=>8, :parent_id_0=>8, :parent_parent_id=>5, :children_id=>11, :children_parent_id=>8},
264
- {:id=>9, :parent_id=>6, :parent_id_0=>6, :parent_parent_id=>3, :children_id=>12, :children_parent_id=>6},
265
- {:id=>10, :parent_id=>7, :parent_id_0=>7, :parent_parent_id=>4, :children_id=>13, :children_parent_id=>7},
266
- {:id=>11, :parent_id=>8, :parent_id_0=>8, :parent_parent_id=>5, :children_id=>14, :children_parent_id=>8}
267
- ]).all
268
- @c.db.sqls.must_equal ["SELECT t.id, t.parent_id, parent.id AS parent_id_0, parent.parent_id AS parent_parent_id, children.id AS children_id, children.parent_id AS children_parent_id FROM t LEFT OUTER JOIN t AS parent ON (parent.id = t.parent_id) LEFT OUTER JOIN t AS children ON (children.parent_id = parent.id)"]
269
-
270
- a.must_equal [@c.load(:id=>9, :parent_id=>6), @c.load(:id=>10, :parent_id=>7), @c.load(:id=>11, :parent_id=>8)]
271
- a.map(&:parent).must_equal [@c.load(:id=>6, :parent_id=>3), @c.load(:id=>7, :parent_id=>4), @c.load(:id=>8, :parent_id=>5)]
272
- a.map(&:parent).map(&:children).must_equal [
273
- [@c.load(:id=>9, :parent_id=>6), @c.load(:id=>12, :parent_id=>6)],
274
- [@c.load(:id=>10, :parent_id=>7), @c.load(:id=>13, :parent_id=>7)],
275
- [@c.load(:id=>11, :parent_id=>8), @c.load(:id=>14, :parent_id=>8)]]
276
- @c.db.sqls.must_equal []
277
-
278
- @c.dataset = @c.dataset.with_fetch([{:id=>19, :parent_id=>9}, {:id=>24, :parent_id=>14}])
279
- a.map(&:parent).map(&:children).map{|v| v.map(&:children)}
280
- #.must_equal [
281
- # [[@c.load(:id=>19, :parent_id=>9)], []],
282
- # [[], []],
283
- # [[], @c.load(:id=>24, :parent_id=>14)]]
284
- @c.db.sqls.must_equal ["SELECT * FROM t WHERE (t.parent_id IN (9, 10, 11, 12, 13, 14))"]
285
- end
286
-
287
- it "should allow eager loading of associated objects when using chained one_to_many associations with partial data" do
288
- a = @c.eager_graph(:children=>:children).
289
- with_fetch([
290
- {:id=>1, :parent_id=>nil, :children_id=>3, :children_parent_id=>1, :children_0_id=>6, :children_0_parent_id=>3},
291
- {:id=>1, :parent_id=>nil, :children_id=>4, :children_parent_id=>1, :children_0_id=>nil, :children_0_parent_id=>nil},
292
- {:id=>2, :parent_id=>nil, :children_id=>nil, :children_parent_id=>nil, :children_0_id=>nil, :children_0_parent_id=>nil}
293
- ]).all
294
- @c.db.sqls.must_equal ["SELECT t.id, t.parent_id, children.id AS children_id, children.parent_id AS children_parent_id, children_0.id AS children_0_id, children_0.parent_id AS children_0_parent_id FROM t LEFT OUTER JOIN t AS children ON (children.parent_id = t.id) LEFT OUTER JOIN t AS children_0 ON (children_0.parent_id = children.id)"]
295
-
296
- a.must_equal [@c.load(:id=>1, :parent_id=>nil), @c.load(:id=>2, :parent_id=>nil)]
297
- a.map(&:children).must_equal [
298
- [@c.load(:id=>3, :parent_id=>1),
299
- @c.load(:id=>4, :parent_id=>1)],
300
- []]
301
-
302
- a.map(&:children).map{|v| v.map(&:children)}.must_equal [
303
- [[@c.load(:id=>6, :parent_id=>3)],
304
- []],
305
- []]
306
- @c.db.sqls.must_equal []
307
-
308
- @c.dataset = @c.dataset.with_fetch([{:id=>9, :parent_id=>6}])
309
- a.map(&:children).map{|v| v.map(&:children).map{|v1| v1.map(&:children)}}.must_equal [
310
- [[[@c.load(:id=>9, :parent_id=>6)]],
311
- []],
312
- []]
313
- @c.db.sqls.must_equal ["SELECT * FROM t WHERE (t.parent_id IN (6))"]
314
- end
315
-
316
- it "should allow eager loading of associated objects when using chained many_to_one associations with partial data" do
317
- a = @c.eager_graph(:parent=>:parent).
318
- with_fetch([
319
- {:id=>9, :parent_id=>6, :parent_id_0=>6, :parent_parent_id=>3, :parent_0_id=>3, :parent_0_parent_id=>1},
320
- {:id=>10, :parent_id=>7, :parent_id_0=>7, :parent_parent_id=>nil, :parent_0_id=>nil, :parent_0_parent_id=>nil},
321
- {:id=>11, :parent_id=>nil, :parent_id_0=>nil, :parent_parent_id=>nil, :parent_0_id=>nil, :parent_0_parent_id=>nil}
322
- ]).all
323
- @c.db.sqls.must_equal ["SELECT t.id, t.parent_id, parent.id AS parent_id_0, parent.parent_id AS parent_parent_id, parent_0.id AS parent_0_id, parent_0.parent_id AS parent_0_parent_id FROM t LEFT OUTER JOIN t AS parent ON (parent.id = t.parent_id) LEFT OUTER JOIN t AS parent_0 ON (parent_0.id = parent.parent_id)"]
324
-
325
- a.must_equal [@c.load(:id=>9, :parent_id=>6), @c.load(:id=>10, :parent_id=>7), @c.load(:id=>11, :parent_id=>nil)]
326
- a.map(&:parent).must_equal [@c.load(:id=>6, :parent_id=>3), @c.load(:id=>7, :parent_id=>nil), nil]
327
- a.map(&:parent).map{|v| v.parent if v}.must_equal [@c.load(:id=>3, :parent_id=>1), nil, nil]
328
- @c.db.sqls.must_equal []
329
-
330
- @c.dataset = @c.dataset.with_fetch([{:id=>1, :parent_id=>nil}])
331
- a.map(&:parent).map{|v| v.parent.parent if v && v.parent}.must_equal [@c.load(:id=>1, :parent_id=>nil), nil, nil]
332
- @c.db.sqls.must_equal ["SELECT * FROM t WHERE (t.id IN (1))"]
333
- end
334
-
335
- it "should skip setup of eager loading when using eager_graph for association not using plugin" do
336
- c = Class.new(Sequel::Model)
337
- c.class_eval do
338
- set_dataset DB[:t]
339
- columns :id, :t_id
340
- end
341
- @c.many_to_one :f, :class=>c, :key=>:parent_id
342
- @c.one_to_many :fs, :class=>c
343
- c.many_to_one :t, :class=>@c
344
- c.one_to_many :ts, :class=>@c, :key=>:parent_id
345
-
346
- a = @c.eager_graph(:f, :parent, :fs=>:t).
347
- with_fetch([
348
- {:id=>5, :parent_id=>4, :f_id=>4, :t_id=>20, :parent_id_0=>4, :parent_parent_id=>3, :fs_id=>5, :fs_t_id=>30, :t_0_id=>30, :t_0_parent_id=>40},
349
- {:id=>15, :parent_id=>14, :f_id=>14, :t_id=>30, :parent_id_0=>14, :parent_parent_id=>13, :fs_id=>15, :fs_t_id=>40, :t_0_id=>40, :t_0_parent_id=>50},
350
- ]).
351
- all
352
- @c.db.sqls.must_equal ["SELECT t.id, t.parent_id, f.id AS f_id, f.t_id, parent.id AS parent_id_0, parent.parent_id AS parent_parent_id, fs.id AS fs_id, fs.t_id AS fs_t_id, t_0.id AS t_0_id, t_0.parent_id AS t_0_parent_id FROM t LEFT OUTER JOIN t AS f ON (f.id = t.parent_id) LEFT OUTER JOIN t AS parent ON (parent.id = t.parent_id) LEFT OUTER JOIN t AS fs ON (fs._id = t.id) LEFT OUTER JOIN t AS t_0 ON (t_0.id = fs.t_id)"]
353
-
354
- a.must_equal [@c.load(:id=>5, :parent_id=>4), @c.load(:id=>15, :parent_id=>14)]
355
- a.map(&:f).must_equal [c.load(:id=>4, :t_id=>20), c.load(:id=>14, :t_id=>30)]
356
- a.map(&:parent).must_equal [@c.load(:id=>4, :parent_id=>3), @c.load(:id=>14, :parent_id=>13)]
357
- a.map(&:fs).must_equal [[c.load(:id=>5, :t_id=>30)], [c.load(:id=>15, :t_id=>40)]]
358
- a.map(&:fs).map{|v| v.map(&:t)}.must_equal [[@c.load(:id=>30, :parent_id=>40)], [@c.load(:id=>40, :parent_id=>50)]]
359
- @c.db.sqls.must_equal []
360
-
361
- @c.dataset = @c.dataset.with_fetch([[{:id=>3, :parent_id=>1}, {:id=>13, :parent_id=>1}],
362
- [{:id=>1, :parent_id=>nil}],
363
- [{:id=>20, :parent_id=>nil}],
364
- [{:id=>30, :parent_id=>nil}],
365
- [{:id=>50, :parent_id=>nil}, {:id=>40, :parent_id=>nil}]
366
- ])
367
- a.map(&:parent).map(&:parent).must_equal [@c.load(:id=>3, :parent_id=>1), @c.load(:id=>13, :parent_id=>1)]
368
- @c.db.sqls.must_equal ["SELECT * FROM t WHERE (t.id IN (3, 13))"]
369
- a.map(&:parent).map(&:parent).map(&:parent).must_equal [@c.load(:id=>1, :parent_id=>nil), @c.load(:id=>1, :parent_id=>nil)]
370
- @c.db.sqls.must_equal ["SELECT * FROM t WHERE (t.id IN (1))"]
371
-
372
- a.map(&:f).map(&:t).must_equal [@c.load(:id=>20, :parent_id=>nil), @c.load(:id=>30, :parent_id=>nil)]
373
- @c.db.sqls.must_equal ["SELECT * FROM t WHERE id = 20", "SELECT * FROM t WHERE id = 30"]
374
-
375
- a.map(&:fs).map{|v| v.map(&:t).map(&:parent)}.must_equal [[@c.load(:id=>40, :parent_id=>nil)], [@c.load(:id=>50, :parent_id=>nil)]]
376
- @c.db.sqls.must_equal ["SELECT * FROM t WHERE (t.id IN (40, 50))"]
377
- end
378
-
379
- it "should skip frozen objects when eager loading for model objects" do
380
- a = @c.eager_graph(:parent).
381
- with_fetch([
382
- {:id=>9, :parent_id=>6, :parent_id_0=>6, :parent_parent_id=>3},
383
- {:id=>10, :parent_id=>7, :parent_id_0=>7, :parent_parent_id=>4},
384
- {:id=>11, :parent_id=>8, :parent_id_0=>8, :parent_parent_id=>5}
385
- ]).all
386
- @c.db.sqls.must_equal ["SELECT t.id, t.parent_id, parent.id AS parent_id_0, parent.parent_id AS parent_parent_id FROM t LEFT OUTER JOIN t AS parent ON (parent.id = t.parent_id)"]
387
-
388
- a.must_equal [@c.load(:id=>9, :parent_id=>6), @c.load(:id=>10, :parent_id=>7), @c.load(:id=>11, :parent_id=>8)]
389
- a.map(&:parent).must_equal [@c.load(:id=>6, :parent_id=>3), @c.load(:id=>7, :parent_id=>4), @c.load(:id=>8, :parent_id=>5)]
390
- @c.db.sqls.must_equal []
391
-
392
- @c.dataset = @c.dataset.with_fetch([[{:id=>3, :parent_id=>1}, {:id=>5, :parent_id=>2}], [{:id=>4, :parent_id=>nil}]])
393
- parents = a.map(&:parent)
394
- parents[1].freeze
395
- parents[0].parent.must_equal @c.load(:id=>3, :parent_id=>1)
396
- @c.db.sqls.must_equal ["SELECT * FROM t WHERE (t.id IN (3, 5))"]
397
- parents[1].parent.must_equal @c.load(:id=>4, :parent_id=>nil)
398
- @c.db.sqls.must_equal ["SELECT * FROM t WHERE id = 4"]
399
- parents[2].parent.must_equal @c.load(:id=>5, :parent_id=>2)
400
- @c.db.sqls.must_equal []
401
- end
402
- end