sequel 4.36.0 → 5.61.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 (760) hide show
  1. checksums.yaml +5 -5
  2. data/CHANGELOG +548 -5749
  3. data/MIT-LICENSE +1 -1
  4. data/README.rdoc +265 -159
  5. data/bin/sequel +34 -12
  6. data/doc/advanced_associations.rdoc +228 -187
  7. data/doc/association_basics.rdoc +281 -291
  8. data/doc/bin_sequel.rdoc +5 -3
  9. data/doc/cheat_sheet.rdoc +86 -51
  10. data/doc/code_order.rdoc +25 -19
  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/fork_safety.rdoc +84 -0
  16. data/doc/mass_assignment.rdoc +74 -31
  17. data/doc/migration.rdoc +59 -51
  18. data/doc/model_dataset_method_design.rdoc +129 -0
  19. data/doc/model_hooks.rdoc +15 -25
  20. data/doc/model_plugins.rdoc +12 -12
  21. data/doc/mssql_stored_procedures.rdoc +3 -3
  22. data/doc/object_model.rdoc +58 -68
  23. data/doc/opening_databases.rdoc +85 -95
  24. data/doc/postgresql.rdoc +263 -38
  25. data/doc/prepared_statements.rdoc +29 -24
  26. data/doc/querying.rdoc +189 -167
  27. data/doc/reflection.rdoc +5 -6
  28. data/doc/release_notes/5.0.0.txt +159 -0
  29. data/doc/release_notes/5.1.0.txt +31 -0
  30. data/doc/release_notes/5.10.0.txt +84 -0
  31. data/doc/release_notes/5.11.0.txt +83 -0
  32. data/doc/release_notes/5.12.0.txt +141 -0
  33. data/doc/release_notes/5.13.0.txt +27 -0
  34. data/doc/release_notes/5.14.0.txt +63 -0
  35. data/doc/release_notes/5.15.0.txt +39 -0
  36. data/doc/release_notes/5.16.0.txt +110 -0
  37. data/doc/release_notes/5.17.0.txt +31 -0
  38. data/doc/release_notes/5.18.0.txt +69 -0
  39. data/doc/release_notes/5.19.0.txt +28 -0
  40. data/doc/release_notes/5.2.0.txt +33 -0
  41. data/doc/release_notes/5.20.0.txt +89 -0
  42. data/doc/release_notes/5.21.0.txt +87 -0
  43. data/doc/release_notes/5.22.0.txt +48 -0
  44. data/doc/release_notes/5.23.0.txt +56 -0
  45. data/doc/release_notes/5.24.0.txt +56 -0
  46. data/doc/release_notes/5.25.0.txt +32 -0
  47. data/doc/release_notes/5.26.0.txt +35 -0
  48. data/doc/release_notes/5.27.0.txt +21 -0
  49. data/doc/release_notes/5.28.0.txt +16 -0
  50. data/doc/release_notes/5.29.0.txt +22 -0
  51. data/doc/release_notes/5.3.0.txt +121 -0
  52. data/doc/release_notes/5.30.0.txt +20 -0
  53. data/doc/release_notes/5.31.0.txt +148 -0
  54. data/doc/release_notes/5.32.0.txt +46 -0
  55. data/doc/release_notes/5.33.0.txt +24 -0
  56. data/doc/release_notes/5.34.0.txt +40 -0
  57. data/doc/release_notes/5.35.0.txt +56 -0
  58. data/doc/release_notes/5.36.0.txt +60 -0
  59. data/doc/release_notes/5.37.0.txt +30 -0
  60. data/doc/release_notes/5.38.0.txt +28 -0
  61. data/doc/release_notes/5.39.0.txt +19 -0
  62. data/doc/release_notes/5.4.0.txt +80 -0
  63. data/doc/release_notes/5.40.0.txt +40 -0
  64. data/doc/release_notes/5.41.0.txt +25 -0
  65. data/doc/release_notes/5.42.0.txt +136 -0
  66. data/doc/release_notes/5.43.0.txt +98 -0
  67. data/doc/release_notes/5.44.0.txt +32 -0
  68. data/doc/release_notes/5.45.0.txt +34 -0
  69. data/doc/release_notes/5.46.0.txt +87 -0
  70. data/doc/release_notes/5.47.0.txt +59 -0
  71. data/doc/release_notes/5.48.0.txt +14 -0
  72. data/doc/release_notes/5.49.0.txt +59 -0
  73. data/doc/release_notes/5.5.0.txt +61 -0
  74. data/doc/release_notes/5.50.0.txt +78 -0
  75. data/doc/release_notes/5.51.0.txt +47 -0
  76. data/doc/release_notes/5.52.0.txt +87 -0
  77. data/doc/release_notes/5.53.0.txt +23 -0
  78. data/doc/release_notes/5.54.0.txt +27 -0
  79. data/doc/release_notes/5.55.0.txt +21 -0
  80. data/doc/release_notes/5.56.0.txt +51 -0
  81. data/doc/release_notes/5.57.0.txt +23 -0
  82. data/doc/release_notes/5.58.0.txt +31 -0
  83. data/doc/release_notes/5.59.0.txt +73 -0
  84. data/doc/release_notes/5.6.0.txt +31 -0
  85. data/doc/release_notes/5.60.0.txt +22 -0
  86. data/doc/release_notes/5.61.0.txt +43 -0
  87. data/doc/release_notes/5.7.0.txt +108 -0
  88. data/doc/release_notes/5.8.0.txt +170 -0
  89. data/doc/release_notes/5.9.0.txt +99 -0
  90. data/doc/schema_modification.rdoc +95 -75
  91. data/doc/security.rdoc +109 -80
  92. data/doc/sharding.rdoc +74 -47
  93. data/doc/sql.rdoc +147 -122
  94. data/doc/testing.rdoc +43 -20
  95. data/doc/thread_safety.rdoc +2 -4
  96. data/doc/transactions.rdoc +97 -18
  97. data/doc/validations.rdoc +52 -50
  98. data/doc/virtual_rows.rdoc +90 -109
  99. data/lib/sequel/adapters/ado/access.rb +15 -17
  100. data/lib/sequel/adapters/ado/mssql.rb +6 -15
  101. data/lib/sequel/adapters/ado.rb +150 -20
  102. data/lib/sequel/adapters/amalgalite.rb +11 -23
  103. data/lib/sequel/adapters/ibmdb.rb +47 -55
  104. data/lib/sequel/adapters/jdbc/db2.rb +29 -39
  105. data/lib/sequel/adapters/jdbc/derby.rb +58 -54
  106. data/lib/sequel/adapters/jdbc/h2.rb +93 -35
  107. data/lib/sequel/adapters/jdbc/hsqldb.rb +24 -31
  108. data/lib/sequel/adapters/jdbc/jtds.rb +2 -10
  109. data/lib/sequel/adapters/jdbc/mssql.rb +3 -11
  110. data/lib/sequel/adapters/jdbc/mysql.rb +17 -20
  111. data/lib/sequel/adapters/jdbc/oracle.rb +22 -18
  112. data/lib/sequel/adapters/jdbc/postgresql.rb +69 -71
  113. data/lib/sequel/adapters/jdbc/sqlanywhere.rb +11 -23
  114. data/lib/sequel/adapters/jdbc/sqlite.rb +47 -11
  115. data/lib/sequel/adapters/jdbc/sqlserver.rb +34 -9
  116. data/lib/sequel/adapters/jdbc/transactions.rb +22 -38
  117. data/lib/sequel/adapters/jdbc.rb +145 -130
  118. data/lib/sequel/adapters/mock.rb +100 -111
  119. data/lib/sequel/adapters/mysql.rb +114 -122
  120. data/lib/sequel/adapters/mysql2.rb +147 -63
  121. data/lib/sequel/adapters/odbc/db2.rb +1 -1
  122. data/lib/sequel/adapters/odbc/mssql.rb +8 -14
  123. data/lib/sequel/adapters/odbc/oracle.rb +11 -0
  124. data/lib/sequel/adapters/odbc.rb +20 -25
  125. data/lib/sequel/adapters/oracle.rb +50 -56
  126. data/lib/sequel/adapters/postgres.rb +305 -327
  127. data/lib/sequel/adapters/postgresql.rb +1 -1
  128. data/lib/sequel/adapters/shared/access.rb +74 -78
  129. data/lib/sequel/adapters/shared/db2.rb +118 -71
  130. data/lib/sequel/adapters/shared/mssql.rb +301 -220
  131. data/lib/sequel/adapters/shared/mysql.rb +299 -217
  132. data/lib/sequel/adapters/shared/oracle.rb +226 -65
  133. data/lib/sequel/adapters/shared/postgres.rb +935 -395
  134. data/lib/sequel/adapters/shared/sqlanywhere.rb +105 -126
  135. data/lib/sequel/adapters/shared/sqlite.rb +447 -173
  136. data/lib/sequel/adapters/sqlanywhere.rb +48 -35
  137. data/lib/sequel/adapters/sqlite.rb +156 -111
  138. data/lib/sequel/adapters/tinytds.rb +30 -38
  139. data/lib/sequel/adapters/utils/columns_limit_1.rb +22 -0
  140. data/lib/sequel/adapters/utils/emulate_offset_with_reverse_and_count.rb +3 -6
  141. data/lib/sequel/adapters/utils/emulate_offset_with_row_number.rb +2 -2
  142. data/lib/sequel/adapters/utils/mysql_mysql2.rb +87 -0
  143. data/lib/sequel/adapters/utils/mysql_prepared_statements.rb +56 -0
  144. data/lib/sequel/adapters/utils/replace.rb +1 -4
  145. data/lib/sequel/adapters/utils/stored_procedures.rb +7 -22
  146. data/lib/sequel/adapters/utils/unmodified_identifiers.rb +28 -0
  147. data/lib/sequel/ast_transformer.rb +17 -89
  148. data/lib/sequel/connection_pool/sharded_single.rb +18 -15
  149. data/lib/sequel/connection_pool/sharded_threaded.rb +130 -111
  150. data/lib/sequel/connection_pool/single.rb +18 -13
  151. data/lib/sequel/connection_pool/threaded.rb +121 -120
  152. data/lib/sequel/connection_pool.rb +48 -29
  153. data/lib/sequel/core.rb +351 -301
  154. data/lib/sequel/database/connecting.rb +69 -57
  155. data/lib/sequel/database/dataset.rb +13 -5
  156. data/lib/sequel/database/dataset_defaults.rb +18 -102
  157. data/lib/sequel/database/features.rb +18 -4
  158. data/lib/sequel/database/logging.rb +12 -11
  159. data/lib/sequel/database/misc.rb +180 -122
  160. data/lib/sequel/database/query.rb +47 -27
  161. data/lib/sequel/database/schema_generator.rb +178 -84
  162. data/lib/sequel/database/schema_methods.rb +172 -97
  163. data/lib/sequel/database/transactions.rb +205 -44
  164. data/lib/sequel/database.rb +17 -2
  165. data/lib/sequel/dataset/actions.rb +339 -155
  166. data/lib/sequel/dataset/dataset_module.rb +46 -0
  167. data/lib/sequel/dataset/features.rb +90 -35
  168. data/lib/sequel/dataset/graph.rb +80 -58
  169. data/lib/sequel/dataset/misc.rb +137 -47
  170. data/lib/sequel/dataset/placeholder_literalizer.rb +63 -25
  171. data/lib/sequel/dataset/prepared_statements.rb +188 -85
  172. data/lib/sequel/dataset/query.rb +530 -222
  173. data/lib/sequel/dataset/sql.rb +590 -368
  174. data/lib/sequel/dataset.rb +26 -16
  175. data/lib/sequel/deprecated.rb +12 -2
  176. data/lib/sequel/exceptions.rb +46 -16
  177. data/lib/sequel/extensions/_model_constraint_validations.rb +16 -0
  178. data/lib/sequel/extensions/_model_pg_row.rb +43 -0
  179. data/lib/sequel/extensions/_pretty_table.rb +2 -5
  180. data/lib/sequel/extensions/any_not_empty.rb +45 -0
  181. data/lib/sequel/extensions/arbitrary_servers.rb +10 -10
  182. data/lib/sequel/extensions/async_thread_pool.rb +438 -0
  183. data/lib/sequel/extensions/auto_literal_strings.rb +74 -0
  184. data/lib/sequel/extensions/blank.rb +8 -0
  185. data/lib/sequel/extensions/caller_logging.rb +79 -0
  186. data/lib/sequel/extensions/columns_introspection.rb +4 -3
  187. data/lib/sequel/extensions/connection_expiration.rb +20 -10
  188. data/lib/sequel/extensions/connection_validator.rb +11 -10
  189. data/lib/sequel/extensions/constant_sql_override.rb +65 -0
  190. data/lib/sequel/extensions/constraint_validations.rb +62 -39
  191. data/lib/sequel/extensions/core_extensions.rb +42 -48
  192. data/lib/sequel/extensions/core_refinements.rb +80 -59
  193. data/lib/sequel/extensions/current_datetime_timestamp.rb +1 -4
  194. data/lib/sequel/extensions/date_arithmetic.rb +98 -39
  195. data/lib/sequel/extensions/date_parse_input_handler.rb +67 -0
  196. data/lib/sequel/extensions/datetime_parse_to_time.rb +41 -0
  197. data/lib/sequel/extensions/duplicate_columns_handler.rb +21 -14
  198. data/lib/sequel/extensions/empty_array_consider_nulls.rb +2 -2
  199. data/lib/sequel/extensions/escaped_like.rb +100 -0
  200. data/lib/sequel/extensions/eval_inspect.rb +12 -15
  201. data/lib/sequel/extensions/exclude_or_null.rb +68 -0
  202. data/lib/sequel/extensions/fiber_concurrency.rb +24 -0
  203. data/lib/sequel/extensions/freeze_datasets.rb +3 -0
  204. data/lib/sequel/extensions/from_block.rb +1 -34
  205. data/lib/sequel/extensions/graph_each.rb +4 -4
  206. data/lib/sequel/extensions/identifier_mangling.rb +180 -0
  207. data/lib/sequel/extensions/implicit_subquery.rb +48 -0
  208. data/lib/sequel/extensions/index_caching.rb +109 -0
  209. data/lib/sequel/extensions/inflector.rb +13 -5
  210. data/lib/sequel/extensions/integer64.rb +32 -0
  211. data/lib/sequel/extensions/is_distinct_from.rb +141 -0
  212. data/lib/sequel/extensions/looser_typecasting.rb +17 -8
  213. data/lib/sequel/extensions/migration.rb +119 -78
  214. data/lib/sequel/extensions/named_timezones.rb +88 -23
  215. data/lib/sequel/extensions/no_auto_literal_strings.rb +2 -82
  216. data/lib/sequel/extensions/null_dataset.rb +8 -8
  217. data/lib/sequel/extensions/pagination.rb +32 -29
  218. data/lib/sequel/extensions/pg_array.rb +221 -287
  219. data/lib/sequel/extensions/pg_array_ops.rb +17 -9
  220. data/lib/sequel/extensions/pg_enum.rb +63 -23
  221. data/lib/sequel/extensions/pg_extended_date_support.rb +241 -0
  222. data/lib/sequel/extensions/pg_hstore.rb +45 -54
  223. data/lib/sequel/extensions/pg_hstore_ops.rb +58 -6
  224. data/lib/sequel/extensions/pg_inet.rb +31 -12
  225. data/lib/sequel/extensions/pg_inet_ops.rb +2 -2
  226. data/lib/sequel/extensions/pg_interval.rb +56 -29
  227. data/lib/sequel/extensions/pg_json.rb +417 -140
  228. data/lib/sequel/extensions/pg_json_ops.rb +270 -18
  229. data/lib/sequel/extensions/pg_loose_count.rb +4 -2
  230. data/lib/sequel/extensions/pg_multirange.rb +372 -0
  231. data/lib/sequel/extensions/pg_range.rb +131 -191
  232. data/lib/sequel/extensions/pg_range_ops.rb +42 -13
  233. data/lib/sequel/extensions/pg_row.rb +48 -81
  234. data/lib/sequel/extensions/pg_row_ops.rb +33 -14
  235. data/lib/sequel/extensions/pg_static_cache_updater.rb +2 -2
  236. data/lib/sequel/extensions/pg_timestamptz.rb +28 -0
  237. data/lib/sequel/extensions/query.rb +9 -7
  238. data/lib/sequel/extensions/round_timestamps.rb +0 -6
  239. data/lib/sequel/extensions/run_transaction_hooks.rb +72 -0
  240. data/lib/sequel/extensions/s.rb +60 -0
  241. data/lib/sequel/extensions/schema_caching.rb +10 -1
  242. data/lib/sequel/extensions/schema_dumper.rb +71 -48
  243. data/lib/sequel/extensions/select_remove.rb +4 -4
  244. data/lib/sequel/extensions/sequel_4_dataset_methods.rb +85 -0
  245. data/lib/sequel/extensions/server_block.rb +51 -27
  246. data/lib/sequel/extensions/split_array_nil.rb +4 -4
  247. data/lib/sequel/extensions/sql_comments.rb +119 -7
  248. data/lib/sequel/extensions/sql_expr.rb +2 -1
  249. data/lib/sequel/extensions/sql_log_normalizer.rb +108 -0
  250. data/lib/sequel/extensions/sqlite_json_ops.rb +255 -0
  251. data/lib/sequel/extensions/string_agg.rb +11 -8
  252. data/lib/sequel/extensions/string_date_time.rb +19 -23
  253. data/lib/sequel/extensions/symbol_aref.rb +55 -0
  254. data/lib/sequel/extensions/symbol_aref_refinement.rb +43 -0
  255. data/lib/sequel/extensions/symbol_as.rb +23 -0
  256. data/lib/sequel/extensions/symbol_as_refinement.rb +37 -0
  257. data/lib/sequel/extensions/synchronize_sql.rb +45 -0
  258. data/lib/sequel/extensions/to_dot.rb +10 -4
  259. data/lib/sequel/extensions/virtual_row_method_block.rb +44 -0
  260. data/lib/sequel/model/associations.rb +1006 -284
  261. data/lib/sequel/model/base.rb +560 -805
  262. data/lib/sequel/model/dataset_module.rb +11 -10
  263. data/lib/sequel/model/default_inflections.rb +1 -1
  264. data/lib/sequel/model/errors.rb +10 -3
  265. data/lib/sequel/model/exceptions.rb +8 -10
  266. data/lib/sequel/model/inflections.rb +7 -20
  267. data/lib/sequel/model/plugins.rb +114 -0
  268. data/lib/sequel/model.rb +32 -82
  269. data/lib/sequel/plugins/active_model.rb +30 -14
  270. data/lib/sequel/plugins/after_initialize.rb +1 -1
  271. data/lib/sequel/plugins/association_dependencies.rb +25 -18
  272. data/lib/sequel/plugins/association_lazy_eager_option.rb +66 -0
  273. data/lib/sequel/plugins/association_multi_add_remove.rb +85 -0
  274. data/lib/sequel/plugins/association_pks.rb +147 -70
  275. data/lib/sequel/plugins/association_proxies.rb +33 -9
  276. data/lib/sequel/plugins/async_thread_pool.rb +39 -0
  277. data/lib/sequel/plugins/auto_restrict_eager_graph.rb +62 -0
  278. data/lib/sequel/plugins/auto_validations.rb +95 -28
  279. data/lib/sequel/plugins/auto_validations_constraint_validations_presence_message.rb +68 -0
  280. data/lib/sequel/plugins/before_after_save.rb +0 -42
  281. data/lib/sequel/plugins/blacklist_security.rb +21 -12
  282. data/lib/sequel/plugins/boolean_readers.rb +5 -5
  283. data/lib/sequel/plugins/boolean_subsets.rb +13 -8
  284. data/lib/sequel/plugins/caching.rb +25 -16
  285. data/lib/sequel/plugins/class_table_inheritance.rb +179 -100
  286. data/lib/sequel/plugins/column_conflicts.rb +16 -3
  287. data/lib/sequel/plugins/column_encryption.rb +728 -0
  288. data/lib/sequel/plugins/column_select.rb +7 -5
  289. data/lib/sequel/plugins/columns_updated.rb +42 -0
  290. data/lib/sequel/plugins/composition.rb +42 -26
  291. data/lib/sequel/plugins/concurrent_eager_loading.rb +174 -0
  292. data/lib/sequel/plugins/constraint_validations.rb +20 -14
  293. data/lib/sequel/plugins/csv_serializer.rb +56 -35
  294. data/lib/sequel/plugins/dataset_associations.rb +40 -17
  295. data/lib/sequel/plugins/def_dataset_method.rb +90 -0
  296. data/lib/sequel/plugins/defaults_setter.rb +65 -10
  297. data/lib/sequel/plugins/delay_add_association.rb +1 -1
  298. data/lib/sequel/plugins/dirty.rb +62 -24
  299. data/lib/sequel/plugins/eager_each.rb +3 -3
  300. data/lib/sequel/plugins/eager_graph_eager.rb +139 -0
  301. data/lib/sequel/plugins/empty_failure_backtraces.rb +38 -0
  302. data/lib/sequel/plugins/enum.rb +124 -0
  303. data/lib/sequel/plugins/error_splitter.rb +17 -12
  304. data/lib/sequel/plugins/finder.rb +246 -0
  305. data/lib/sequel/plugins/forbid_lazy_load.rb +216 -0
  306. data/lib/sequel/plugins/force_encoding.rb +7 -12
  307. data/lib/sequel/plugins/hook_class_methods.rb +37 -54
  308. data/lib/sequel/plugins/input_transformer.rb +18 -10
  309. data/lib/sequel/plugins/insert_conflict.rb +76 -0
  310. data/lib/sequel/plugins/insert_returning_select.rb +2 -2
  311. data/lib/sequel/plugins/instance_filters.rb +10 -8
  312. data/lib/sequel/plugins/instance_hooks.rb +34 -17
  313. data/lib/sequel/plugins/instance_specific_default.rb +113 -0
  314. data/lib/sequel/plugins/inverted_subsets.rb +22 -13
  315. data/lib/sequel/plugins/json_serializer.rb +124 -64
  316. data/lib/sequel/plugins/lazy_attributes.rb +21 -14
  317. data/lib/sequel/plugins/list.rb +35 -21
  318. data/lib/sequel/plugins/many_through_many.rb +134 -21
  319. data/lib/sequel/plugins/modification_detection.rb +15 -5
  320. data/lib/sequel/plugins/mssql_optimistic_locking.rb +6 -5
  321. data/lib/sequel/plugins/nested_attributes.rb +61 -31
  322. data/lib/sequel/plugins/optimistic_locking.rb +3 -3
  323. data/lib/sequel/plugins/pg_array_associations.rb +103 -53
  324. data/lib/sequel/plugins/pg_auto_constraint_validations.rb +350 -0
  325. data/lib/sequel/plugins/pg_row.rb +5 -51
  326. data/lib/sequel/plugins/prepared_statements.rb +60 -72
  327. data/lib/sequel/plugins/prepared_statements_safe.rb +9 -4
  328. data/lib/sequel/plugins/rcte_tree.rb +68 -82
  329. data/lib/sequel/plugins/require_valid_schema.rb +67 -0
  330. data/lib/sequel/plugins/serialization.rb +43 -46
  331. data/lib/sequel/plugins/serialization_modification_detection.rb +3 -2
  332. data/lib/sequel/plugins/sharding.rb +15 -10
  333. data/lib/sequel/plugins/single_table_inheritance.rb +67 -28
  334. data/lib/sequel/plugins/skip_create_refresh.rb +3 -3
  335. data/lib/sequel/plugins/skip_saving_columns.rb +108 -0
  336. data/lib/sequel/plugins/split_values.rb +11 -6
  337. data/lib/sequel/plugins/sql_comments.rb +189 -0
  338. data/lib/sequel/plugins/static_cache.rb +77 -53
  339. data/lib/sequel/plugins/static_cache_cache.rb +53 -0
  340. data/lib/sequel/plugins/string_stripper.rb +3 -3
  341. data/lib/sequel/plugins/subclasses.rb +43 -10
  342. data/lib/sequel/plugins/subset_conditions.rb +15 -5
  343. data/lib/sequel/plugins/table_select.rb +2 -2
  344. data/lib/sequel/plugins/tactical_eager_loading.rb +96 -12
  345. data/lib/sequel/plugins/throw_failures.rb +110 -0
  346. data/lib/sequel/plugins/timestamps.rb +20 -8
  347. data/lib/sequel/plugins/touch.rb +19 -8
  348. data/lib/sequel/plugins/tree.rb +62 -32
  349. data/lib/sequel/plugins/typecast_on_load.rb +12 -4
  350. data/lib/sequel/plugins/unlimited_update.rb +1 -7
  351. data/lib/sequel/plugins/unused_associations.rb +521 -0
  352. data/lib/sequel/plugins/update_or_create.rb +4 -4
  353. data/lib/sequel/plugins/update_primary_key.rb +1 -1
  354. data/lib/sequel/plugins/update_refresh.rb +26 -15
  355. data/lib/sequel/plugins/uuid.rb +7 -11
  356. data/lib/sequel/plugins/validate_associated.rb +18 -0
  357. data/lib/sequel/plugins/validation_class_methods.rb +38 -19
  358. data/lib/sequel/plugins/validation_contexts.rb +49 -0
  359. data/lib/sequel/plugins/validation_helpers.rb +57 -41
  360. data/lib/sequel/plugins/whitelist_security.rb +122 -0
  361. data/lib/sequel/plugins/xml_serializer.rb +30 -31
  362. data/lib/sequel/sql.rb +471 -331
  363. data/lib/sequel/timezones.rb +78 -47
  364. data/lib/sequel/version.rb +7 -2
  365. data/lib/sequel.rb +1 -1
  366. metadata +217 -521
  367. data/Rakefile +0 -164
  368. data/doc/active_record.rdoc +0 -928
  369. data/doc/release_notes/1.0.txt +0 -38
  370. data/doc/release_notes/1.1.txt +0 -143
  371. data/doc/release_notes/1.3.txt +0 -101
  372. data/doc/release_notes/1.4.0.txt +0 -53
  373. data/doc/release_notes/1.5.0.txt +0 -155
  374. data/doc/release_notes/2.0.0.txt +0 -298
  375. data/doc/release_notes/2.1.0.txt +0 -271
  376. data/doc/release_notes/2.10.0.txt +0 -328
  377. data/doc/release_notes/2.11.0.txt +0 -215
  378. data/doc/release_notes/2.12.0.txt +0 -534
  379. data/doc/release_notes/2.2.0.txt +0 -253
  380. data/doc/release_notes/2.3.0.txt +0 -88
  381. data/doc/release_notes/2.4.0.txt +0 -106
  382. data/doc/release_notes/2.5.0.txt +0 -137
  383. data/doc/release_notes/2.6.0.txt +0 -157
  384. data/doc/release_notes/2.7.0.txt +0 -166
  385. data/doc/release_notes/2.8.0.txt +0 -171
  386. data/doc/release_notes/2.9.0.txt +0 -97
  387. data/doc/release_notes/3.0.0.txt +0 -221
  388. data/doc/release_notes/3.1.0.txt +0 -406
  389. data/doc/release_notes/3.10.0.txt +0 -286
  390. data/doc/release_notes/3.11.0.txt +0 -254
  391. data/doc/release_notes/3.12.0.txt +0 -304
  392. data/doc/release_notes/3.13.0.txt +0 -210
  393. data/doc/release_notes/3.14.0.txt +0 -118
  394. data/doc/release_notes/3.15.0.txt +0 -78
  395. data/doc/release_notes/3.16.0.txt +0 -45
  396. data/doc/release_notes/3.17.0.txt +0 -58
  397. data/doc/release_notes/3.18.0.txt +0 -120
  398. data/doc/release_notes/3.19.0.txt +0 -67
  399. data/doc/release_notes/3.2.0.txt +0 -268
  400. data/doc/release_notes/3.20.0.txt +0 -41
  401. data/doc/release_notes/3.21.0.txt +0 -87
  402. data/doc/release_notes/3.22.0.txt +0 -39
  403. data/doc/release_notes/3.23.0.txt +0 -172
  404. data/doc/release_notes/3.24.0.txt +0 -420
  405. data/doc/release_notes/3.25.0.txt +0 -88
  406. data/doc/release_notes/3.26.0.txt +0 -88
  407. data/doc/release_notes/3.27.0.txt +0 -82
  408. data/doc/release_notes/3.28.0.txt +0 -304
  409. data/doc/release_notes/3.29.0.txt +0 -459
  410. data/doc/release_notes/3.3.0.txt +0 -192
  411. data/doc/release_notes/3.30.0.txt +0 -135
  412. data/doc/release_notes/3.31.0.txt +0 -146
  413. data/doc/release_notes/3.32.0.txt +0 -202
  414. data/doc/release_notes/3.33.0.txt +0 -157
  415. data/doc/release_notes/3.34.0.txt +0 -671
  416. data/doc/release_notes/3.35.0.txt +0 -144
  417. data/doc/release_notes/3.36.0.txt +0 -245
  418. data/doc/release_notes/3.37.0.txt +0 -338
  419. data/doc/release_notes/3.38.0.txt +0 -234
  420. data/doc/release_notes/3.39.0.txt +0 -237
  421. data/doc/release_notes/3.4.0.txt +0 -325
  422. data/doc/release_notes/3.40.0.txt +0 -73
  423. data/doc/release_notes/3.41.0.txt +0 -155
  424. data/doc/release_notes/3.42.0.txt +0 -74
  425. data/doc/release_notes/3.43.0.txt +0 -105
  426. data/doc/release_notes/3.44.0.txt +0 -152
  427. data/doc/release_notes/3.45.0.txt +0 -179
  428. data/doc/release_notes/3.46.0.txt +0 -122
  429. data/doc/release_notes/3.47.0.txt +0 -270
  430. data/doc/release_notes/3.48.0.txt +0 -477
  431. data/doc/release_notes/3.5.0.txt +0 -510
  432. data/doc/release_notes/3.6.0.txt +0 -366
  433. data/doc/release_notes/3.7.0.txt +0 -179
  434. data/doc/release_notes/3.8.0.txt +0 -151
  435. data/doc/release_notes/3.9.0.txt +0 -233
  436. data/doc/release_notes/4.0.0.txt +0 -262
  437. data/doc/release_notes/4.1.0.txt +0 -85
  438. data/doc/release_notes/4.10.0.txt +0 -226
  439. data/doc/release_notes/4.11.0.txt +0 -147
  440. data/doc/release_notes/4.12.0.txt +0 -105
  441. data/doc/release_notes/4.13.0.txt +0 -169
  442. data/doc/release_notes/4.14.0.txt +0 -68
  443. data/doc/release_notes/4.15.0.txt +0 -56
  444. data/doc/release_notes/4.16.0.txt +0 -36
  445. data/doc/release_notes/4.17.0.txt +0 -38
  446. data/doc/release_notes/4.18.0.txt +0 -36
  447. data/doc/release_notes/4.19.0.txt +0 -45
  448. data/doc/release_notes/4.2.0.txt +0 -129
  449. data/doc/release_notes/4.20.0.txt +0 -79
  450. data/doc/release_notes/4.21.0.txt +0 -94
  451. data/doc/release_notes/4.22.0.txt +0 -72
  452. data/doc/release_notes/4.23.0.txt +0 -65
  453. data/doc/release_notes/4.24.0.txt +0 -99
  454. data/doc/release_notes/4.25.0.txt +0 -181
  455. data/doc/release_notes/4.26.0.txt +0 -44
  456. data/doc/release_notes/4.27.0.txt +0 -78
  457. data/doc/release_notes/4.28.0.txt +0 -57
  458. data/doc/release_notes/4.29.0.txt +0 -41
  459. data/doc/release_notes/4.3.0.txt +0 -40
  460. data/doc/release_notes/4.30.0.txt +0 -37
  461. data/doc/release_notes/4.31.0.txt +0 -57
  462. data/doc/release_notes/4.32.0.txt +0 -132
  463. data/doc/release_notes/4.33.0.txt +0 -88
  464. data/doc/release_notes/4.34.0.txt +0 -86
  465. data/doc/release_notes/4.35.0.txt +0 -130
  466. data/doc/release_notes/4.36.0.txt +0 -116
  467. data/doc/release_notes/4.4.0.txt +0 -92
  468. data/doc/release_notes/4.5.0.txt +0 -34
  469. data/doc/release_notes/4.6.0.txt +0 -30
  470. data/doc/release_notes/4.7.0.txt +0 -103
  471. data/doc/release_notes/4.8.0.txt +0 -175
  472. data/doc/release_notes/4.9.0.txt +0 -190
  473. data/lib/sequel/adapters/cubrid.rb +0 -144
  474. data/lib/sequel/adapters/do/mysql.rb +0 -66
  475. data/lib/sequel/adapters/do/postgres.rb +0 -44
  476. data/lib/sequel/adapters/do/sqlite3.rb +0 -42
  477. data/lib/sequel/adapters/do.rb +0 -158
  478. data/lib/sequel/adapters/jdbc/as400.rb +0 -84
  479. data/lib/sequel/adapters/jdbc/cubrid.rb +0 -64
  480. data/lib/sequel/adapters/jdbc/firebirdsql.rb +0 -36
  481. data/lib/sequel/adapters/jdbc/informix-sqli.rb +0 -33
  482. data/lib/sequel/adapters/jdbc/jdbcprogress.rb +0 -33
  483. data/lib/sequel/adapters/odbc/progress.rb +0 -10
  484. data/lib/sequel/adapters/shared/cubrid.rb +0 -245
  485. data/lib/sequel/adapters/shared/firebird.rb +0 -247
  486. data/lib/sequel/adapters/shared/informix.rb +0 -54
  487. data/lib/sequel/adapters/shared/mysql_prepared_statements.rb +0 -152
  488. data/lib/sequel/adapters/shared/progress.rb +0 -40
  489. data/lib/sequel/adapters/swift/mysql.rb +0 -49
  490. data/lib/sequel/adapters/swift/postgres.rb +0 -47
  491. data/lib/sequel/adapters/swift/sqlite.rb +0 -49
  492. data/lib/sequel/adapters/swift.rb +0 -160
  493. data/lib/sequel/adapters/utils/pg_types.rb +0 -70
  494. data/lib/sequel/dataset/mutation.rb +0 -111
  495. data/lib/sequel/extensions/empty_array_ignore_nulls.rb +0 -5
  496. data/lib/sequel/extensions/filter_having.rb +0 -63
  497. data/lib/sequel/extensions/hash_aliases.rb +0 -49
  498. data/lib/sequel/extensions/meta_def.rb +0 -35
  499. data/lib/sequel/extensions/query_literals.rb +0 -84
  500. data/lib/sequel/extensions/ruby18_symbol_extensions.rb +0 -24
  501. data/lib/sequel/extensions/sequel_3_dataset_methods.rb +0 -122
  502. data/lib/sequel/extensions/set_overrides.rb +0 -76
  503. data/lib/sequel/no_core_ext.rb +0 -3
  504. data/lib/sequel/plugins/association_autoreloading.rb +0 -9
  505. data/lib/sequel/plugins/identifier_columns.rb +0 -47
  506. data/lib/sequel/plugins/many_to_one_pk_lookup.rb +0 -9
  507. data/lib/sequel/plugins/pg_typecast_on_load.rb +0 -81
  508. data/lib/sequel/plugins/prepared_statements_associations.rb +0 -119
  509. data/lib/sequel/plugins/prepared_statements_with_pk.rb +0 -61
  510. data/lib/sequel/plugins/schema.rb +0 -82
  511. data/lib/sequel/plugins/scissors.rb +0 -35
  512. data/spec/adapter_spec.rb +0 -4
  513. data/spec/adapters/db2_spec.rb +0 -160
  514. data/spec/adapters/firebird_spec.rb +0 -411
  515. data/spec/adapters/informix_spec.rb +0 -100
  516. data/spec/adapters/mssql_spec.rb +0 -733
  517. data/spec/adapters/mysql_spec.rb +0 -1319
  518. data/spec/adapters/oracle_spec.rb +0 -313
  519. data/spec/adapters/postgres_spec.rb +0 -3790
  520. data/spec/adapters/spec_helper.rb +0 -49
  521. data/spec/adapters/sqlanywhere_spec.rb +0 -170
  522. data/spec/adapters/sqlite_spec.rb +0 -688
  523. data/spec/bin_spec.rb +0 -258
  524. data/spec/core/connection_pool_spec.rb +0 -1045
  525. data/spec/core/database_spec.rb +0 -2636
  526. data/spec/core/dataset_spec.rb +0 -5175
  527. data/spec/core/deprecated_spec.rb +0 -70
  528. data/spec/core/expression_filters_spec.rb +0 -1247
  529. data/spec/core/mock_adapter_spec.rb +0 -464
  530. data/spec/core/object_graph_spec.rb +0 -303
  531. data/spec/core/placeholder_literalizer_spec.rb +0 -163
  532. data/spec/core/schema_generator_spec.rb +0 -203
  533. data/spec/core/schema_spec.rb +0 -1676
  534. data/spec/core/spec_helper.rb +0 -34
  535. data/spec/core/version_spec.rb +0 -7
  536. data/spec/core_extensions_spec.rb +0 -699
  537. data/spec/core_model_spec.rb +0 -2
  538. data/spec/core_spec.rb +0 -1
  539. data/spec/extensions/accessed_columns_spec.rb +0 -51
  540. data/spec/extensions/active_model_spec.rb +0 -85
  541. data/spec/extensions/after_initialize_spec.rb +0 -24
  542. data/spec/extensions/arbitrary_servers_spec.rb +0 -109
  543. data/spec/extensions/association_dependencies_spec.rb +0 -117
  544. data/spec/extensions/association_pks_spec.rb +0 -405
  545. data/spec/extensions/association_proxies_spec.rb +0 -86
  546. data/spec/extensions/auto_validations_spec.rb +0 -192
  547. data/spec/extensions/before_after_save_spec.rb +0 -40
  548. data/spec/extensions/blacklist_security_spec.rb +0 -88
  549. data/spec/extensions/blank_spec.rb +0 -69
  550. data/spec/extensions/boolean_readers_spec.rb +0 -93
  551. data/spec/extensions/boolean_subsets_spec.rb +0 -47
  552. data/spec/extensions/caching_spec.rb +0 -270
  553. data/spec/extensions/class_table_inheritance_spec.rb +0 -444
  554. data/spec/extensions/column_conflicts_spec.rb +0 -60
  555. data/spec/extensions/column_select_spec.rb +0 -108
  556. data/spec/extensions/columns_introspection_spec.rb +0 -91
  557. data/spec/extensions/composition_spec.rb +0 -242
  558. data/spec/extensions/connection_expiration_spec.rb +0 -121
  559. data/spec/extensions/connection_validator_spec.rb +0 -127
  560. data/spec/extensions/constraint_validations_plugin_spec.rb +0 -288
  561. data/spec/extensions/constraint_validations_spec.rb +0 -389
  562. data/spec/extensions/core_refinements_spec.rb +0 -519
  563. data/spec/extensions/csv_serializer_spec.rb +0 -180
  564. data/spec/extensions/current_datetime_timestamp_spec.rb +0 -27
  565. data/spec/extensions/dataset_associations_spec.rb +0 -343
  566. data/spec/extensions/dataset_source_alias_spec.rb +0 -51
  567. data/spec/extensions/date_arithmetic_spec.rb +0 -167
  568. data/spec/extensions/defaults_setter_spec.rb +0 -102
  569. data/spec/extensions/delay_add_association_spec.rb +0 -74
  570. data/spec/extensions/dirty_spec.rb +0 -180
  571. data/spec/extensions/duplicate_columns_handler_spec.rb +0 -110
  572. data/spec/extensions/eager_each_spec.rb +0 -66
  573. data/spec/extensions/empty_array_consider_nulls_spec.rb +0 -24
  574. data/spec/extensions/error_splitter_spec.rb +0 -18
  575. data/spec/extensions/error_sql_spec.rb +0 -20
  576. data/spec/extensions/eval_inspect_spec.rb +0 -73
  577. data/spec/extensions/filter_having_spec.rb +0 -40
  578. data/spec/extensions/force_encoding_spec.rb +0 -114
  579. data/spec/extensions/from_block_spec.rb +0 -21
  580. data/spec/extensions/graph_each_spec.rb +0 -119
  581. data/spec/extensions/hash_aliases_spec.rb +0 -24
  582. data/spec/extensions/hook_class_methods_spec.rb +0 -429
  583. data/spec/extensions/identifier_columns_spec.rb +0 -17
  584. data/spec/extensions/inflector_spec.rb +0 -183
  585. data/spec/extensions/input_transformer_spec.rb +0 -54
  586. data/spec/extensions/insert_returning_select_spec.rb +0 -46
  587. data/spec/extensions/instance_filters_spec.rb +0 -79
  588. data/spec/extensions/instance_hooks_spec.rb +0 -276
  589. data/spec/extensions/inverted_subsets_spec.rb +0 -33
  590. data/spec/extensions/json_serializer_spec.rb +0 -304
  591. data/spec/extensions/lazy_attributes_spec.rb +0 -170
  592. data/spec/extensions/list_spec.rb +0 -278
  593. data/spec/extensions/looser_typecasting_spec.rb +0 -43
  594. data/spec/extensions/many_through_many_spec.rb +0 -2172
  595. data/spec/extensions/meta_def_spec.rb +0 -21
  596. data/spec/extensions/migration_spec.rb +0 -728
  597. data/spec/extensions/modification_detection_spec.rb +0 -80
  598. data/spec/extensions/mssql_optimistic_locking_spec.rb +0 -91
  599. data/spec/extensions/named_timezones_spec.rb +0 -108
  600. data/spec/extensions/nested_attributes_spec.rb +0 -697
  601. data/spec/extensions/no_auto_literal_strings_spec.rb +0 -65
  602. data/spec/extensions/null_dataset_spec.rb +0 -85
  603. data/spec/extensions/optimistic_locking_spec.rb +0 -128
  604. data/spec/extensions/pagination_spec.rb +0 -118
  605. data/spec/extensions/pg_array_associations_spec.rb +0 -736
  606. data/spec/extensions/pg_array_ops_spec.rb +0 -143
  607. data/spec/extensions/pg_array_spec.rb +0 -390
  608. data/spec/extensions/pg_enum_spec.rb +0 -92
  609. data/spec/extensions/pg_hstore_ops_spec.rb +0 -236
  610. data/spec/extensions/pg_hstore_spec.rb +0 -206
  611. data/spec/extensions/pg_inet_ops_spec.rb +0 -101
  612. data/spec/extensions/pg_inet_spec.rb +0 -52
  613. data/spec/extensions/pg_interval_spec.rb +0 -76
  614. data/spec/extensions/pg_json_ops_spec.rb +0 -275
  615. data/spec/extensions/pg_json_spec.rb +0 -218
  616. data/spec/extensions/pg_loose_count_spec.rb +0 -17
  617. data/spec/extensions/pg_range_ops_spec.rb +0 -58
  618. data/spec/extensions/pg_range_spec.rb +0 -473
  619. data/spec/extensions/pg_row_ops_spec.rb +0 -60
  620. data/spec/extensions/pg_row_plugin_spec.rb +0 -62
  621. data/spec/extensions/pg_row_spec.rb +0 -360
  622. data/spec/extensions/pg_static_cache_updater_spec.rb +0 -92
  623. data/spec/extensions/pg_typecast_on_load_spec.rb +0 -63
  624. data/spec/extensions/prepared_statements_associations_spec.rb +0 -159
  625. data/spec/extensions/prepared_statements_safe_spec.rb +0 -61
  626. data/spec/extensions/prepared_statements_spec.rb +0 -103
  627. data/spec/extensions/prepared_statements_with_pk_spec.rb +0 -31
  628. data/spec/extensions/pretty_table_spec.rb +0 -92
  629. data/spec/extensions/query_literals_spec.rb +0 -183
  630. data/spec/extensions/query_spec.rb +0 -102
  631. data/spec/extensions/rcte_tree_spec.rb +0 -392
  632. data/spec/extensions/round_timestamps_spec.rb +0 -43
  633. data/spec/extensions/schema_caching_spec.rb +0 -41
  634. data/spec/extensions/schema_dumper_spec.rb +0 -814
  635. data/spec/extensions/schema_spec.rb +0 -117
  636. data/spec/extensions/scissors_spec.rb +0 -26
  637. data/spec/extensions/select_remove_spec.rb +0 -38
  638. data/spec/extensions/sequel_3_dataset_methods_spec.rb +0 -101
  639. data/spec/extensions/serialization_modification_detection_spec.rb +0 -98
  640. data/spec/extensions/serialization_spec.rb +0 -362
  641. data/spec/extensions/server_block_spec.rb +0 -90
  642. data/spec/extensions/server_logging_spec.rb +0 -45
  643. data/spec/extensions/set_overrides_spec.rb +0 -61
  644. data/spec/extensions/sharding_spec.rb +0 -198
  645. data/spec/extensions/shared_caching_spec.rb +0 -175
  646. data/spec/extensions/single_table_inheritance_spec.rb +0 -297
  647. data/spec/extensions/singular_table_names_spec.rb +0 -22
  648. data/spec/extensions/skip_create_refresh_spec.rb +0 -17
  649. data/spec/extensions/spec_helper.rb +0 -71
  650. data/spec/extensions/split_array_nil_spec.rb +0 -24
  651. data/spec/extensions/split_values_spec.rb +0 -22
  652. data/spec/extensions/sql_comments_spec.rb +0 -27
  653. data/spec/extensions/sql_expr_spec.rb +0 -60
  654. data/spec/extensions/static_cache_spec.rb +0 -361
  655. data/spec/extensions/string_agg_spec.rb +0 -85
  656. data/spec/extensions/string_date_time_spec.rb +0 -95
  657. data/spec/extensions/string_stripper_spec.rb +0 -68
  658. data/spec/extensions/subclasses_spec.rb +0 -66
  659. data/spec/extensions/subset_conditions_spec.rb +0 -38
  660. data/spec/extensions/table_select_spec.rb +0 -71
  661. data/spec/extensions/tactical_eager_loading_spec.rb +0 -136
  662. data/spec/extensions/thread_local_timezones_spec.rb +0 -67
  663. data/spec/extensions/timestamps_spec.rb +0 -175
  664. data/spec/extensions/to_dot_spec.rb +0 -154
  665. data/spec/extensions/touch_spec.rb +0 -203
  666. data/spec/extensions/tree_spec.rb +0 -274
  667. data/spec/extensions/typecast_on_load_spec.rb +0 -80
  668. data/spec/extensions/unlimited_update_spec.rb +0 -20
  669. data/spec/extensions/update_or_create_spec.rb +0 -87
  670. data/spec/extensions/update_primary_key_spec.rb +0 -100
  671. data/spec/extensions/update_refresh_spec.rb +0 -53
  672. data/spec/extensions/uuid_spec.rb +0 -106
  673. data/spec/extensions/validate_associated_spec.rb +0 -52
  674. data/spec/extensions/validation_class_methods_spec.rb +0 -1027
  675. data/spec/extensions/validation_helpers_spec.rb +0 -554
  676. data/spec/extensions/xml_serializer_spec.rb +0 -207
  677. data/spec/files/bad_down_migration/001_create_alt_basic.rb +0 -4
  678. data/spec/files/bad_down_migration/002_create_alt_advanced.rb +0 -4
  679. data/spec/files/bad_timestamped_migrations/1273253849_create_sessions.rb +0 -9
  680. data/spec/files/bad_timestamped_migrations/1273253851_create_nodes.rb +0 -9
  681. data/spec/files/bad_timestamped_migrations/1273253853_3_create_users.rb +0 -3
  682. data/spec/files/bad_up_migration/001_create_alt_basic.rb +0 -4
  683. data/spec/files/bad_up_migration/002_create_alt_advanced.rb +0 -3
  684. data/spec/files/convert_to_timestamp_migrations/001_create_sessions.rb +0 -9
  685. data/spec/files/convert_to_timestamp_migrations/002_create_nodes.rb +0 -9
  686. data/spec/files/convert_to_timestamp_migrations/003_3_create_users.rb +0 -4
  687. data/spec/files/convert_to_timestamp_migrations/1273253850_create_artists.rb +0 -9
  688. data/spec/files/convert_to_timestamp_migrations/1273253852_create_albums.rb +0 -9
  689. data/spec/files/double_migration/001_create_sessions.rb +0 -9
  690. data/spec/files/double_migration/002_create_nodes.rb +0 -19
  691. data/spec/files/double_migration/003_3_create_users.rb +0 -4
  692. data/spec/files/duplicate_integer_migrations/001_create_alt_advanced.rb +0 -4
  693. data/spec/files/duplicate_integer_migrations/001_create_alt_basic.rb +0 -4
  694. data/spec/files/duplicate_timestamped_migrations/1273253849_create_sessions.rb +0 -9
  695. data/spec/files/duplicate_timestamped_migrations/1273253853_create_nodes.rb +0 -9
  696. data/spec/files/duplicate_timestamped_migrations/1273253853_create_users.rb +0 -4
  697. data/spec/files/empty_migration/001_create_sessions.rb +0 -9
  698. data/spec/files/empty_migration/002_create_nodes.rb +0 -0
  699. data/spec/files/empty_migration/003_3_create_users.rb +0 -4
  700. data/spec/files/integer_migrations/001_create_sessions.rb +0 -9
  701. data/spec/files/integer_migrations/002_create_nodes.rb +0 -9
  702. data/spec/files/integer_migrations/003_3_create_users.rb +0 -4
  703. data/spec/files/interleaved_timestamped_migrations/1273253849_create_sessions.rb +0 -9
  704. data/spec/files/interleaved_timestamped_migrations/1273253850_create_artists.rb +0 -9
  705. data/spec/files/interleaved_timestamped_migrations/1273253851_create_nodes.rb +0 -9
  706. data/spec/files/interleaved_timestamped_migrations/1273253852_create_albums.rb +0 -9
  707. data/spec/files/interleaved_timestamped_migrations/1273253853_3_create_users.rb +0 -4
  708. data/spec/files/missing_integer_migrations/001_create_alt_basic.rb +0 -4
  709. data/spec/files/missing_integer_migrations/003_create_alt_advanced.rb +0 -4
  710. data/spec/files/missing_timestamped_migrations/1273253849_create_sessions.rb +0 -9
  711. data/spec/files/missing_timestamped_migrations/1273253853_3_create_users.rb +0 -4
  712. data/spec/files/reversible_migrations/001_reversible.rb +0 -5
  713. data/spec/files/reversible_migrations/002_reversible.rb +0 -5
  714. data/spec/files/reversible_migrations/003_reversible.rb +0 -5
  715. data/spec/files/reversible_migrations/004_reversible.rb +0 -5
  716. data/spec/files/reversible_migrations/005_reversible.rb +0 -10
  717. data/spec/files/reversible_migrations/006_reversible.rb +0 -10
  718. data/spec/files/reversible_migrations/007_reversible.rb +0 -10
  719. data/spec/files/timestamped_migrations/1273253849_create_sessions.rb +0 -9
  720. data/spec/files/timestamped_migrations/1273253851_create_nodes.rb +0 -9
  721. data/spec/files/timestamped_migrations/1273253853_3_create_users.rb +0 -4
  722. data/spec/files/transaction_specified_migrations/001_create_alt_basic.rb +0 -4
  723. data/spec/files/transaction_specified_migrations/002_create_basic.rb +0 -4
  724. data/spec/files/transaction_unspecified_migrations/001_create_alt_basic.rb +0 -3
  725. data/spec/files/transaction_unspecified_migrations/002_create_basic.rb +0 -3
  726. data/spec/files/uppercase_timestamped_migrations/1273253849_CREATE_SESSIONS.RB +0 -9
  727. data/spec/files/uppercase_timestamped_migrations/1273253851_CREATE_NODES.RB +0 -9
  728. data/spec/files/uppercase_timestamped_migrations/1273253853_3_CREATE_USERS.RB +0 -4
  729. data/spec/guards_helper.rb +0 -55
  730. data/spec/integration/associations_test.rb +0 -2506
  731. data/spec/integration/database_test.rb +0 -113
  732. data/spec/integration/dataset_test.rb +0 -1858
  733. data/spec/integration/eager_loader_test.rb +0 -687
  734. data/spec/integration/migrator_test.rb +0 -262
  735. data/spec/integration/model_test.rb +0 -230
  736. data/spec/integration/plugin_test.rb +0 -2297
  737. data/spec/integration/prepared_statement_test.rb +0 -467
  738. data/spec/integration/schema_test.rb +0 -815
  739. data/spec/integration/spec_helper.rb +0 -56
  740. data/spec/integration/timezone_test.rb +0 -86
  741. data/spec/integration/transaction_test.rb +0 -406
  742. data/spec/integration/type_test.rb +0 -133
  743. data/spec/model/association_reflection_spec.rb +0 -565
  744. data/spec/model/associations_spec.rb +0 -4589
  745. data/spec/model/base_spec.rb +0 -759
  746. data/spec/model/class_dataset_methods_spec.rb +0 -150
  747. data/spec/model/dataset_methods_spec.rb +0 -149
  748. data/spec/model/eager_loading_spec.rb +0 -2197
  749. data/spec/model/hooks_spec.rb +0 -604
  750. data/spec/model/inflector_spec.rb +0 -26
  751. data/spec/model/model_spec.rb +0 -1097
  752. data/spec/model/plugins_spec.rb +0 -299
  753. data/spec/model/record_spec.rb +0 -2162
  754. data/spec/model/spec_helper.rb +0 -46
  755. data/spec/model/validations_spec.rb +0 -193
  756. data/spec/model_no_assoc_spec.rb +0 -1
  757. data/spec/model_spec.rb +0 -1
  758. data/spec/plugin_spec.rb +0 -1
  759. data/spec/sequel_coverage.rb +0 -15
  760. data/spec/spec_config.rb +0 -10
@@ -1,65 +0,0 @@
1
- = New Features
2
-
3
- * An update_refresh plugin has been added, for refreshing a model
4
- instance when updating. The default behavior is to only refresh
5
- when inserting. However, if you have triggers on the model's table,
6
- it's a good idea to refresh when updating to pick up the possibly
7
- changed values. On databases that support UPDATE RETURNING, such as
8
- PostgreSQL, the update and refresh are done in a single query.
9
-
10
- * A delay_add_association plugin has been added, for delaying add_*
11
- method calls for associations until after the receiver has been
12
- saved, if the receiver is a new object. Example:
13
-
14
- artist = Artist.new(:name=>'Foo')
15
- artist.add_album(Album.new(:name=>'Bar'))
16
- # No database queries yet
17
-
18
- artist.save # Saves artist, then album
19
-
20
- * A validate_associated plugin has been added, for validating
21
- associated objects when validating the current object. This
22
- was extracted from the nested_attributes plugin, and is also
23
- used by the delay_add_association plugin. For example,
24
- if you have an albums association and you want to validate all
25
- associated objects before saving the current object, you can
26
- cal validate_associated_object for each object:
27
-
28
- def validate
29
- super
30
- reflection = association_reflection(:albums)
31
- associations[:albums].each do |obj|
32
- validate_associated_object(reflection, obj)
33
- end
34
- end
35
-
36
- = Other Improvements
37
-
38
- * Database#transaction now returns the block return value if
39
- :rollback=>:always is used. Previously, it would return nil in
40
- that case.
41
-
42
- * Postgres::JSONBOp#[] and #get_text now return JSONBOp instances
43
- instead of JSONOp instances.
44
-
45
- * Model#move_to, #move_up, and #move_down in the list plugin now
46
- automatically handle out-of-range targets by defaulting to the first
47
- or last position in the list. Previously, using an out of range
48
- target would raise an exception.
49
-
50
- * Database#add_named_conversion_proc on PostgreSQL now works for enum
51
- types.
52
-
53
- * dataset.call_sproc(:insert, ...) now works correctly on JDBC.
54
-
55
- * postgresql:// connection strings are now supported, since that is
56
- the protocol name supported by libpq.
57
-
58
- * Sequel has switched from rspec to minitest/spec for testing, and
59
- now uses random test order when testing. During the conversion
60
- process, many test order dependency bugs were fixed.
61
-
62
- = Backwards Compatibility
63
-
64
- * The deprecated fdbsql, jdbc/fdbsql, and openbase adapters have been
65
- removed.
@@ -1,99 +0,0 @@
1
- = New Features
2
-
3
- * A pg_inet_ops extension has been added, for DSL support for
4
- calling PostgreSQL inet functions and operators. Example:
5
-
6
- r = Sequel.pg_inet_op(:inet)
7
-
8
- ~r # ~inet
9
- r & :other # inet & other
10
- r | :other # inet | other
11
- r << :other # inet << other
12
- r >> :other # inet >> other
13
-
14
- r.contained_by(:other) # inet << other
15
- r.contained_by_or_equals(:other) # inet <<= other
16
- r.contains(:other) # inet >> other
17
- r.contains_or_equals(:other) # inet >>= other
18
- r.contains_or_contained_by(:other) # inet && other
19
-
20
- r.abbrev # abbrev(inet)
21
- r.broadcast # broadcast(inet)
22
- r.family # family(inet)
23
- r.host # host(inet)
24
- r.hostmask # hostmask(inet)
25
- r.masklen # masklen(inet)
26
- r.netmask # netmask(inet)
27
- r.network # network(inet)
28
- r.set_masklen(16) # set_masklen(inet, 16)
29
- r.text # text(inet)
30
-
31
- * The association_pks plugin now supports a :delay_pks association
32
- option. When set to true, this makes the methods created by the
33
- plugin usable on new objects, by delaying the saving of the
34
- associated pks until after the new object has been saved. When
35
- set to :always, this also changes the behavior of the methods
36
- for existing objects, so that nothing is persisted until the
37
- object has been saved. Example:
38
-
39
- Album.plugin :association_pks
40
- Album.many_to_many :tags, :delay_pks=>true
41
-
42
- album = Album.new(:tag_pks=>[1,2,3]) # No database query
43
- album.save # Queries to insert album, and then update albums_tags
44
-
45
- * The class_table_inheritance plugin now supports subclasses that
46
- don't require additional columns, and therefore do not need to
47
- join to additional tables. It now loads the
48
- single_table_inheritance plugin and supports options that were
49
- previously only supported by single_table_inheritance, such as the
50
- :key_map and :key_chooser options.
51
-
52
- * The validation_helpers plugin now supports a :from=>:values option
53
- in the validation methods, which will take the value directly from
54
- the values hash instead of calling the related method. This
55
- allows validation_helpers to differentiate between validations on
56
- underlying database column and validations on the model.
57
-
58
- The auto_validations plugin has been modified to use this feature,
59
- since all validations it generates are for validations on the
60
- underlying database columns.
61
-
62
- * The auto_validations plugin now supports options to pass to each
63
- of the underlying validation methods:
64
-
65
- Sequel::Model.plugin :auto_validations,
66
- :unique_opts=>{:only_if_modified=>true}
67
-
68
- In addition to :unique_opts, there is support for :not_null_opts
69
- (for NOT NULL columns without a default), :explicit_not_null_opts
70
- (for NOT NULL columns with a default), :max_length_opts, and
71
- :schema_types_opts.
72
-
73
- * The update_refresh plugin now accepts a :columns option, which
74
- specifies the columns to refresh. This option is currently only
75
- respected if the related dataset supports RETURNING.
76
-
77
- * The :timeout option to Database#listen in the postgres adapter can
78
- now be a callable object, previously it had to be Numeric. This
79
- allows you to dynamically change the timeout based on current
80
- application state.
81
-
82
- = Other Improvements
83
-
84
- * The uniqueness validations added by the auto_validations plugin now
85
- use a symbol key in the related Errors instance if the underlying
86
- index was on a single column. Previously, the uniqueness
87
- validations for a single column would use an array key in the
88
- related Errors instance.
89
-
90
- * The jdbc subadapters now correctly handle 64-bit autoincrementing
91
- primary keys.
92
-
93
- * The jdbc subadapters now work correctly if they issue queries while
94
- the subadapter is being loaded. This can happen in the
95
- jdbc/postgresql adapter if the pg_hstore extension is used.
96
-
97
- = Backwards Compatibility
98
-
99
- * The deprecated db2 and dbi adapters have been removed.
@@ -1,181 +0,0 @@
1
- = New Features
2
-
3
- * The =~ and !~ methods are now defined on ComplexExpressions in
4
- addition to GenericExpressions, allowing the following code to
5
- work:
6
-
7
- DB[:table].where{(column1 + column2) =~ column3}
8
-
9
- * Dataset#group_append has been added for appending to an existing
10
- GROUP BY clause:
11
-
12
- ds = DB[:table].group(:column1)
13
- # SELECT * FROM table GROUP BY column1
14
-
15
- ds = ds.group_append(:column2)
16
- # SELECT * FROM table GROUP BY column1, column2
17
-
18
- * An inverted_subsets plugin has been added, for automatic creation of
19
- methods for the inversion of the subset criteria. For example:
20
-
21
- Album.plugin :inverted_subsets
22
- Album.subset :published, :published=>true
23
-
24
- Album.published
25
- # SELECT * FROM albums WHERE published IS TRUE
26
-
27
- Album.not_published
28
- # SELECT * FROM albums WHERE published IS NOT TRUE
29
-
30
- By default, the subset method name is prefixed with "not_". You can
31
- pass a block to override the default behavior:
32
-
33
- Album.plugin(:inverted_subsets){|name| "exclude_#{name}"}
34
- Album.subset :published, :published=>true
35
-
36
- Album.exclude_published
37
- # SELECT * FROM albums WHERE published IS NOT TRUE
38
-
39
- * A singular_table_names plugin has been added, which changes Sequel
40
- to not pluralize table names by default.
41
-
42
- Sequel::Model.plugin :singular_table_names
43
- class FooBar < Sequel::Model; end
44
- FooBar.table_name # => foo_bar
45
-
46
- * Dataset#insert_conflict and #insert_ignore have been added on
47
- PostgreSQL. When using PostgreSQL 9.5+, they allow you to ignore
48
- unique or exclusion constraint violations on inserting, or to do
49
- an update instead:
50
-
51
- DB[:table].insert_conflict.insert(:a=>1, :b=>2)
52
- # INSERT INTO TABLE (a, b) VALUES (1, 2)
53
- # ON CONFLICT DO NOTHING
54
-
55
- You can pass a specific constraint name using :constraint, to only
56
- ignore a specific constraint violation:
57
-
58
- DB[:table].insert_conflict(:constraint=>:table_a_uidx).
59
- insert(:a=>1, :b=>2)
60
- # INSERT INTO TABLE (a, b) VALUES (1, 2)
61
- # ON CONFLICT ON CONSTRAINT table_a_uidx DO NOTHING
62
-
63
- If the unique or exclusion constraint covers the whole table (e.g.
64
- it isn't a partial unique index), then you can just specify the
65
- column using the :target option:
66
-
67
- DB[:table].insert_conflict(:target=>:a).insert(:a=>1, :b=>2)
68
- # INSERT INTO TABLE (a, b) VALUES (1, 2)
69
- # ON CONFLICT (a) DO NOTHING
70
-
71
- If you want to update the existing row instead of ignoring the
72
- constraint violation, you can pass an :update option with a hash of
73
- values to update. You must pass either the :target or :constraint
74
- options when passing the :update option:
75
-
76
- DB[:table].insert_conflict(:target=>:a,
77
- :update=>{:b=>:excluded__b}).
78
- insert(:a=>1, :b=>2)
79
- # INSERT INTO TABLE (a, b) VALUES (1, 2)
80
- # ON CONFLICT (a) DO UPDATE SET b = excluded.b
81
-
82
- Additionally, if you only want to do the update in certain cases,
83
- you can specify an :update_where option, which will be used as a
84
- filter. If the row doesn't match the conditions, the constraint
85
- violation will be ignored, but the row will not be updated:
86
-
87
- DB[:table].insert_conflict(:constraint=>:table_a_uidx,
88
- :update=>{:b=>:excluded__b},
89
- :update_where=>{:table__status_id=>1}).
90
- insert(:a=>1, :b=>2)
91
- # INSERT INTO TABLE (a, b) VALUES (1, 2)
92
- # ON CONFLICT ON CONSTRAINT table_a_uidx
93
- # DO UPDATE SET b = excluded.b WHERE (table.status_id = 1)
94
-
95
- * Dataset#group_rollup and #group_cube are now supported when using
96
- PostgreSQL 9.5+.
97
-
98
- * Sequel now supports Dataset#returning when using prepared statements
99
- and bound variables:
100
-
101
- DB[:table].returning.prepare(:insert, :i, :col=>:$col).
102
- call(:col=>42)
103
- # => [{:col=>42}]
104
-
105
- = Other Improvements
106
-
107
- * The serialization plugin now integrates with the dirty plugin, so
108
- that column changes are detected correctly. However, column values
109
- that are changed and then changed back to the original value are
110
- still detected as changed.
111
-
112
- * Dataset#for_update and similar locking methods now cause Sequel not
113
- to use the :read_only shard if sharding is used.
114
-
115
- * The association_pks plugin now clears cached delayed associated pks
116
- when the object is refreshed.
117
-
118
- * The :collate column option when adding columns now literalizes
119
- non-String values on PostgreSQL. Previously, the :collate option
120
- value was used verbatim. This is because PostgreSQL's collations
121
- generally require quoting as they are uppercase or mixed-case.
122
-
123
- * Sequel's metadata parsing methods now support Microsoft SQL Server
124
- 2012+ when used in case sensitive mode.
125
-
126
- * Sequel now recognizes an addition check constraint violation
127
- exception on SQLite.
128
-
129
- * Sequel now recognizes constraint violations when using the
130
- swift/sqlite adapter.
131
-
132
- * Sequel now automatically REORGs tables when altering them in the
133
- jdbc/db2 adapter.
134
-
135
- = Backwards Compatibility
136
-
137
- * Sequel now defaults to ignoring NULL values when using IN/NOT IN
138
- with an empty array. Previously, code such as:
139
-
140
- DB[:table].where(:column=>[])
141
-
142
- would be literalized as:
143
-
144
- SELECT * FROM table WHERE (column != column)
145
-
146
- This yields a NULL value when column is NULL, similarly to how most
147
- other SQL operators work. Unfortunately, most databases do not
148
- optimize this, and such a query can require a sequential scan of the
149
- table.
150
-
151
- Sequel previously shipped with a empty_array_ignore_nulls extension
152
- that literalized the query to:
153
-
154
- SELECT * FROM table WHERE (1 = 0)
155
-
156
- which databases will generally optimize to a constant false value,
157
- resulting in much faster queries. This behavior is now the default.
158
-
159
- Users that desire the previous behavior can use the new
160
- empty_array_consider_nulls extension.
161
-
162
- * The deprecated firebird and informix adapters have been removed.
163
-
164
- * Calling prepare on a prepared statement now raises an exception.
165
- It was supported accidently before, as prepared statements are
166
- dataset instances.
167
-
168
- * Model::DatasetModule#subset now calls Model.subset instead of
169
- the other way around. This makes it possible to modify the
170
- behavior of subset in a plugin.
171
-
172
- * The :collate column option change on PostgreSQL can break code
173
- that used already quoted values in symbols. For example:
174
-
175
- String :column_name, collate=>:'"C"'
176
-
177
- would need to change to:
178
-
179
- String :column_name, collate=>:C
180
- # or
181
- String :column_name, collate=>'"C"'
@@ -1,44 +0,0 @@
1
- = New Features
2
-
3
- * Add Dataset#grouping_sets to support GROUP BY GROUPING SETS on
4
- PostgreSQL 9.5+, MSSQL 2008+, Oracle, DB2, and SQLAnywhere:
5
-
6
- DB[:test].group([:type_id, :b], :type_id, []).grouping_sets
7
- # SELECT * FROM test
8
- # GROUP BY GROUPING SETS((type_id, b), (type_id), ())
9
-
10
- * Sequel::NoMatchingRow exceptions raised by Sequel now give access
11
- to the dataset that raised the exception via the dataset method.
12
- This makes it easier to write generic error handling code.
13
-
14
- * Support :if_exists option to drop_column on PostgreSQL:
15
-
16
- DB.drop_column :t, :col, :if_exists=>true
17
- ALTER TABLE t DROP COLUMN IF EXISTS col
18
-
19
- = Other Improvements
20
-
21
- * Make the class_table_inheritance plugin work correctly without an
22
- sti_key. This was broken in a recent refactoring to make class
23
- table inheritance support multiple classes for a single table.
24
-
25
- * Make Class.new(ModelClass){set_dataset :table} work correctly on
26
- ruby 1.8. This was broken in a refactoring to allow the
27
- singular_table_names plugin to work.
28
-
29
- * Make offset emulation via ROW_NUMBER better handle ambiguous column
30
- names for datasets without an ORDER BY clause, but with an explicit
31
- SELECT clause.
32
-
33
- * Make pg_range extension use PostgreSQL range function constructors
34
- instead of casting string literals to the appropriate range type,
35
- if the range type is known. This allows arbitrary expressions to
36
- be used inside ranges, such as CURRENT_TIMESTAMP in timestamp
37
- ranges.
38
-
39
- * Make Dataset#== not consider frozen status.
40
-
41
- * Allow Dataset#prepare on already prepared statements in situations
42
- where determining the SQL for a prepared statement requires it.
43
-
44
- * Detect additional disconnect errors when using the tinytds adapter.
@@ -1,78 +0,0 @@
1
- = New Features
2
-
3
- * A before_after_save plugin has been added, which for newly
4
- created objects refreshes the object before calling after_create,
5
- and resets the modified flag before calling after_update.
6
- Previously, these actions were not taken until after after_save
7
- was called. This will be the default behavior in Sequel 5.
8
-
9
- * In create_table blocks, primary_key now supports a :keep_order
10
- option, which will not change the order in which the primary key
11
- is added. Without this option, Sequel's historical behavior of
12
- making the primary key column the first column is used.
13
-
14
- DB.create_table(:foo) do
15
- Integer :a
16
- primary_key :b, :keep_order=>true
17
- end
18
- # CREATE TABLE foo
19
- # (a integer, b integer PRIMARY KEY AUTOINCREMENT)
20
-
21
- The schema dumper now uses this option if necessary, allowing it
22
- to correctly dump tables where the primary key column is not the
23
- first column.
24
-
25
- * Dataset#single_record! and #single_value! have been added. These
26
- are faster versions of #single_record and #single_value that
27
- don't require cloning the dataset. If you are sure the dataset
28
- will only return a single row or a single value, you can use
29
- these methods for better performance.
30
-
31
- * The new jsonb and json functions added in PostgreSQL 9.5 are now
32
- supported by the pg_json_ops extension.
33
-
34
- Sequel.pg_jsonb_op(:metadata).set(%w'a b', [1,2,3])
35
- # jsonb_set("metadata", ARRAY['a','b'], '[1,2,3]'::jsonb, true)
36
-
37
- = Other Improvements
38
-
39
- * Sequel.synchronize is no longer a stub on MRI. Testing has shown
40
- that relying on the global interpreter lock to protect
41
- multi-threaded access to hashes is not safe in all environments,
42
- so Sequel now uses a mutex on MRI just as it does on other ruby
43
- interpreters.
44
-
45
- * Database#schema now sets the :auto_increment option correctly for
46
- auto incrementing primary keys if they are not the first column
47
- in the table.
48
-
49
- * Dataset#single_value and #with_sql_single_value are now slightly
50
- faster by avoiding an array allocation.
51
-
52
- * Model datasets can now use #with_sql_single_value and return a
53
- single value, instead of an array in [:column_name, value] format.
54
-
55
- * Model#persisted? in the active_model plugin will now return false
56
- if the transaction that inserts the row for the object is rolled
57
- back.
58
-
59
- * bin/sequel now warns if additional arguments are passed that it
60
- ignores. In Sequel 5, bin/sequel will raise an error in these
61
- cases.
62
-
63
- * Database#foreign_key_list on PostgreSQL now returns referenced
64
- composite keys in the correct order.
65
-
66
- * The postgres adapter now works with postgres-pr 0.7.0. Note that
67
- postgres adapter users that want a pure-ruby driver are encouraged
68
- to use jeremyevans-postgres-pr as that has many additional bugfixes
69
- and is the version tested with Sequel on a regular basis.
70
-
71
- * The jdbc/postgresql adapter now recognizes an additional disconnect
72
- error.
73
-
74
- = Backwards Compatibility
75
-
76
- * Users who were relying on #with_sql_single_value returning an array
77
- instead of a single value for model datasets need to update their
78
- code.
@@ -1,57 +0,0 @@
1
- = New Features
2
-
3
- * A subset_conditions plugin has been added, which adds a method
4
- for each subset that returns the filter conditions for the
5
- subset. This makes it easier to reuse the subset conditions:
6
-
7
- class Foo < Sequel::Model
8
- plugin :subset_conditions
9
- subset :active, :active=>true
10
- end
11
-
12
- Foo.exclude(Foo.active_conditions)
13
- Foo.where(:a=>1).or(Foo.active_conditions)
14
-
15
- * A boolean_subsets plugin has been added, which adds a subset for each
16
- boolean column:
17
-
18
- # Assume boolean column :active
19
- Foo.plugin :boolean_subsets
20
-
21
- Foo.active
22
- # SELECT * FROM foos WHERE (active IS TRUE)
23
-
24
- You can provide a block to the plugin to change the arguments passed
25
- to subset:
26
-
27
- Foo.plugin :boolean_subsets do |column|
28
- [:"where_#{column}", column]
29
- end
30
-
31
- Foo.where_active
32
- # SELECT * FROM foos WHERE active
33
-
34
- As with similar plugins, you can add the boolean_subsets plugin to
35
- Sequel::Model itself, and all subclasses created afterward will have
36
- the boolean subset methods automatically created.
37
-
38
- = Other Improvements
39
-
40
- * If Model#refresh can't find the related row, Sequel now raises a
41
- Sequel::NoExistingObject exception instead of a generic
42
- Sequel::Error exception.
43
-
44
- * In the csv_serializer plugin, when calling #to_csv on a model class
45
- or dataset, instead of using #[] to access data, #send is used to
46
- call methods. This is more similar to other plugins as well as
47
- Model#to_csv.
48
-
49
- * The list plugin now works better with the auto_validations plugin,
50
- or any other time there is a validation on the position column.
51
-
52
- = Backwards Compatibility
53
-
54
- * The change to the csv_serializer plugin can change results if you
55
- are overriding any of the column accessor methods. It can also
56
- break existing code if one of the columns being used isn't defined
57
- as a method or the method requires more than one argument.
@@ -1,41 +0,0 @@
1
- = New Features
2
-
3
- * A uuid plugin has now been added. This plugin will automatically
4
- create a uuid for newly created model objects.
5
-
6
- Model.plugin :uuid
7
- Model.create.uuid => # some UUID
8
-
9
- * Model#json_serializer_opts has been added to the json_serializer
10
- plugin, allowing you to override the JSON serialization options
11
- on a per instance basis without passing the options directly
12
- to Model#to_json. This is useful if you are including the model
13
- instance inside another datastructure that will be serialized
14
- to JSON.
15
-
16
- obj.json_serializer_opts(:root => true)
17
- [obj].to_json
18
- # => '[{"obj":{"id":1,"name":"Foo"}}]'
19
-
20
- = Other Improvements
21
-
22
- * The Database#transaction :retry_on option now works when using
23
- savepoints.
24
-
25
- * Calling Database#table_exists? inside a transaction will now use
26
- a savepoint if the database supports it, so that if the table
27
- doesn't exist, it will not affect the state of the transaction.
28
-
29
- * Blobs can now be used as bound variables in the oracle adapter.
30
-
31
- * The sqlanywhere adapter now works with database sharding.
32
-
33
- * The Dataset#full_text_search :rank option has been fixed to order
34
- by rank descending instead of ascending.
35
-
36
- * External adapters that do not support INSERT with DEFAULT VALUES
37
- can now override Dataset#insert_empty_columns_values to set
38
- the columns and values to use for an empty INSERT.
39
-
40
- * External adapters can now implement Dataset#date_add_sql_append
41
- to integrate with the date_arithmetic extension.
@@ -1,40 +0,0 @@
1
- = New Features
2
-
3
- * The tree and rcte_tree plugins now support composite keys.
4
-
5
- * An error_sql Database extension has been added. This extension
6
- adds the DatabaseError#sql method, which should return the
7
- database query that caused the error. This is useful for
8
- drivers that don't include the SQL used as part of the error
9
- message.
10
-
11
- = Other Improvements
12
-
13
- * Empty blobs are now literalized correctly on MySQL.
14
-
15
- * Empty arrays are now literalized correctly on PostgreSQL <8.4.
16
-
17
- * In the pagination extension, Dataset#page_count is now 1 even if
18
- the dataset is empty. This fixes issues with last_page? and
19
- page_range returning bad values for empty datasets.
20
-
21
- * In the pagination extension, calling Dataset#each_page without a
22
- block now returns an Enumerator.
23
-
24
- * Dataset#qualify and Sequel.delay now work together, qualifying
25
- the object returned by the delayed evaluation.
26
-
27
- * Migrator.migrator_class is now a public method.
28
-
29
- * The PostgreSQL citext type is now recognized as a string.
30
-
31
- * Another disconnect error is now recognized in the jdbc/as400
32
- adapter.
33
-
34
- * Guides about using and creating Sequel extensions and model
35
- plugins have been added.
36
-
37
- = Backwards Compatibility
38
-
39
- * If you were expecting Dataset#page_count on a empty paginated
40
- dataset to return 0, you need to update your code.
@@ -1,37 +0,0 @@
1
- = New Features
2
-
3
- * Overriding the :limit and :eager_limit_strategy association options
4
- can now be done on a per-call basis when eager loading, by using an
5
- eager block callback and setting the :eager_limit or
6
- :eager_limit_strategy dataset options. Example:
7
-
8
- Album.eager(:tracks=>proc{|ds| ds.clone(:eager_limit=>5)}).all
9
-
10
- * Dataset#insert_conflict and #insert_ignore have been added on
11
- SQLite, adding support for the INSERT OR ... SQL syntax:
12
-
13
- DB[:table].insert_ignore.insert(:a=>1, :b=>2)
14
- # INSERT OR IGNORE INTO TABLE (a, b) VALUES (1, 2)
15
-
16
- DB[:table].insert_conflict(:replace).insert(:a=>1, :b=>2)
17
- # INSERT OR REPLACE INTO TABLE (a, b) VALUES (1, 2)
18
-
19
- * An identifier_columns plugin has been added, which allows
20
- Sequel::Model#save to work when column names contain double
21
- underscores.
22
-
23
- = Other Improvements
24
-
25
- * IPv6 addresses can now be used in connection URLs when using
26
- ruby 1.9.3+.
27
-
28
- * The :db_type entries in column schema hashes now include sizes
29
- for string and decimal types on DB2 and when using the jdbc
30
- adapter's generic schema parsing.
31
-
32
- * Database#row_type in the pg_row extension now handles different
33
- formats of specifying schema qualified types. So a row type
34
- registered via :schema__type can be found using
35
- Sequel.qualify(:schema, :type).
36
-
37
- * Another disconnect error is recognized in the tinytds adapter.