sequel 4.26.0 → 5.37.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (692) hide show
  1. checksums.yaml +5 -5
  2. data/CHANGELOG +405 -5656
  3. data/MIT-LICENSE +1 -1
  4. data/README.rdoc +232 -157
  5. data/bin/sequel +32 -9
  6. data/doc/advanced_associations.rdoc +252 -188
  7. data/doc/association_basics.rdoc +231 -273
  8. data/doc/bin_sequel.rdoc +5 -3
  9. data/doc/cheat_sheet.rdoc +75 -48
  10. data/doc/code_order.rdoc +28 -10
  11. data/doc/core_extensions.rdoc +104 -63
  12. data/doc/dataset_basics.rdoc +12 -21
  13. data/doc/dataset_filtering.rdoc +99 -86
  14. data/doc/extensions.rdoc +3 -10
  15. data/doc/mass_assignment.rdoc +74 -31
  16. data/doc/migration.rdoc +72 -46
  17. data/doc/model_dataset_method_design.rdoc +129 -0
  18. data/doc/model_hooks.rdoc +15 -25
  19. data/doc/model_plugins.rdoc +12 -12
  20. data/doc/mssql_stored_procedures.rdoc +3 -3
  21. data/doc/object_model.rdoc +59 -69
  22. data/doc/opening_databases.rdoc +84 -94
  23. data/doc/postgresql.rdoc +268 -38
  24. data/doc/prepared_statements.rdoc +29 -24
  25. data/doc/querying.rdoc +184 -164
  26. data/doc/reflection.rdoc +5 -6
  27. data/doc/release_notes/5.0.0.txt +159 -0
  28. data/doc/release_notes/5.1.0.txt +31 -0
  29. data/doc/release_notes/5.10.0.txt +84 -0
  30. data/doc/release_notes/5.11.0.txt +83 -0
  31. data/doc/release_notes/5.12.0.txt +141 -0
  32. data/doc/release_notes/5.13.0.txt +27 -0
  33. data/doc/release_notes/5.14.0.txt +63 -0
  34. data/doc/release_notes/5.15.0.txt +39 -0
  35. data/doc/release_notes/5.16.0.txt +110 -0
  36. data/doc/release_notes/5.17.0.txt +31 -0
  37. data/doc/release_notes/5.18.0.txt +69 -0
  38. data/doc/release_notes/5.19.0.txt +28 -0
  39. data/doc/release_notes/5.2.0.txt +33 -0
  40. data/doc/release_notes/5.20.0.txt +89 -0
  41. data/doc/release_notes/5.21.0.txt +87 -0
  42. data/doc/release_notes/5.22.0.txt +48 -0
  43. data/doc/release_notes/5.23.0.txt +56 -0
  44. data/doc/release_notes/5.24.0.txt +56 -0
  45. data/doc/release_notes/5.25.0.txt +32 -0
  46. data/doc/release_notes/5.26.0.txt +35 -0
  47. data/doc/release_notes/5.27.0.txt +21 -0
  48. data/doc/release_notes/5.28.0.txt +16 -0
  49. data/doc/release_notes/5.29.0.txt +22 -0
  50. data/doc/release_notes/5.3.0.txt +121 -0
  51. data/doc/release_notes/5.30.0.txt +20 -0
  52. data/doc/release_notes/5.31.0.txt +148 -0
  53. data/doc/release_notes/5.32.0.txt +46 -0
  54. data/doc/release_notes/5.33.0.txt +24 -0
  55. data/doc/release_notes/5.34.0.txt +40 -0
  56. data/doc/release_notes/5.35.0.txt +56 -0
  57. data/doc/release_notes/5.36.0.txt +60 -0
  58. data/doc/release_notes/5.37.0.txt +30 -0
  59. data/doc/release_notes/5.4.0.txt +80 -0
  60. data/doc/release_notes/5.5.0.txt +61 -0
  61. data/doc/release_notes/5.6.0.txt +31 -0
  62. data/doc/release_notes/5.7.0.txt +108 -0
  63. data/doc/release_notes/5.8.0.txt +170 -0
  64. data/doc/release_notes/5.9.0.txt +99 -0
  65. data/doc/schema_modification.rdoc +102 -77
  66. data/doc/security.rdoc +160 -87
  67. data/doc/sharding.rdoc +74 -47
  68. data/doc/sql.rdoc +135 -122
  69. data/doc/testing.rdoc +34 -18
  70. data/doc/thread_safety.rdoc +2 -4
  71. data/doc/transactions.rdoc +101 -19
  72. data/doc/validations.rdoc +64 -51
  73. data/doc/virtual_rows.rdoc +90 -109
  74. data/lib/sequel.rb +3 -1
  75. data/lib/sequel/adapters/ado.rb +154 -22
  76. data/lib/sequel/adapters/ado/access.rb +21 -21
  77. data/lib/sequel/adapters/ado/mssql.rb +8 -15
  78. data/lib/sequel/adapters/amalgalite.rb +17 -25
  79. data/lib/sequel/adapters/ibmdb.rb +52 -58
  80. data/lib/sequel/adapters/jdbc.rb +149 -127
  81. data/lib/sequel/adapters/jdbc/db2.rb +32 -40
  82. data/lib/sequel/adapters/jdbc/derby.rb +56 -58
  83. data/lib/sequel/adapters/jdbc/h2.rb +40 -30
  84. data/lib/sequel/adapters/jdbc/hsqldb.rb +22 -33
  85. data/lib/sequel/adapters/jdbc/jtds.rb +4 -10
  86. data/lib/sequel/adapters/jdbc/mssql.rb +6 -12
  87. data/lib/sequel/adapters/jdbc/mysql.rb +17 -18
  88. data/lib/sequel/adapters/jdbc/oracle.rb +25 -19
  89. data/lib/sequel/adapters/jdbc/postgresql.rb +90 -69
  90. data/lib/sequel/adapters/jdbc/sqlanywhere.rb +14 -24
  91. data/lib/sequel/adapters/jdbc/sqlite.rb +50 -12
  92. data/lib/sequel/adapters/jdbc/sqlserver.rb +36 -9
  93. data/lib/sequel/adapters/jdbc/transactions.rb +25 -39
  94. data/lib/sequel/adapters/mock.rb +104 -113
  95. data/lib/sequel/adapters/mysql.rb +42 -61
  96. data/lib/sequel/adapters/mysql2.rb +126 -35
  97. data/lib/sequel/adapters/odbc.rb +21 -28
  98. data/lib/sequel/adapters/odbc/db2.rb +3 -1
  99. data/lib/sequel/adapters/odbc/mssql.rb +11 -15
  100. data/lib/sequel/adapters/odbc/oracle.rb +11 -0
  101. data/lib/sequel/adapters/oracle.rb +62 -68
  102. data/lib/sequel/adapters/postgres.rb +257 -311
  103. data/lib/sequel/adapters/postgresql.rb +3 -1
  104. data/lib/sequel/adapters/shared/access.rb +75 -79
  105. data/lib/sequel/adapters/shared/db2.rb +96 -74
  106. data/lib/sequel/adapters/shared/mssql.rb +258 -213
  107. data/lib/sequel/adapters/shared/mysql.rb +284 -216
  108. data/lib/sequel/adapters/shared/oracle.rb +175 -60
  109. data/lib/sequel/adapters/shared/postgres.rb +829 -383
  110. data/lib/sequel/adapters/shared/sqlanywhere.rb +105 -127
  111. data/lib/sequel/adapters/shared/sqlite.rb +382 -159
  112. data/lib/sequel/adapters/sqlanywhere.rb +53 -38
  113. data/lib/sequel/adapters/sqlite.rb +111 -105
  114. data/lib/sequel/adapters/tinytds.rb +38 -46
  115. data/lib/sequel/adapters/utils/emulate_offset_with_reverse_and_count.rb +8 -9
  116. data/lib/sequel/adapters/utils/emulate_offset_with_row_number.rb +7 -5
  117. data/lib/sequel/adapters/utils/mysql_mysql2.rb +87 -0
  118. data/lib/sequel/adapters/utils/mysql_prepared_statements.rb +56 -0
  119. data/lib/sequel/adapters/utils/replace.rb +3 -4
  120. data/lib/sequel/adapters/utils/split_alter_table.rb +2 -0
  121. data/lib/sequel/adapters/utils/stored_procedures.rb +9 -22
  122. data/lib/sequel/adapters/utils/unmodified_identifiers.rb +28 -0
  123. data/lib/sequel/ast_transformer.rb +13 -89
  124. data/lib/sequel/connection_pool.rb +54 -26
  125. data/lib/sequel/connection_pool/sharded_single.rb +19 -12
  126. data/lib/sequel/connection_pool/sharded_threaded.rb +160 -111
  127. data/lib/sequel/connection_pool/single.rb +21 -12
  128. data/lib/sequel/connection_pool/threaded.rb +137 -119
  129. data/lib/sequel/core.rb +352 -320
  130. data/lib/sequel/database.rb +19 -2
  131. data/lib/sequel/database/connecting.rb +70 -55
  132. data/lib/sequel/database/dataset.rb +15 -5
  133. data/lib/sequel/database/dataset_defaults.rb +20 -102
  134. data/lib/sequel/database/features.rb +20 -4
  135. data/lib/sequel/database/logging.rb +25 -7
  136. data/lib/sequel/database/misc.rb +132 -118
  137. data/lib/sequel/database/query.rb +51 -28
  138. data/lib/sequel/database/schema_generator.rb +188 -75
  139. data/lib/sequel/database/schema_methods.rb +161 -92
  140. data/lib/sequel/database/transactions.rb +260 -58
  141. data/lib/sequel/dataset.rb +28 -12
  142. data/lib/sequel/dataset/actions.rb +354 -170
  143. data/lib/sequel/dataset/dataset_module.rb +46 -0
  144. data/lib/sequel/dataset/features.rb +81 -34
  145. data/lib/sequel/dataset/graph.rb +82 -58
  146. data/lib/sequel/dataset/misc.rb +139 -47
  147. data/lib/sequel/dataset/placeholder_literalizer.rb +66 -26
  148. data/lib/sequel/dataset/prepared_statements.rb +188 -85
  149. data/lib/sequel/dataset/query.rb +428 -214
  150. data/lib/sequel/dataset/sql.rb +446 -339
  151. data/lib/sequel/deprecated.rb +14 -2
  152. data/lib/sequel/exceptions.rb +48 -16
  153. data/lib/sequel/extensions/_model_constraint_validations.rb +16 -0
  154. data/lib/sequel/extensions/_model_pg_row.rb +43 -0
  155. data/lib/sequel/extensions/_pretty_table.rb +10 -9
  156. data/lib/sequel/extensions/any_not_empty.rb +45 -0
  157. data/lib/sequel/extensions/arbitrary_servers.rb +15 -11
  158. data/lib/sequel/extensions/auto_literal_strings.rb +74 -0
  159. data/lib/sequel/extensions/blank.rb +2 -0
  160. data/lib/sequel/extensions/caller_logging.rb +79 -0
  161. data/lib/sequel/extensions/columns_introspection.rb +9 -4
  162. data/lib/sequel/extensions/connection_expiration.rb +99 -0
  163. data/lib/sequel/extensions/connection_validator.rb +26 -13
  164. data/lib/sequel/extensions/constant_sql_override.rb +65 -0
  165. data/lib/sequel/extensions/constraint_validations.rb +93 -38
  166. data/lib/sequel/extensions/core_extensions.rb +45 -53
  167. data/lib/sequel/extensions/core_refinements.rb +44 -46
  168. data/lib/sequel/extensions/current_datetime_timestamp.rb +5 -4
  169. data/lib/sequel/extensions/dataset_source_alias.rb +4 -0
  170. data/lib/sequel/extensions/date_arithmetic.rb +42 -16
  171. data/lib/sequel/extensions/datetime_parse_to_time.rb +37 -0
  172. data/lib/sequel/extensions/duplicate_columns_handler.rb +94 -0
  173. data/lib/sequel/extensions/empty_array_consider_nulls.rb +7 -3
  174. data/lib/sequel/extensions/error_sql.rb +7 -3
  175. data/lib/sequel/extensions/escaped_like.rb +100 -0
  176. data/lib/sequel/extensions/eval_inspect.rb +14 -15
  177. data/lib/sequel/extensions/exclude_or_null.rb +68 -0
  178. data/lib/sequel/extensions/fiber_concurrency.rb +24 -0
  179. data/lib/sequel/extensions/freeze_datasets.rb +3 -0
  180. data/lib/sequel/extensions/from_block.rb +2 -31
  181. data/lib/sequel/extensions/graph_each.rb +19 -6
  182. data/lib/sequel/extensions/identifier_mangling.rb +180 -0
  183. data/lib/sequel/extensions/implicit_subquery.rb +48 -0
  184. data/lib/sequel/extensions/index_caching.rb +109 -0
  185. data/lib/sequel/extensions/inflector.rb +8 -4
  186. data/lib/sequel/extensions/integer64.rb +32 -0
  187. data/lib/sequel/extensions/looser_typecasting.rb +19 -9
  188. data/lib/sequel/extensions/migration.rb +132 -80
  189. data/lib/sequel/extensions/mssql_emulate_lateral_with_apply.rb +4 -0
  190. data/lib/sequel/extensions/named_timezones.rb +88 -23
  191. data/lib/sequel/extensions/no_auto_literal_strings.rb +4 -0
  192. data/lib/sequel/extensions/null_dataset.rb +12 -8
  193. data/lib/sequel/extensions/pagination.rb +35 -28
  194. data/lib/sequel/extensions/pg_array.rb +227 -316
  195. data/lib/sequel/extensions/pg_array_ops.rb +19 -7
  196. data/lib/sequel/extensions/pg_enum.rb +69 -24
  197. data/lib/sequel/extensions/pg_extended_date_support.rb +250 -0
  198. data/lib/sequel/extensions/pg_hstore.rb +50 -59
  199. data/lib/sequel/extensions/pg_hstore_ops.rb +9 -3
  200. data/lib/sequel/extensions/pg_inet.rb +34 -15
  201. data/lib/sequel/extensions/pg_inet_ops.rb +5 -1
  202. data/lib/sequel/extensions/pg_interval.rb +26 -26
  203. data/lib/sequel/extensions/pg_json.rb +422 -141
  204. data/lib/sequel/extensions/pg_json_ops.rb +248 -9
  205. data/lib/sequel/extensions/pg_loose_count.rb +5 -1
  206. data/lib/sequel/extensions/pg_range.rb +162 -146
  207. data/lib/sequel/extensions/pg_range_ops.rb +10 -5
  208. data/lib/sequel/extensions/pg_row.rb +53 -87
  209. data/lib/sequel/extensions/pg_row_ops.rb +36 -13
  210. data/lib/sequel/extensions/pg_static_cache_updater.rb +6 -2
  211. data/lib/sequel/extensions/pg_timestamptz.rb +28 -0
  212. data/lib/sequel/extensions/pretty_table.rb +4 -0
  213. data/lib/sequel/extensions/query.rb +12 -7
  214. data/lib/sequel/extensions/round_timestamps.rb +6 -9
  215. data/lib/sequel/extensions/run_transaction_hooks.rb +72 -0
  216. data/lib/sequel/extensions/s.rb +59 -0
  217. data/lib/sequel/extensions/schema_caching.rb +14 -1
  218. data/lib/sequel/extensions/schema_dumper.rb +83 -55
  219. data/lib/sequel/extensions/select_remove.rb +8 -4
  220. data/lib/sequel/extensions/sequel_4_dataset_methods.rb +85 -0
  221. data/lib/sequel/extensions/server_block.rb +50 -17
  222. data/lib/sequel/extensions/server_logging.rb +61 -0
  223. data/lib/sequel/extensions/split_array_nil.rb +8 -4
  224. data/lib/sequel/extensions/sql_comments.rb +96 -0
  225. data/lib/sequel/extensions/sql_expr.rb +4 -1
  226. data/lib/sequel/extensions/string_agg.rb +181 -0
  227. data/lib/sequel/extensions/string_date_time.rb +2 -0
  228. data/lib/sequel/extensions/symbol_aref.rb +53 -0
  229. data/lib/sequel/extensions/symbol_aref_refinement.rb +43 -0
  230. data/lib/sequel/extensions/symbol_as.rb +23 -0
  231. data/lib/sequel/extensions/symbol_as_refinement.rb +37 -0
  232. data/lib/sequel/extensions/synchronize_sql.rb +45 -0
  233. data/lib/sequel/extensions/thread_local_timezones.rb +4 -0
  234. data/lib/sequel/extensions/to_dot.rb +15 -5
  235. data/lib/sequel/extensions/virtual_row_method_block.rb +44 -0
  236. data/lib/sequel/model.rb +36 -126
  237. data/lib/sequel/model/associations.rb +850 -257
  238. data/lib/sequel/model/base.rb +652 -764
  239. data/lib/sequel/model/dataset_module.rb +13 -10
  240. data/lib/sequel/model/default_inflections.rb +3 -1
  241. data/lib/sequel/model/errors.rb +3 -3
  242. data/lib/sequel/model/exceptions.rb +12 -12
  243. data/lib/sequel/model/inflections.rb +8 -19
  244. data/lib/sequel/model/plugins.rb +111 -0
  245. data/lib/sequel/plugins/accessed_columns.rb +2 -0
  246. data/lib/sequel/plugins/active_model.rb +32 -7
  247. data/lib/sequel/plugins/after_initialize.rb +3 -1
  248. data/lib/sequel/plugins/association_dependencies.rb +27 -18
  249. data/lib/sequel/plugins/association_lazy_eager_option.rb +66 -0
  250. data/lib/sequel/plugins/association_multi_add_remove.rb +85 -0
  251. data/lib/sequel/plugins/association_pks.rb +181 -83
  252. data/lib/sequel/plugins/association_proxies.rb +33 -9
  253. data/lib/sequel/plugins/auto_validations.rb +58 -23
  254. data/lib/sequel/plugins/before_after_save.rb +8 -0
  255. data/lib/sequel/plugins/blacklist_security.rb +23 -12
  256. data/lib/sequel/plugins/boolean_readers.rb +9 -6
  257. data/lib/sequel/plugins/boolean_subsets.rb +64 -0
  258. data/lib/sequel/plugins/caching.rb +27 -16
  259. data/lib/sequel/plugins/class_table_inheritance.rb +192 -94
  260. data/lib/sequel/plugins/column_conflicts.rb +18 -3
  261. data/lib/sequel/plugins/column_select.rb +9 -5
  262. data/lib/sequel/plugins/columns_updated.rb +42 -0
  263. data/lib/sequel/plugins/composition.rb +36 -24
  264. data/lib/sequel/plugins/constraint_validations.rb +37 -16
  265. data/lib/sequel/plugins/csv_serializer.rb +58 -35
  266. data/lib/sequel/plugins/dataset_associations.rb +60 -18
  267. data/lib/sequel/plugins/def_dataset_method.rb +90 -0
  268. data/lib/sequel/plugins/defaults_setter.rb +74 -13
  269. data/lib/sequel/plugins/delay_add_association.rb +4 -1
  270. data/lib/sequel/plugins/dirty.rb +65 -24
  271. data/lib/sequel/plugins/eager_each.rb +27 -3
  272. data/lib/sequel/plugins/eager_graph_eager.rb +139 -0
  273. data/lib/sequel/plugins/empty_failure_backtraces.rb +38 -0
  274. data/lib/sequel/plugins/error_splitter.rb +19 -12
  275. data/lib/sequel/plugins/finder.rb +246 -0
  276. data/lib/sequel/plugins/forbid_lazy_load.rb +216 -0
  277. data/lib/sequel/plugins/force_encoding.rb +9 -12
  278. data/lib/sequel/plugins/hook_class_methods.rb +39 -54
  279. data/lib/sequel/plugins/input_transformer.rb +20 -10
  280. data/lib/sequel/plugins/insert_conflict.rb +72 -0
  281. data/lib/sequel/plugins/insert_returning_select.rb +4 -2
  282. data/lib/sequel/plugins/instance_filters.rb +12 -8
  283. data/lib/sequel/plugins/instance_hooks.rb +36 -17
  284. data/lib/sequel/plugins/instance_specific_default.rb +113 -0
  285. data/lib/sequel/plugins/inverted_subsets.rb +24 -13
  286. data/lib/sequel/plugins/json_serializer.rb +123 -47
  287. data/lib/sequel/plugins/lazy_attributes.rb +20 -14
  288. data/lib/sequel/plugins/list.rb +40 -26
  289. data/lib/sequel/plugins/many_through_many.rb +28 -12
  290. data/lib/sequel/plugins/modification_detection.rb +17 -5
  291. data/lib/sequel/plugins/mssql_optimistic_locking.rb +8 -5
  292. data/lib/sequel/plugins/nested_attributes.rb +55 -28
  293. data/lib/sequel/plugins/optimistic_locking.rb +5 -3
  294. data/lib/sequel/plugins/pg_array_associations.rb +52 -18
  295. data/lib/sequel/plugins/pg_auto_constraint_validations.rb +348 -0
  296. data/lib/sequel/plugins/pg_row.rb +7 -51
  297. data/lib/sequel/plugins/prepared_statements.rb +53 -72
  298. data/lib/sequel/plugins/prepared_statements_safe.rb +13 -5
  299. data/lib/sequel/plugins/rcte_tree.rb +43 -63
  300. data/lib/sequel/plugins/serialization.rb +37 -44
  301. data/lib/sequel/plugins/serialization_modification_detection.rb +3 -1
  302. data/lib/sequel/plugins/sharding.rb +17 -10
  303. data/lib/sequel/plugins/single_table_inheritance.rb +62 -28
  304. data/lib/sequel/plugins/singular_table_names.rb +2 -0
  305. data/lib/sequel/plugins/skip_create_refresh.rb +5 -3
  306. data/lib/sequel/plugins/skip_saving_columns.rb +108 -0
  307. data/lib/sequel/plugins/split_values.rb +13 -6
  308. data/lib/sequel/plugins/static_cache.rb +79 -53
  309. data/lib/sequel/plugins/static_cache_cache.rb +53 -0
  310. data/lib/sequel/plugins/string_stripper.rb +5 -3
  311. data/lib/sequel/plugins/subclasses.rb +20 -2
  312. data/lib/sequel/plugins/subset_conditions.rb +48 -0
  313. data/lib/sequel/plugins/table_select.rb +4 -2
  314. data/lib/sequel/plugins/tactical_eager_loading.rb +120 -6
  315. data/lib/sequel/plugins/throw_failures.rb +110 -0
  316. data/lib/sequel/plugins/timestamps.rb +22 -8
  317. data/lib/sequel/plugins/touch.rb +21 -8
  318. data/lib/sequel/plugins/tree.rb +57 -30
  319. data/lib/sequel/plugins/typecast_on_load.rb +14 -4
  320. data/lib/sequel/plugins/unlimited_update.rb +3 -7
  321. data/lib/sequel/plugins/update_or_create.rb +6 -4
  322. data/lib/sequel/plugins/update_primary_key.rb +3 -1
  323. data/lib/sequel/plugins/update_refresh.rb +28 -15
  324. data/lib/sequel/plugins/uuid.rb +70 -0
  325. data/lib/sequel/plugins/validate_associated.rb +20 -0
  326. data/lib/sequel/plugins/validation_class_methods.rb +40 -19
  327. data/lib/sequel/plugins/validation_contexts.rb +49 -0
  328. data/lib/sequel/plugins/validation_helpers.rb +49 -31
  329. data/lib/sequel/plugins/whitelist_security.rb +122 -0
  330. data/lib/sequel/plugins/xml_serializer.rb +31 -30
  331. data/lib/sequel/sql.rb +479 -329
  332. data/lib/sequel/timezones.rb +62 -32
  333. data/lib/sequel/version.rb +10 -3
  334. metadata +177 -477
  335. data/Rakefile +0 -165
  336. data/doc/active_record.rdoc +0 -912
  337. data/doc/release_notes/1.0.txt +0 -38
  338. data/doc/release_notes/1.1.txt +0 -143
  339. data/doc/release_notes/1.3.txt +0 -101
  340. data/doc/release_notes/1.4.0.txt +0 -53
  341. data/doc/release_notes/1.5.0.txt +0 -155
  342. data/doc/release_notes/2.0.0.txt +0 -298
  343. data/doc/release_notes/2.1.0.txt +0 -271
  344. data/doc/release_notes/2.10.0.txt +0 -328
  345. data/doc/release_notes/2.11.0.txt +0 -215
  346. data/doc/release_notes/2.12.0.txt +0 -534
  347. data/doc/release_notes/2.2.0.txt +0 -253
  348. data/doc/release_notes/2.3.0.txt +0 -88
  349. data/doc/release_notes/2.4.0.txt +0 -106
  350. data/doc/release_notes/2.5.0.txt +0 -137
  351. data/doc/release_notes/2.6.0.txt +0 -157
  352. data/doc/release_notes/2.7.0.txt +0 -166
  353. data/doc/release_notes/2.8.0.txt +0 -171
  354. data/doc/release_notes/2.9.0.txt +0 -97
  355. data/doc/release_notes/3.0.0.txt +0 -221
  356. data/doc/release_notes/3.1.0.txt +0 -406
  357. data/doc/release_notes/3.10.0.txt +0 -286
  358. data/doc/release_notes/3.11.0.txt +0 -254
  359. data/doc/release_notes/3.12.0.txt +0 -304
  360. data/doc/release_notes/3.13.0.txt +0 -210
  361. data/doc/release_notes/3.14.0.txt +0 -118
  362. data/doc/release_notes/3.15.0.txt +0 -78
  363. data/doc/release_notes/3.16.0.txt +0 -45
  364. data/doc/release_notes/3.17.0.txt +0 -58
  365. data/doc/release_notes/3.18.0.txt +0 -120
  366. data/doc/release_notes/3.19.0.txt +0 -67
  367. data/doc/release_notes/3.2.0.txt +0 -268
  368. data/doc/release_notes/3.20.0.txt +0 -41
  369. data/doc/release_notes/3.21.0.txt +0 -87
  370. data/doc/release_notes/3.22.0.txt +0 -39
  371. data/doc/release_notes/3.23.0.txt +0 -172
  372. data/doc/release_notes/3.24.0.txt +0 -420
  373. data/doc/release_notes/3.25.0.txt +0 -88
  374. data/doc/release_notes/3.26.0.txt +0 -88
  375. data/doc/release_notes/3.27.0.txt +0 -82
  376. data/doc/release_notes/3.28.0.txt +0 -304
  377. data/doc/release_notes/3.29.0.txt +0 -459
  378. data/doc/release_notes/3.3.0.txt +0 -192
  379. data/doc/release_notes/3.30.0.txt +0 -135
  380. data/doc/release_notes/3.31.0.txt +0 -146
  381. data/doc/release_notes/3.32.0.txt +0 -202
  382. data/doc/release_notes/3.33.0.txt +0 -157
  383. data/doc/release_notes/3.34.0.txt +0 -671
  384. data/doc/release_notes/3.35.0.txt +0 -144
  385. data/doc/release_notes/3.36.0.txt +0 -245
  386. data/doc/release_notes/3.37.0.txt +0 -338
  387. data/doc/release_notes/3.38.0.txt +0 -234
  388. data/doc/release_notes/3.39.0.txt +0 -237
  389. data/doc/release_notes/3.4.0.txt +0 -325
  390. data/doc/release_notes/3.40.0.txt +0 -73
  391. data/doc/release_notes/3.41.0.txt +0 -155
  392. data/doc/release_notes/3.42.0.txt +0 -74
  393. data/doc/release_notes/3.43.0.txt +0 -105
  394. data/doc/release_notes/3.44.0.txt +0 -152
  395. data/doc/release_notes/3.45.0.txt +0 -179
  396. data/doc/release_notes/3.46.0.txt +0 -122
  397. data/doc/release_notes/3.47.0.txt +0 -270
  398. data/doc/release_notes/3.48.0.txt +0 -477
  399. data/doc/release_notes/3.5.0.txt +0 -510
  400. data/doc/release_notes/3.6.0.txt +0 -366
  401. data/doc/release_notes/3.7.0.txt +0 -179
  402. data/doc/release_notes/3.8.0.txt +0 -151
  403. data/doc/release_notes/3.9.0.txt +0 -233
  404. data/doc/release_notes/4.0.0.txt +0 -262
  405. data/doc/release_notes/4.1.0.txt +0 -85
  406. data/doc/release_notes/4.10.0.txt +0 -226
  407. data/doc/release_notes/4.11.0.txt +0 -147
  408. data/doc/release_notes/4.12.0.txt +0 -105
  409. data/doc/release_notes/4.13.0.txt +0 -169
  410. data/doc/release_notes/4.14.0.txt +0 -68
  411. data/doc/release_notes/4.15.0.txt +0 -56
  412. data/doc/release_notes/4.16.0.txt +0 -36
  413. data/doc/release_notes/4.17.0.txt +0 -38
  414. data/doc/release_notes/4.18.0.txt +0 -36
  415. data/doc/release_notes/4.19.0.txt +0 -45
  416. data/doc/release_notes/4.2.0.txt +0 -129
  417. data/doc/release_notes/4.20.0.txt +0 -79
  418. data/doc/release_notes/4.21.0.txt +0 -94
  419. data/doc/release_notes/4.22.0.txt +0 -72
  420. data/doc/release_notes/4.23.0.txt +0 -65
  421. data/doc/release_notes/4.24.0.txt +0 -99
  422. data/doc/release_notes/4.25.0.txt +0 -181
  423. data/doc/release_notes/4.26.0.txt +0 -44
  424. data/doc/release_notes/4.3.0.txt +0 -40
  425. data/doc/release_notes/4.4.0.txt +0 -92
  426. data/doc/release_notes/4.5.0.txt +0 -34
  427. data/doc/release_notes/4.6.0.txt +0 -30
  428. data/doc/release_notes/4.7.0.txt +0 -103
  429. data/doc/release_notes/4.8.0.txt +0 -175
  430. data/doc/release_notes/4.9.0.txt +0 -190
  431. data/lib/sequel/adapters/cubrid.rb +0 -142
  432. data/lib/sequel/adapters/do.rb +0 -156
  433. data/lib/sequel/adapters/do/mysql.rb +0 -64
  434. data/lib/sequel/adapters/do/postgres.rb +0 -42
  435. data/lib/sequel/adapters/do/sqlite3.rb +0 -40
  436. data/lib/sequel/adapters/jdbc/as400.rb +0 -82
  437. data/lib/sequel/adapters/jdbc/cubrid.rb +0 -62
  438. data/lib/sequel/adapters/jdbc/firebirdsql.rb +0 -34
  439. data/lib/sequel/adapters/jdbc/informix-sqli.rb +0 -31
  440. data/lib/sequel/adapters/jdbc/jdbcprogress.rb +0 -31
  441. data/lib/sequel/adapters/odbc/progress.rb +0 -8
  442. data/lib/sequel/adapters/shared/cubrid.rb +0 -243
  443. data/lib/sequel/adapters/shared/firebird.rb +0 -245
  444. data/lib/sequel/adapters/shared/informix.rb +0 -52
  445. data/lib/sequel/adapters/shared/mysql_prepared_statements.rb +0 -150
  446. data/lib/sequel/adapters/shared/progress.rb +0 -38
  447. data/lib/sequel/adapters/swift.rb +0 -158
  448. data/lib/sequel/adapters/swift/mysql.rb +0 -47
  449. data/lib/sequel/adapters/swift/postgres.rb +0 -45
  450. data/lib/sequel/adapters/swift/sqlite.rb +0 -47
  451. data/lib/sequel/adapters/utils/pg_types.rb +0 -68
  452. data/lib/sequel/dataset/mutation.rb +0 -109
  453. data/lib/sequel/extensions/empty_array_ignore_nulls.rb +0 -3
  454. data/lib/sequel/extensions/filter_having.rb +0 -59
  455. data/lib/sequel/extensions/hash_aliases.rb +0 -45
  456. data/lib/sequel/extensions/meta_def.rb +0 -31
  457. data/lib/sequel/extensions/query_literals.rb +0 -80
  458. data/lib/sequel/extensions/ruby18_symbol_extensions.rb +0 -22
  459. data/lib/sequel/extensions/sequel_3_dataset_methods.rb +0 -118
  460. data/lib/sequel/extensions/set_overrides.rb +0 -72
  461. data/lib/sequel/no_core_ext.rb +0 -1
  462. data/lib/sequel/plugins/association_autoreloading.rb +0 -7
  463. data/lib/sequel/plugins/many_to_one_pk_lookup.rb +0 -7
  464. data/lib/sequel/plugins/pg_typecast_on_load.rb +0 -78
  465. data/lib/sequel/plugins/prepared_statements_associations.rb +0 -117
  466. data/lib/sequel/plugins/prepared_statements_with_pk.rb +0 -59
  467. data/lib/sequel/plugins/schema.rb +0 -80
  468. data/lib/sequel/plugins/scissors.rb +0 -33
  469. data/spec/adapters/db2_spec.rb +0 -160
  470. data/spec/adapters/firebird_spec.rb +0 -411
  471. data/spec/adapters/informix_spec.rb +0 -100
  472. data/spec/adapters/mssql_spec.rb +0 -706
  473. data/spec/adapters/mysql_spec.rb +0 -1287
  474. data/spec/adapters/oracle_spec.rb +0 -313
  475. data/spec/adapters/postgres_spec.rb +0 -3725
  476. data/spec/adapters/spec_helper.rb +0 -43
  477. data/spec/adapters/sqlanywhere_spec.rb +0 -170
  478. data/spec/adapters/sqlite_spec.rb +0 -653
  479. data/spec/bin_spec.rb +0 -254
  480. data/spec/core/connection_pool_spec.rb +0 -1016
  481. data/spec/core/database_spec.rb +0 -2531
  482. data/spec/core/dataset_spec.rb +0 -5098
  483. data/spec/core/deprecated_spec.rb +0 -70
  484. data/spec/core/expression_filters_spec.rb +0 -1243
  485. data/spec/core/mock_adapter_spec.rb +0 -462
  486. data/spec/core/object_graph_spec.rb +0 -303
  487. data/spec/core/placeholder_literalizer_spec.rb +0 -163
  488. data/spec/core/schema_generator_spec.rb +0 -179
  489. data/spec/core/schema_spec.rb +0 -1659
  490. data/spec/core/spec_helper.rb +0 -34
  491. data/spec/core/version_spec.rb +0 -7
  492. data/spec/core_extensions_spec.rb +0 -699
  493. data/spec/extensions/accessed_columns_spec.rb +0 -51
  494. data/spec/extensions/active_model_spec.rb +0 -123
  495. data/spec/extensions/after_initialize_spec.rb +0 -24
  496. data/spec/extensions/arbitrary_servers_spec.rb +0 -109
  497. data/spec/extensions/association_dependencies_spec.rb +0 -117
  498. data/spec/extensions/association_pks_spec.rb +0 -365
  499. data/spec/extensions/association_proxies_spec.rb +0 -86
  500. data/spec/extensions/auto_validations_spec.rb +0 -192
  501. data/spec/extensions/blacklist_security_spec.rb +0 -88
  502. data/spec/extensions/blank_spec.rb +0 -69
  503. data/spec/extensions/boolean_readers_spec.rb +0 -93
  504. data/spec/extensions/caching_spec.rb +0 -270
  505. data/spec/extensions/class_table_inheritance_spec.rb +0 -420
  506. data/spec/extensions/column_conflicts_spec.rb +0 -60
  507. data/spec/extensions/column_select_spec.rb +0 -108
  508. data/spec/extensions/columns_introspection_spec.rb +0 -91
  509. data/spec/extensions/composition_spec.rb +0 -242
  510. data/spec/extensions/connection_validator_spec.rb +0 -120
  511. data/spec/extensions/constraint_validations_plugin_spec.rb +0 -274
  512. data/spec/extensions/constraint_validations_spec.rb +0 -325
  513. data/spec/extensions/core_refinements_spec.rb +0 -519
  514. data/spec/extensions/csv_serializer_spec.rb +0 -173
  515. data/spec/extensions/current_datetime_timestamp_spec.rb +0 -27
  516. data/spec/extensions/dataset_associations_spec.rb +0 -311
  517. data/spec/extensions/dataset_source_alias_spec.rb +0 -51
  518. data/spec/extensions/date_arithmetic_spec.rb +0 -150
  519. data/spec/extensions/defaults_setter_spec.rb +0 -101
  520. data/spec/extensions/delay_add_association_spec.rb +0 -52
  521. data/spec/extensions/dirty_spec.rb +0 -180
  522. data/spec/extensions/eager_each_spec.rb +0 -42
  523. data/spec/extensions/empty_array_consider_nulls_spec.rb +0 -24
  524. data/spec/extensions/error_splitter_spec.rb +0 -18
  525. data/spec/extensions/error_sql_spec.rb +0 -20
  526. data/spec/extensions/eval_inspect_spec.rb +0 -73
  527. data/spec/extensions/filter_having_spec.rb +0 -40
  528. data/spec/extensions/force_encoding_spec.rb +0 -114
  529. data/spec/extensions/from_block_spec.rb +0 -21
  530. data/spec/extensions/graph_each_spec.rb +0 -109
  531. data/spec/extensions/hash_aliases_spec.rb +0 -24
  532. data/spec/extensions/hook_class_methods_spec.rb +0 -429
  533. data/spec/extensions/inflector_spec.rb +0 -183
  534. data/spec/extensions/input_transformer_spec.rb +0 -54
  535. data/spec/extensions/insert_returning_select_spec.rb +0 -46
  536. data/spec/extensions/instance_filters_spec.rb +0 -79
  537. data/spec/extensions/instance_hooks_spec.rb +0 -276
  538. data/spec/extensions/inverted_subsets_spec.rb +0 -33
  539. data/spec/extensions/json_serializer_spec.rb +0 -291
  540. data/spec/extensions/lazy_attributes_spec.rb +0 -170
  541. data/spec/extensions/list_spec.rb +0 -267
  542. data/spec/extensions/looser_typecasting_spec.rb +0 -43
  543. data/spec/extensions/many_through_many_spec.rb +0 -2172
  544. data/spec/extensions/meta_def_spec.rb +0 -21
  545. data/spec/extensions/migration_spec.rb +0 -712
  546. data/spec/extensions/modification_detection_spec.rb +0 -80
  547. data/spec/extensions/mssql_optimistic_locking_spec.rb +0 -91
  548. data/spec/extensions/named_timezones_spec.rb +0 -108
  549. data/spec/extensions/nested_attributes_spec.rb +0 -697
  550. data/spec/extensions/null_dataset_spec.rb +0 -85
  551. data/spec/extensions/optimistic_locking_spec.rb +0 -128
  552. data/spec/extensions/pagination_spec.rb +0 -118
  553. data/spec/extensions/pg_array_associations_spec.rb +0 -736
  554. data/spec/extensions/pg_array_ops_spec.rb +0 -143
  555. data/spec/extensions/pg_array_spec.rb +0 -395
  556. data/spec/extensions/pg_enum_spec.rb +0 -92
  557. data/spec/extensions/pg_hstore_ops_spec.rb +0 -236
  558. data/spec/extensions/pg_hstore_spec.rb +0 -206
  559. data/spec/extensions/pg_inet_ops_spec.rb +0 -101
  560. data/spec/extensions/pg_inet_spec.rb +0 -52
  561. data/spec/extensions/pg_interval_spec.rb +0 -76
  562. data/spec/extensions/pg_json_ops_spec.rb +0 -229
  563. data/spec/extensions/pg_json_spec.rb +0 -218
  564. data/spec/extensions/pg_loose_count_spec.rb +0 -17
  565. data/spec/extensions/pg_range_ops_spec.rb +0 -58
  566. data/spec/extensions/pg_range_spec.rb +0 -404
  567. data/spec/extensions/pg_row_ops_spec.rb +0 -60
  568. data/spec/extensions/pg_row_plugin_spec.rb +0 -62
  569. data/spec/extensions/pg_row_spec.rb +0 -360
  570. data/spec/extensions/pg_static_cache_updater_spec.rb +0 -92
  571. data/spec/extensions/pg_typecast_on_load_spec.rb +0 -63
  572. data/spec/extensions/prepared_statements_associations_spec.rb +0 -159
  573. data/spec/extensions/prepared_statements_safe_spec.rb +0 -61
  574. data/spec/extensions/prepared_statements_spec.rb +0 -103
  575. data/spec/extensions/prepared_statements_with_pk_spec.rb +0 -31
  576. data/spec/extensions/pretty_table_spec.rb +0 -92
  577. data/spec/extensions/query_literals_spec.rb +0 -183
  578. data/spec/extensions/query_spec.rb +0 -102
  579. data/spec/extensions/rcte_tree_spec.rb +0 -392
  580. data/spec/extensions/round_timestamps_spec.rb +0 -43
  581. data/spec/extensions/schema_caching_spec.rb +0 -41
  582. data/spec/extensions/schema_dumper_spec.rb +0 -789
  583. data/spec/extensions/schema_spec.rb +0 -117
  584. data/spec/extensions/scissors_spec.rb +0 -26
  585. data/spec/extensions/select_remove_spec.rb +0 -38
  586. data/spec/extensions/sequel_3_dataset_methods_spec.rb +0 -101
  587. data/spec/extensions/serialization_modification_detection_spec.rb +0 -98
  588. data/spec/extensions/serialization_spec.rb +0 -362
  589. data/spec/extensions/server_block_spec.rb +0 -90
  590. data/spec/extensions/set_overrides_spec.rb +0 -61
  591. data/spec/extensions/sharding_spec.rb +0 -198
  592. data/spec/extensions/shared_caching_spec.rb +0 -175
  593. data/spec/extensions/single_table_inheritance_spec.rb +0 -297
  594. data/spec/extensions/singular_table_names_spec.rb +0 -22
  595. data/spec/extensions/skip_create_refresh_spec.rb +0 -17
  596. data/spec/extensions/spec_helper.rb +0 -71
  597. data/spec/extensions/split_array_nil_spec.rb +0 -24
  598. data/spec/extensions/split_values_spec.rb +0 -22
  599. data/spec/extensions/sql_expr_spec.rb +0 -60
  600. data/spec/extensions/static_cache_spec.rb +0 -361
  601. data/spec/extensions/string_date_time_spec.rb +0 -95
  602. data/spec/extensions/string_stripper_spec.rb +0 -68
  603. data/spec/extensions/subclasses_spec.rb +0 -66
  604. data/spec/extensions/table_select_spec.rb +0 -71
  605. data/spec/extensions/tactical_eager_loading_spec.rb +0 -82
  606. data/spec/extensions/thread_local_timezones_spec.rb +0 -67
  607. data/spec/extensions/timestamps_spec.rb +0 -175
  608. data/spec/extensions/to_dot_spec.rb +0 -154
  609. data/spec/extensions/touch_spec.rb +0 -203
  610. data/spec/extensions/tree_spec.rb +0 -274
  611. data/spec/extensions/typecast_on_load_spec.rb +0 -80
  612. data/spec/extensions/unlimited_update_spec.rb +0 -20
  613. data/spec/extensions/update_or_create_spec.rb +0 -87
  614. data/spec/extensions/update_primary_key_spec.rb +0 -100
  615. data/spec/extensions/update_refresh_spec.rb +0 -53
  616. data/spec/extensions/validate_associated_spec.rb +0 -52
  617. data/spec/extensions/validation_class_methods_spec.rb +0 -1027
  618. data/spec/extensions/validation_helpers_spec.rb +0 -541
  619. data/spec/extensions/xml_serializer_spec.rb +0 -207
  620. data/spec/files/bad_down_migration/001_create_alt_basic.rb +0 -4
  621. data/spec/files/bad_down_migration/002_create_alt_advanced.rb +0 -4
  622. data/spec/files/bad_timestamped_migrations/1273253849_create_sessions.rb +0 -9
  623. data/spec/files/bad_timestamped_migrations/1273253851_create_nodes.rb +0 -9
  624. data/spec/files/bad_timestamped_migrations/1273253853_3_create_users.rb +0 -3
  625. data/spec/files/bad_up_migration/001_create_alt_basic.rb +0 -4
  626. data/spec/files/bad_up_migration/002_create_alt_advanced.rb +0 -3
  627. data/spec/files/convert_to_timestamp_migrations/001_create_sessions.rb +0 -9
  628. data/spec/files/convert_to_timestamp_migrations/002_create_nodes.rb +0 -9
  629. data/spec/files/convert_to_timestamp_migrations/003_3_create_users.rb +0 -4
  630. data/spec/files/convert_to_timestamp_migrations/1273253850_create_artists.rb +0 -9
  631. data/spec/files/convert_to_timestamp_migrations/1273253852_create_albums.rb +0 -9
  632. data/spec/files/duplicate_integer_migrations/001_create_alt_advanced.rb +0 -4
  633. data/spec/files/duplicate_integer_migrations/001_create_alt_basic.rb +0 -4
  634. data/spec/files/duplicate_timestamped_migrations/1273253849_create_sessions.rb +0 -9
  635. data/spec/files/duplicate_timestamped_migrations/1273253853_create_nodes.rb +0 -9
  636. data/spec/files/duplicate_timestamped_migrations/1273253853_create_users.rb +0 -4
  637. data/spec/files/integer_migrations/001_create_sessions.rb +0 -9
  638. data/spec/files/integer_migrations/002_create_nodes.rb +0 -9
  639. data/spec/files/integer_migrations/003_3_create_users.rb +0 -4
  640. data/spec/files/interleaved_timestamped_migrations/1273253849_create_sessions.rb +0 -9
  641. data/spec/files/interleaved_timestamped_migrations/1273253850_create_artists.rb +0 -9
  642. data/spec/files/interleaved_timestamped_migrations/1273253851_create_nodes.rb +0 -9
  643. data/spec/files/interleaved_timestamped_migrations/1273253852_create_albums.rb +0 -9
  644. data/spec/files/interleaved_timestamped_migrations/1273253853_3_create_users.rb +0 -4
  645. data/spec/files/missing_integer_migrations/001_create_alt_basic.rb +0 -4
  646. data/spec/files/missing_integer_migrations/003_create_alt_advanced.rb +0 -4
  647. data/spec/files/missing_timestamped_migrations/1273253849_create_sessions.rb +0 -9
  648. data/spec/files/missing_timestamped_migrations/1273253853_3_create_users.rb +0 -4
  649. data/spec/files/reversible_migrations/001_reversible.rb +0 -5
  650. data/spec/files/reversible_migrations/002_reversible.rb +0 -5
  651. data/spec/files/reversible_migrations/003_reversible.rb +0 -5
  652. data/spec/files/reversible_migrations/004_reversible.rb +0 -5
  653. data/spec/files/reversible_migrations/005_reversible.rb +0 -10
  654. data/spec/files/timestamped_migrations/1273253849_create_sessions.rb +0 -9
  655. data/spec/files/timestamped_migrations/1273253851_create_nodes.rb +0 -9
  656. data/spec/files/timestamped_migrations/1273253853_3_create_users.rb +0 -4
  657. data/spec/files/transaction_specified_migrations/001_create_alt_basic.rb +0 -4
  658. data/spec/files/transaction_specified_migrations/002_create_basic.rb +0 -4
  659. data/spec/files/transaction_unspecified_migrations/001_create_alt_basic.rb +0 -3
  660. data/spec/files/transaction_unspecified_migrations/002_create_basic.rb +0 -3
  661. data/spec/files/uppercase_timestamped_migrations/1273253849_CREATE_SESSIONS.RB +0 -9
  662. data/spec/files/uppercase_timestamped_migrations/1273253851_CREATE_NODES.RB +0 -9
  663. data/spec/files/uppercase_timestamped_migrations/1273253853_3_CREATE_USERS.RB +0 -4
  664. data/spec/guards_helper.rb +0 -55
  665. data/spec/integration/associations_test.rb +0 -2454
  666. data/spec/integration/database_test.rb +0 -113
  667. data/spec/integration/dataset_test.rb +0 -1808
  668. data/spec/integration/eager_loader_test.rb +0 -687
  669. data/spec/integration/migrator_test.rb +0 -240
  670. data/spec/integration/model_test.rb +0 -226
  671. data/spec/integration/plugin_test.rb +0 -2240
  672. data/spec/integration/prepared_statement_test.rb +0 -467
  673. data/spec/integration/schema_test.rb +0 -817
  674. data/spec/integration/spec_helper.rb +0 -48
  675. data/spec/integration/timezone_test.rb +0 -86
  676. data/spec/integration/transaction_test.rb +0 -374
  677. data/spec/integration/type_test.rb +0 -133
  678. data/spec/model/association_reflection_spec.rb +0 -525
  679. data/spec/model/associations_spec.rb +0 -4426
  680. data/spec/model/base_spec.rb +0 -759
  681. data/spec/model/class_dataset_methods_spec.rb +0 -146
  682. data/spec/model/dataset_methods_spec.rb +0 -149
  683. data/spec/model/eager_loading_spec.rb +0 -2137
  684. data/spec/model/hooks_spec.rb +0 -604
  685. data/spec/model/inflector_spec.rb +0 -26
  686. data/spec/model/model_spec.rb +0 -982
  687. data/spec/model/plugins_spec.rb +0 -299
  688. data/spec/model/record_spec.rb +0 -2147
  689. data/spec/model/spec_helper.rb +0 -46
  690. data/spec/model/validations_spec.rb +0 -193
  691. data/spec/sequel_coverage.rb +0 -15
  692. data/spec/spec_config.rb +0 -10
@@ -1,117 +0,0 @@
1
- require File.join(File.dirname(File.expand_path(__FILE__)), "spec_helper")
2
-
3
- describe Sequel::Model, "set_schema" do
4
- before do
5
- @model = Class.new(Sequel::Model(:items))
6
- @model.plugin :schema
7
- end
8
-
9
- it "sets schema with implicit table name" do
10
- @model.set_schema do
11
- primary_key :ssn, :type=>:string
12
- end
13
- @model.primary_key.must_equal :ssn
14
- @model.table_name.must_equal :items
15
- end
16
-
17
- it "sets schema with explicit table name" do
18
- @model.set_schema :foo do
19
- primary_key :id
20
- end
21
- @model.primary_key.must_equal :id
22
- @model.table_name.must_equal :foo
23
- end
24
- end
25
-
26
- describe Sequel::Model, "create_table and schema" do
27
- before do
28
- @model = Class.new(Sequel::Model)
29
- @model.class_eval do
30
- plugin :schema
31
- set_schema(:items) do
32
- text :name
33
- float :price, :null => false
34
- end
35
- end
36
- DB.reset
37
- end
38
-
39
- it "should get the create table SQL list from the db and execute it line by line" do
40
- @model.create_table
41
- DB.sqls.must_equal ['CREATE TABLE items (name text, price float NOT NULL)']
42
- end
43
-
44
- it "should allow setting schema and creating the table in one call" do
45
- @model.create_table { text :name }
46
- DB.sqls.must_equal ['CREATE TABLE items (name text)']
47
- end
48
-
49
- it "should reload the schema from the database" do
50
- schem = {:name=>{:type=>:string}, :price=>{:type=>:float}}
51
- @model.db.stub(:schema, schem.to_a.sort_by{|x| x[0].to_s}) do
52
- @model.create_table
53
- @model.db_schema.must_equal schem
54
- end
55
- @model.instance_variable_get(:@columns).must_equal [:name, :price]
56
- end
57
-
58
- it "should return the schema generator via schema" do
59
- @model.schema.must_be_kind_of(Sequel::Schema::Generator)
60
- end
61
-
62
- it "should use the superclasses schema if it exists" do
63
- @submodel = Class.new(@model)
64
- @submodel.schema.must_be_kind_of(Sequel::Schema::Generator)
65
- end
66
-
67
- it "should return nil if no schema is present" do
68
- @model = Class.new(Sequel::Model)
69
- @model.plugin :schema
70
- @model.schema.must_equal nil
71
- @submodel = Class.new(@model)
72
- @submodel.schema.must_equal nil
73
- end
74
- end
75
-
76
- describe Sequel::Model, "schema methods" do
77
- before do
78
- @model = Class.new(Sequel::Model(:items))
79
- @model.plugin :schema
80
- DB.reset
81
- end
82
-
83
- it "table_exists? should get the table name and question the model's db if table_exists?" do
84
- DB.stub(:table_exists?, false) do
85
- @model.table_exists?.must_equal false
86
- end
87
- end
88
-
89
- it "drop_table should drop the related table" do
90
- @model.drop_table
91
- DB.sqls.must_equal ['DROP TABLE items']
92
- end
93
-
94
- it "drop_table? should drop the table if it exists" do
95
- @model.drop_table?
96
- DB.sqls.must_equal ["SELECT NULL AS nil FROM items LIMIT 1", 'DROP TABLE items']
97
- end
98
-
99
- it "create_table! should drop table if it exists and then create the table" do
100
- @model.create_table!
101
- DB.sqls.must_equal ["SELECT NULL AS nil FROM items LIMIT 1", 'DROP TABLE items', 'CREATE TABLE items ()']
102
- end
103
-
104
- it "create_table? should not create the table if it already exists" do
105
- DB.stub(:table_exists?, true) do
106
- @model.create_table?
107
- end
108
- DB.sqls.must_equal []
109
- end
110
-
111
- it "create_table? should create the table if it doesn't exist" do
112
- DB.stub(:table_exists?, false) do
113
- @model.create_table?
114
- end
115
- DB.sqls.must_equal ['CREATE TABLE items ()']
116
- end
117
- end
@@ -1,26 +0,0 @@
1
- require File.join(File.dirname(File.expand_path(__FILE__)), "spec_helper")
2
-
3
- describe "scissors plugin" do
4
- before do
5
- @m = Class.new(Sequel::Model(:items))
6
- @m.use_transactions = true
7
- @m.plugin :scissors
8
- @m.db.sqls
9
- end
10
-
11
- it "Model.delete should delete from the dataset" do
12
- @m.delete
13
- @m.db.sqls.must_equal ['DELETE FROM items']
14
- end
15
-
16
- it "Model.update should update the dataset" do
17
- @m.update(:a=>1)
18
- @m.db.sqls.must_equal ['UPDATE items SET a = 1']
19
- end
20
-
21
- it "Model.destory each instance in the dataset" do
22
- @m.dataset._fetch = {:id=>1}
23
- @m.destroy
24
- @m.db.sqls.must_equal ['BEGIN', 'SELECT * FROM items', 'DELETE FROM items WHERE id = 1', 'COMMIT']
25
- end
26
- end
@@ -1,38 +0,0 @@
1
- require File.join(File.dirname(File.expand_path(__FILE__)), "spec_helper")
2
-
3
- describe "Dataset#select_remove" do
4
- before do
5
- @d = Sequel.mock.from(:test).extension(:select_remove)
6
- @d.columns :a, :b, :c
7
- end
8
-
9
- it "should remove columns from the selected columns" do
10
- @d.sql.must_equal 'SELECT * FROM test'
11
- @d.select_remove(:a).sql.must_equal 'SELECT b, c FROM test'
12
- @d.select_remove(:b).sql.must_equal 'SELECT a, c FROM test'
13
- @d.select_remove(:c).sql.must_equal 'SELECT a, b FROM test'
14
- end
15
-
16
- it "should work correctly if there are already columns selected" do
17
- d = @d.select(:a, :b, :c)
18
- d.columns :a, :b, :c
19
- d.select_remove(:c).sql.must_equal 'SELECT a, b FROM test'
20
- end
21
-
22
- it "should have no effect if the columns given are not currently selected" do
23
- @d.select_remove(:d).sql.must_equal 'SELECT a, b, c FROM test'
24
- end
25
-
26
- it "should handle expressions where Sequel can't determine the alias by itself" do
27
- d = @d.select(:a, Sequel.function(:b), Sequel.as(:c, :b))
28
- d.columns :a, :"b()", :b
29
- d.select_remove(:"b()").sql.must_equal 'SELECT a, c AS b FROM test'
30
- end
31
-
32
- it "should remove expressions if given exact expressions" do
33
- d = @d.select(:a, Sequel.function(:b), Sequel.as(:c, :b))
34
- d.columns :a, :"b()", :b
35
- d.select_remove(Sequel.function(:b)).sql.must_equal 'SELECT a, c AS b FROM test'
36
- d.select_remove(Sequel.as(:c, :b)).sql.must_equal 'SELECT a, b() FROM test'
37
- end
38
- end
@@ -1,101 +0,0 @@
1
- require File.join(File.dirname(File.expand_path(__FILE__)), "spec_helper")
2
-
3
- describe "Dataset#to_csv" do
4
- before do
5
- @ds = Sequel.mock(:fetch=>[{:a=>1, :b=>2, :c=>3}, {:a=>4, :b=>5, :c=>6}, {:a=>7, :b=>8, :c=>9}])[:items].columns(:a, :b, :c).extension(:sequel_3_dataset_methods)
6
- end
7
-
8
- it "should format a CSV representation of the records" do
9
- @ds.to_csv.must_equal "a, b, c\r\n1, 2, 3\r\n4, 5, 6\r\n7, 8, 9\r\n"
10
- end
11
-
12
- it "should exclude column titles if so specified" do
13
- @ds.to_csv(false).must_equal "1, 2, 3\r\n4, 5, 6\r\n7, 8, 9\r\n"
14
- end
15
- end
16
-
17
- describe "Dataset#[]=" do
18
- it "should perform an update on the specified filter" do
19
- db = Sequel.mock
20
- ds = db[:items].extension(:sequel_3_dataset_methods)
21
- ds[:a => 1] = {:x => 3}
22
- db.sqls.must_equal ['UPDATE items SET x = 3 WHERE (a = 1)']
23
- end
24
- end
25
-
26
- describe "Dataset#insert_multiple" do
27
- before do
28
- @db = Sequel.mock(:autoid=>2)
29
- @ds = @db[:items].extension(:sequel_3_dataset_methods)
30
- end
31
-
32
- it "should insert all items in the supplied array" do
33
- @ds.insert_multiple(['aa', 5, 3, {:a => 2}])
34
- @db.sqls.must_equal ["INSERT INTO items VALUES ('aa')",
35
- "INSERT INTO items VALUES (5)",
36
- "INSERT INTO items VALUES (3)",
37
- "INSERT INTO items (a) VALUES (2)"]
38
- end
39
-
40
- it "should pass array items through the supplied block if given" do
41
- @ds.insert_multiple(["inevitable", "hello", "the ticking clock"]){|i| i.gsub('l', 'r')}
42
- @db.sqls.must_equal ["INSERT INTO items VALUES ('inevitabre')",
43
- "INSERT INTO items VALUES ('herro')",
44
- "INSERT INTO items VALUES ('the ticking crock')"]
45
- end
46
-
47
- it "should return array of inserted ids" do
48
- @ds.insert_multiple(['aa', 5, 3, {:a => 2}]).must_equal [2, 3, 4, 5]
49
- end
50
-
51
- it "should work exactly like in metioned in the example" do
52
- @ds.insert_multiple([{:x=>1}, {:x=>2}]){|row| row[:y] = row[:x] * 2 ; row }
53
- sqls = @db.sqls
54
- ["INSERT INTO items (x, y) VALUES (1, 2)", "INSERT INTO items (y, x) VALUES (2, 1)"].must_include(sqls[0])
55
- ["INSERT INTO items (x, y) VALUES (2, 4)", "INSERT INTO items (y, x) VALUES (4, 2)"].must_include(sqls[1])
56
- end
57
- end
58
-
59
- describe "Dataset#db=" do
60
- it "should change the dataset's database" do
61
- db = Sequel.mock
62
- ds = db[:items].extension(:sequel_3_dataset_methods)
63
- db2 = Sequel.mock
64
- ds.db = db2
65
- ds.db.must_equal db2
66
- ds.db.wont_equal db
67
- end
68
- end
69
-
70
- describe "Dataset#opts=" do
71
- it "should change the dataset's opts" do
72
- db = Sequel.mock
73
- ds = db[:items].extension(:sequel_3_dataset_methods)
74
- ds.sql.must_equal 'SELECT * FROM items'
75
- ds.opts = {}
76
- ds.sql.must_equal 'SELECT *'
77
- ds.opts.must_equal({})
78
- end
79
- end
80
-
81
- describe "Dataset#set" do
82
- it "should act as alias to #update" do
83
- db = Sequel.mock
84
- ds = db[:items].extension(:sequel_3_dataset_methods)
85
- ds.set({:x => 3})
86
- db.sqls.must_equal ['UPDATE items SET x = 3']
87
- end
88
- end
89
-
90
- describe "Sequel::Dataset#qualify_to_first_source" do
91
- it "should qualify to the first source" do
92
- Sequel.mock.dataset.extension(:sequel_3_dataset_methods).from(:t).filter{a<b}.qualify_to_first_source.sql.must_equal 'SELECT t.* FROM t WHERE (t.a < t.b)'
93
- end
94
- end
95
-
96
- describe "Sequel::Dataset#qualify_to" do
97
- it "should qualify to the given table" do
98
- Sequel.mock.dataset.extension(:sequel_3_dataset_methods).from(:t).filter{a<b}.qualify_to(:e).sql.must_equal 'SELECT e.* FROM t WHERE (e.a < e.b)'
99
- end
100
- end
101
-
@@ -1,98 +0,0 @@
1
- require File.join(File.dirname(File.expand_path(__FILE__)), "spec_helper")
2
- require 'yaml'
3
-
4
- describe "serialization_modification_detection plugin" do
5
- before do
6
- @c = Class.new(Sequel::Model(:items))
7
- @c.class_eval do
8
- columns :id, :h
9
- plugin :serialization, :yaml, :h
10
- plugin :serialization_modification_detection
11
- end
12
- @o1 = @c.new(:h=>{})
13
- @o2 = @c.load(:id=>1, :h=>"--- {}\n\n")
14
- @o3 = @c.new
15
- @o4 = @c.load(:id=>1, :h=>nil)
16
- DB.reset
17
- end
18
-
19
- it "should not detect columns that haven't been changed" do
20
- @o1.changed_columns.must_equal []
21
- @o1.h.must_equal({})
22
- @o1.h[1] = 2
23
- @o1.h.clear
24
- @o1.changed_columns.must_equal []
25
-
26
- @o2.changed_columns.must_equal []
27
- @o2.h.must_equal({})
28
- @o2.h[1] = 2
29
- @o2.h.clear
30
- @o2.changed_columns.must_equal []
31
- end
32
-
33
- it "should detect columns that have been changed" do
34
- @o1.changed_columns.must_equal []
35
- @o1.h.must_equal({})
36
- @o1.h[1] = 2
37
- @o1.changed_columns.must_equal [:h]
38
-
39
- @o2.changed_columns.must_equal []
40
- @o2.h.must_equal({})
41
- @o2.h[1] = 2
42
- @o2.changed_columns.must_equal [:h]
43
-
44
- @o3.changed_columns.must_equal []
45
- @o3.h.must_equal nil
46
- @o3.h = {}
47
- @o3.changed_columns.must_equal [:h]
48
-
49
- @o4.changed_columns.must_equal []
50
- @o4.h.must_equal nil
51
- @o4.h = {}
52
- @o4.changed_columns.must_equal [:h]
53
- end
54
-
55
- it "should report correct changed_columns after saving" do
56
- @o1.h[1] = 2
57
- @o1.save
58
- @o1.changed_columns.must_equal []
59
-
60
- @o2.h[1] = 2
61
- @o2.save_changes
62
- @o2.changed_columns.must_equal []
63
-
64
- @o3.h = {1=>2}
65
- @o3.save
66
- @o3.changed_columns.must_equal []
67
-
68
- @o4.h = {1=>2}
69
- @o4.save
70
- @o4.changed_columns.must_equal []
71
- end
72
-
73
- it "should work with frozen objects" do
74
- @o1.changed_columns.must_equal []
75
- @o1.h.must_equal({})
76
- @o1.freeze
77
- @o1.h[1] = 2
78
- @o1.changed_columns.must_equal [:h]
79
- end
80
-
81
- it "should work with duplicating objects" do
82
- @o2.changed_columns.must_equal []
83
- o = @o2.dup
84
- @o2.h.must_equal({})
85
- @o2.h[1] = 2
86
- @o2.changed_columns.must_equal [:h]
87
- o.changed_columns.must_equal []
88
- end
89
-
90
- it "should work with duplicating objects after modifying them" do
91
- @o2.changed_columns.must_equal []
92
- @o2.h.must_equal({})
93
- @o2.h[1] = 2
94
- @o2.changed_columns.must_equal [:h]
95
- o = @o2.dup
96
- o.changed_columns.must_equal [:h]
97
- end
98
- end
@@ -1,362 +0,0 @@
1
- require File.join(File.dirname(File.expand_path(__FILE__)), "spec_helper")
2
-
3
- require 'yaml'
4
- require 'json'
5
-
6
- describe "Serialization plugin" do
7
- before do
8
- @c = Class.new(Sequel::Model(:items)) do
9
- no_primary_key
10
- columns :id, :abc, :def, :ghi
11
- end
12
- DB.reset
13
- end
14
-
15
- it "should allow setting additional serializable attributes via plugin :serialization call" do
16
- @c.plugin :serialization, :yaml, :abc
17
- @c.create(:abc => 1, :def=> 2)
18
- DB.sqls.last.must_match(/INSERT INTO items \((abc, def|def, abc)\) VALUES \(('--- 1\n(\.\.\.\n)?', 2|2, '--- 1\n(\.\.\.\n)?')\)/)
19
-
20
- @c.plugin :serialization, :marshal, :def
21
- @c.create(:abc => 1, :def=> 1)
22
- DB.sqls.last.must_match(/INSERT INTO items \((abc, def|def, abc)\) VALUES \(('--- 1\n(\.\.\.\n)?', 'BAhpBg==\n'|'BAhpBg==\n', '--- 1\n(\.\.\.\n)?')\)/)
23
-
24
- @c.plugin :serialization, :json, :ghi
25
- @c.create(:ghi => [123])
26
- DB.sqls.last.must_match(/INSERT INTO items \((ghi)\) VALUES \('\[123\]'\)/)
27
- end
28
-
29
- it "should handle validations of underlying column" do
30
- @c.plugin :serialization, :yaml, :abc
31
- o = @c.new
32
- def o.validate
33
- errors.add(:abc, "not present") unless self[:abc]
34
- end
35
- o.valid?.must_equal false
36
- o.abc = {}
37
- o.valid?.must_equal true
38
- end
39
-
40
- it "should set column values even when not validating" do
41
- @c.set_primary_key :id
42
- @c.plugin :serialization, :yaml, :abc
43
- @c.load({:id=>1}).set(:abc=>{}).save(:validate=>false)
44
- DB.sqls.last.gsub("\n", '').must_equal "UPDATE items SET abc = '--- {}' WHERE (id = 1)"
45
- end
46
-
47
- it "should allow serializing attributes to yaml" do
48
- @c.plugin :serialization, :yaml, :abc
49
- @c.create(:abc => 1)
50
- @c.create(:abc => "hello")
51
-
52
- DB.sqls.map{|s| s.sub("...\n", '')}.must_equal ["INSERT INTO items (abc) VALUES ('--- 1\n')", "INSERT INTO items (abc) VALUES ('--- hello\n')"]
53
- end
54
-
55
- it "serialized_columns should be the columns serialized" do
56
- @c.plugin :serialization, :yaml, :abc
57
- @c.serialized_columns.must_equal [:abc]
58
- end
59
-
60
- it "should allow serializing attributes to marshal" do
61
- @c.plugin :serialization, :marshal, :abc
62
- @c.create(:abc => 1)
63
- @c.create(:abc => "hello")
64
- x = [Marshal.dump("hello")].pack('m')
65
-
66
- DB.sqls.must_equal [ \
67
- "INSERT INTO items (abc) VALUES ('BAhpBg==\n')", \
68
- "INSERT INTO items (abc) VALUES ('#{x}')", \
69
- ]
70
- end
71
-
72
- it "should allow serializing attributes to json" do
73
- @c.plugin :serialization, :json, :ghi
74
- @c.create(:ghi => [1])
75
- @c.create(:ghi => ["hello"])
76
-
77
- x = ["hello"].to_json
78
- DB.sqls.must_equal [ \
79
- "INSERT INTO items (ghi) VALUES ('[1]')", \
80
- "INSERT INTO items (ghi) VALUES ('#{x}')", \
81
- ]
82
- end
83
-
84
- it "should allow serializing attributes using arbitrary callable" do
85
- @c.plugin :serialization, [proc{|s| s.reverse}, proc{}], :abc
86
- @c.create(:abc => "hello")
87
- DB.sqls.must_equal ["INSERT INTO items (abc) VALUES ('olleh')"]
88
- end
89
-
90
- it "should raise an error if specificing serializer as an unregistered symbol" do
91
- proc{@c.plugin :serialization, :foo, :abc}.must_raise(Sequel::Error)
92
- end
93
-
94
- it "should translate values to and from yaml serialization format using accessor methods" do
95
- @c.set_primary_key :id
96
- @c.plugin :serialization, :yaml, :abc, :def
97
- @c.dataset._fetch = {:id => 1, :abc => "--- 1\n", :def => "--- hello\n"}
98
-
99
- o = @c.first
100
- o.id.must_equal 1
101
- o.abc.must_equal 1
102
- o.abc.must_equal 1
103
- o.def.must_equal "hello"
104
- o.def.must_equal "hello"
105
-
106
- o.update(:abc => 23)
107
- @c.create(:abc => [1, 2, 3])
108
- DB.sqls.must_equal ["SELECT * FROM items LIMIT 1",
109
- "UPDATE items SET abc = '#{23.to_yaml}' WHERE (id = 1)",
110
- "INSERT INTO items (abc) VALUES ('#{[1, 2, 3].to_yaml}')",
111
- "SELECT * FROM items WHERE (id = 10) LIMIT 1"]
112
- end
113
-
114
- it "should translate values to and from marshal serialization format using accessor methods" do
115
- @c.set_primary_key :id
116
- @c.plugin :serialization, :marshal, :abc, :def
117
- @c.dataset._fetch = [:id => 1, :abc =>[Marshal.dump(1)].pack('m'), :def =>[Marshal.dump('hello')].pack('m')]
118
-
119
- o = @c.first
120
- o.id.must_equal 1
121
- o.abc.must_equal 1
122
- o.abc.must_equal 1
123
- o.def.must_equal "hello"
124
- o.def.must_equal "hello"
125
-
126
- o.update(:abc => 23)
127
- @c.create(:abc => [1, 2, 3])
128
- DB.sqls.must_equal ["SELECT * FROM items LIMIT 1",
129
- "UPDATE items SET abc = '#{[Marshal.dump(23)].pack('m')}' WHERE (id = 1)",
130
- "INSERT INTO items (abc) VALUES ('#{[Marshal.dump([1, 2, 3])].pack('m')}')",
131
- "SELECT * FROM items WHERE (id = 10) LIMIT 1"]
132
- end
133
-
134
- it "should handle old non-base-64 encoded marshal serialization format" do
135
- @c.set_primary_key :id
136
- @c.plugin :serialization, :marshal, :abc, :def
137
- @c.dataset._fetch = [:id => 1, :abc =>Marshal.dump(1), :def =>Marshal.dump('hello')]
138
-
139
- o = @c.first
140
- o.abc.must_equal 1
141
- o.def.must_equal "hello"
142
- end
143
-
144
- it "should raise exception for bad marshal data" do
145
- @c.set_primary_key :id
146
- @c.plugin :serialization, :marshal, :abc, :def
147
- @c.dataset._fetch = [:id => 1, :abc =>'foo', :def =>'bar']
148
-
149
- o = @c.first
150
- proc{o.abc}.must_raise TypeError, ArgumentError
151
- proc{o.def}.must_raise TypeError, ArgumentError
152
- end
153
-
154
- it "should translate values to and from json serialization format using accessor methods" do
155
- @c.set_primary_key :id
156
- @c.plugin :serialization, :json, :abc, :def
157
- @c.dataset._fetch = {:id => 1, :abc => [1].to_json, :def => ["hello"].to_json}
158
-
159
- o = @c.first
160
- o.id.must_equal 1
161
- o.abc.must_equal [1]
162
- o.abc.must_equal [1]
163
- o.def.must_equal ["hello"]
164
- o.def.must_equal ["hello"]
165
-
166
- o.update(:abc => [23])
167
- @c.create(:abc => [1,2,3])
168
-
169
- DB.sqls.must_equal ["SELECT * FROM items LIMIT 1",
170
- "UPDATE items SET abc = '#{[23].to_json}' WHERE (id = 1)",
171
- "INSERT INTO items (abc) VALUES ('#{[1,2,3].to_json}')",
172
- "SELECT * FROM items WHERE (id = 10) LIMIT 1"]
173
- end
174
-
175
- it "should translate values to and from arbitrary callables using accessor methods" do
176
- @c.set_primary_key :id
177
- @c.plugin :serialization, [proc{|s| s.reverse}, proc{|s| s.reverse}], :abc, :def
178
- @c.dataset._fetch = {:id => 1, :abc => 'cba', :def => 'olleh'}
179
-
180
- o = @c.first
181
- o.id.must_equal 1
182
- o.abc.must_equal 'abc'
183
- o.abc.must_equal 'abc'
184
- o.def.must_equal "hello"
185
- o.def.must_equal "hello"
186
-
187
- o.update(:abc => 'foo')
188
- @c.create(:abc => 'bar')
189
-
190
- DB.sqls.must_equal ["SELECT * FROM items LIMIT 1",
191
- "UPDATE items SET abc = 'oof' WHERE (id = 1)",
192
- "INSERT INTO items (abc) VALUES ('rab')",
193
- "SELECT * FROM items WHERE (id = 10) LIMIT 1"]
194
- end
195
-
196
- it "should handle registration of custom serializer/deserializer pairs" do
197
- @c.set_primary_key :id
198
- require 'sequel/plugins/serialization'
199
- Sequel::Plugins::Serialization.register_format(:reverse, proc{|s| s.reverse}, proc{|s| s.reverse})
200
- @c.plugin :serialization, :reverse, :abc, :def
201
- @c.dataset._fetch = {:id => 1, :abc => 'cba', :def => 'olleh'}
202
-
203
- o = @c.first
204
- o.id.must_equal 1
205
- o.abc.must_equal 'abc'
206
- o.abc.must_equal 'abc'
207
- o.def.must_equal "hello"
208
- o.def.must_equal "hello"
209
-
210
- o.update(:abc => 'foo')
211
- @c.create(:abc => 'bar')
212
-
213
- DB.sqls.must_equal ["SELECT * FROM items LIMIT 1",
214
- "UPDATE items SET abc = 'oof' WHERE (id = 1)",
215
- "INSERT INTO items (abc) VALUES ('rab')",
216
- "SELECT * FROM items WHERE (id = 10) LIMIT 1"]
217
- end
218
-
219
- it "should copy serialization formats and columns to subclasses" do
220
- @c.set_primary_key :id
221
- @c.plugin :serialization, :yaml, :abc, :def
222
- @c.dataset._fetch = {:id => 1, :abc => "--- 1\n", :def => "--- hello\n"}
223
-
224
- o = Class.new(@c).first
225
- o.id.must_equal 1
226
- o.abc.must_equal 1
227
- o.abc.must_equal 1
228
- o.def.must_equal "hello"
229
- o.def.must_equal "hello"
230
-
231
- o.update(:abc => 23)
232
- Class.new(@c).create(:abc => [1, 2, 3])
233
- DB.sqls.must_equal ["SELECT * FROM items LIMIT 1",
234
- "UPDATE items SET abc = '#{23.to_yaml}' WHERE (id = 1)",
235
- "INSERT INTO items (abc) VALUES ('#{[1, 2, 3].to_yaml}')",
236
- "SELECT * FROM items WHERE (id = 10) LIMIT 1"]
237
- end
238
-
239
- it "should clear the deserialized columns when refreshing" do
240
- @c.set_primary_key :id
241
- @c.plugin :serialization, :yaml, :abc, :def
242
- o = @c.load(:id => 1, :abc => "--- 1\n", :def => "--- hello\n")
243
- o.abc = 23
244
- o.deserialized_values.length.must_equal 1
245
- o.abc.must_equal 23
246
- o.refresh
247
- o.deserialized_values.length.must_equal 0
248
- end
249
-
250
- it "should not clear the deserialized columns when refreshing after saving a new object" do
251
- @c.set_primary_key :id
252
- @c.plugin :serialization, :yaml, :abc, :def
253
- o = @c.new(:abc => "--- 1\n", :def => "--- hello\n")
254
- o.deserialized_values.length.must_equal 2
255
- o.save
256
- o.deserialized_values.length.must_equal 2
257
- end
258
-
259
- it "should not clear the deserialized columns when refreshing after saving a new object with insert_select" do
260
- @c.set_primary_key :id
261
- @c.plugin :serialization, :yaml, :abc, :def
262
- def (@c.instance_dataset).supports_insert_select?() true end
263
- def (@c.instance_dataset).insert_select(*) {:id=>1} end
264
- o = @c.new(:abc => "--- 1\n", :def => "--- hello\n")
265
- o.deserialized_values.length.must_equal 2
266
- o.save
267
- o.deserialized_values.length.must_equal 2
268
- end
269
-
270
- it "should raise an error if calling internal serialization methods with bad columns" do
271
- @c.set_primary_key :id
272
- @c.plugin :serialization
273
- o = @c.load(:id => 1, :abc => "--- 1\n", :def => "--- hello\n")
274
- lambda{o.send(:serialize_value, :abc, 1)}.must_raise(Sequel::Error)
275
- lambda{o.send(:deserialize_value, :abc, "--- hello\n")}.must_raise(Sequel::Error)
276
- end
277
-
278
- it "should add the accessors to a module included in the class, so they can be easily overridden" do
279
- @c.class_eval do
280
- def abc
281
- "#{super}-blah"
282
- end
283
- end
284
- @c.plugin :serialization, :yaml, :abc
285
- o = @c.load(:abc => "--- 1\n")
286
- o.abc.must_equal "1-blah"
287
- end
288
-
289
- it "should call super to get the deserialized value from a previous accessor" do
290
- m = Module.new do
291
- def abc
292
- "--- #{@values[:abc]*3}\n"
293
- end
294
- end
295
- @c.send(:include, m)
296
- @c.plugin :serialization, :yaml, :abc
297
- o = @c.load(:abc => 3)
298
- o.abc.must_equal 9
299
- end
300
-
301
- it "should work correctly with frozen instances" do
302
- @c.set_primary_key :id
303
- @c.plugin :serialization, :yaml, :abc, :def
304
- @c.dataset._fetch = {:id => 1, :abc => "--- 1\n", :def => "--- hello\n"}
305
-
306
- o = @c.first
307
- o.freeze
308
- o.abc.must_equal 1
309
- o.abc.must_equal 1
310
- o.def.must_equal "hello"
311
- o.def.must_equal "hello"
312
- proc{o.abc = 2}.must_raise
313
- proc{o.def = 'h'}.must_raise
314
- end
315
-
316
- it "should have dup duplicate internal structures" do
317
- @c.plugin :serialization, :yaml, :abc, :def
318
- o = @c.new
319
- o.dup.deserialized_values.must_equal o.deserialized_values
320
- o.dup.deserialized_values.wont_be_same_as(o.deserialized_values)
321
- end
322
-
323
- it "should have changed_columns include serialized columns if those columns have changed" do
324
- @c.plugin :serialization, :yaml, :abc, :def
325
- @c.dataset._fetch = {:id => 1, :abc => "--- 1\n", :def => "--- hello\n"}
326
- o = @c.first
327
- o.changed_columns.must_equal []
328
- o.abc = 1
329
- o.changed_columns.must_equal []
330
- o.abc = 1
331
- o.changed_columns.must_equal []
332
- o.abc = 2
333
- o.changed_columns.must_equal [:abc]
334
- o.def = 'hello'
335
- o.changed_columns.must_equal [:abc]
336
- o.def = 'hello'
337
- o.changed_columns.must_equal [:abc]
338
- o.def = 'hello2'
339
- o.changed_columns.must_equal [:abc, :def]
340
- end
341
-
342
- it "should update column_changes if the dirty plugin is used" do
343
- @c.plugin :serialization, :yaml, :abc, :def
344
- @c.plugin :dirty
345
- @c.dataset._fetch = {:id => 1, :abc => "--- 1\n", :def => "--- hello\n"}
346
- o = @c.first
347
- o.column_changes.must_equal({})
348
- o.abc = 1
349
- o.column_changes.must_equal({})
350
- o.abc = 1
351
- o.column_changes.must_equal({})
352
- o.abc = 2
353
- o.column_changes.must_equal(:abc=>[1, 2])
354
- o.def = 'hello'
355
- o.column_changes.must_equal(:abc=>[1, 2])
356
- o.def = 'hello'
357
- o.column_changes.must_equal(:abc=>[1, 2])
358
- o.def = 'hello2'
359
- o.column_changes.must_equal(:abc=>[1, 2], :def=>["hello", "hello2"])
360
- end
361
-
362
- end