sequel 5.8.0 → 5.38.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 (510) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG +409 -1795
  3. data/MIT-LICENSE +1 -1
  4. data/README.rdoc +4 -4
  5. data/bin/sequel +4 -0
  6. data/doc/advanced_associations.rdoc +136 -18
  7. data/doc/association_basics.rdoc +10 -5
  8. data/doc/cheat_sheet.rdoc +1 -0
  9. data/doc/code_order.rdoc +12 -2
  10. data/doc/dataset_filtering.rdoc +17 -2
  11. data/doc/mass_assignment.rdoc +3 -3
  12. data/doc/model_dataset_method_design.rdoc +1 -1
  13. data/doc/model_plugins.rdoc +1 -1
  14. data/doc/opening_databases.rdoc +30 -8
  15. data/doc/postgresql.rdoc +107 -2
  16. data/doc/release_notes/5.10.0.txt +84 -0
  17. data/doc/release_notes/5.11.0.txt +83 -0
  18. data/doc/release_notes/5.12.0.txt +141 -0
  19. data/doc/release_notes/5.13.0.txt +27 -0
  20. data/doc/release_notes/5.14.0.txt +63 -0
  21. data/doc/release_notes/5.15.0.txt +39 -0
  22. data/doc/release_notes/5.16.0.txt +110 -0
  23. data/doc/release_notes/5.17.0.txt +31 -0
  24. data/doc/release_notes/5.18.0.txt +69 -0
  25. data/doc/release_notes/5.19.0.txt +28 -0
  26. data/doc/release_notes/5.20.0.txt +89 -0
  27. data/doc/release_notes/5.21.0.txt +87 -0
  28. data/doc/release_notes/5.22.0.txt +48 -0
  29. data/doc/release_notes/5.23.0.txt +56 -0
  30. data/doc/release_notes/5.24.0.txt +56 -0
  31. data/doc/release_notes/5.25.0.txt +32 -0
  32. data/doc/release_notes/5.26.0.txt +35 -0
  33. data/doc/release_notes/5.27.0.txt +21 -0
  34. data/doc/release_notes/5.28.0.txt +16 -0
  35. data/doc/release_notes/5.29.0.txt +22 -0
  36. data/doc/release_notes/5.30.0.txt +20 -0
  37. data/doc/release_notes/5.31.0.txt +148 -0
  38. data/doc/release_notes/5.32.0.txt +46 -0
  39. data/doc/release_notes/5.33.0.txt +24 -0
  40. data/doc/release_notes/5.34.0.txt +40 -0
  41. data/doc/release_notes/5.35.0.txt +56 -0
  42. data/doc/release_notes/5.36.0.txt +60 -0
  43. data/doc/release_notes/5.37.0.txt +30 -0
  44. data/doc/release_notes/5.38.0.txt +28 -0
  45. data/doc/release_notes/5.9.0.txt +99 -0
  46. data/doc/security.rdoc +10 -0
  47. data/doc/sharding.rdoc +42 -28
  48. data/doc/sql.rdoc +12 -0
  49. data/doc/testing.rdoc +24 -17
  50. data/doc/transactions.rdoc +78 -0
  51. data/doc/validations.rdoc +2 -2
  52. data/lib/sequel/adapters/ado.rb +26 -18
  53. data/lib/sequel/adapters/ado/access.rb +2 -2
  54. data/lib/sequel/adapters/ado/mssql.rb +5 -8
  55. data/lib/sequel/adapters/amalgalite.rb +1 -1
  56. data/lib/sequel/adapters/jdbc.rb +71 -27
  57. data/lib/sequel/adapters/jdbc/mysql.rb +6 -6
  58. data/lib/sequel/adapters/jdbc/oracle.rb +7 -6
  59. data/lib/sequel/adapters/jdbc/postgresql.rb +17 -28
  60. data/lib/sequel/adapters/jdbc/sqlanywhere.rb +5 -6
  61. data/lib/sequel/adapters/jdbc/sqlite.rb +33 -2
  62. data/lib/sequel/adapters/jdbc/sqlserver.rb +4 -3
  63. data/lib/sequel/adapters/jdbc/transactions.rb +14 -28
  64. data/lib/sequel/adapters/mysql.rb +14 -15
  65. data/lib/sequel/adapters/mysql2.rb +5 -3
  66. data/lib/sequel/adapters/odbc.rb +4 -6
  67. data/lib/sequel/adapters/oracle.rb +7 -7
  68. data/lib/sequel/adapters/postgres.rb +52 -16
  69. data/lib/sequel/adapters/shared/access.rb +16 -12
  70. data/lib/sequel/adapters/shared/db2.rb +5 -0
  71. data/lib/sequel/adapters/shared/mssql.rb +41 -18
  72. data/lib/sequel/adapters/shared/mysql.rb +66 -19
  73. data/lib/sequel/adapters/shared/oracle.rb +29 -23
  74. data/lib/sequel/adapters/shared/postgres.rb +341 -95
  75. data/lib/sequel/adapters/shared/sqlanywhere.rb +23 -10
  76. data/lib/sequel/adapters/shared/sqlite.rb +174 -21
  77. data/lib/sequel/adapters/sqlanywhere.rb +33 -17
  78. data/lib/sequel/adapters/sqlite.rb +78 -68
  79. data/lib/sequel/adapters/tinytds.rb +14 -6
  80. data/lib/sequel/adapters/utils/emulate_offset_with_reverse_and_count.rb +2 -5
  81. data/lib/sequel/adapters/utils/mysql_mysql2.rb +5 -1
  82. data/lib/sequel/connection_pool.rb +2 -6
  83. data/lib/sequel/connection_pool/sharded_single.rb +7 -4
  84. data/lib/sequel/connection_pool/sharded_threaded.rb +32 -21
  85. data/lib/sequel/connection_pool/single.rb +1 -1
  86. data/lib/sequel/connection_pool/threaded.rb +26 -11
  87. data/lib/sequel/core.rb +327 -319
  88. data/lib/sequel/database/connecting.rb +7 -8
  89. data/lib/sequel/database/logging.rb +7 -1
  90. data/lib/sequel/database/misc.rb +68 -34
  91. data/lib/sequel/database/query.rb +6 -4
  92. data/lib/sequel/database/schema_generator.rb +31 -11
  93. data/lib/sequel/database/schema_methods.rb +32 -22
  94. data/lib/sequel/database/transactions.rb +129 -25
  95. data/lib/sequel/dataset.rb +4 -2
  96. data/lib/sequel/dataset/actions.rb +34 -23
  97. data/lib/sequel/dataset/features.rb +34 -0
  98. data/lib/sequel/dataset/graph.rb +27 -11
  99. data/lib/sequel/dataset/misc.rb +17 -3
  100. data/lib/sequel/dataset/placeholder_literalizer.rb +50 -21
  101. data/lib/sequel/dataset/prepared_statements.rb +96 -26
  102. data/lib/sequel/dataset/query.rb +43 -8
  103. data/lib/sequel/dataset/sql.rb +189 -41
  104. data/lib/sequel/deprecated.rb +3 -1
  105. data/lib/sequel/exceptions.rb +2 -0
  106. data/lib/sequel/extensions/_pretty_table.rb +1 -2
  107. data/lib/sequel/extensions/any_not_empty.rb +45 -0
  108. data/lib/sequel/extensions/caller_logging.rb +79 -0
  109. data/lib/sequel/extensions/columns_introspection.rb +1 -2
  110. data/lib/sequel/extensions/connection_expiration.rb +6 -6
  111. data/lib/sequel/extensions/connection_validator.rb +7 -6
  112. data/lib/sequel/extensions/constant_sql_override.rb +65 -0
  113. data/lib/sequel/extensions/constraint_validations.rb +53 -28
  114. data/lib/sequel/extensions/core_refinements.rb +2 -0
  115. data/lib/sequel/extensions/duplicate_columns_handler.rb +2 -0
  116. data/lib/sequel/extensions/escaped_like.rb +100 -0
  117. data/lib/sequel/extensions/eval_inspect.rb +3 -1
  118. data/lib/sequel/extensions/exclude_or_null.rb +68 -0
  119. data/lib/sequel/extensions/fiber_concurrency.rb +24 -0
  120. data/lib/sequel/extensions/index_caching.rb +9 -7
  121. data/lib/sequel/extensions/integer64.rb +3 -1
  122. data/lib/sequel/extensions/looser_typecasting.rb +3 -3
  123. data/lib/sequel/extensions/migration.rb +13 -6
  124. data/lib/sequel/extensions/named_timezones.rb +84 -23
  125. data/lib/sequel/extensions/pg_array.rb +87 -79
  126. data/lib/sequel/extensions/pg_array_ops.rb +14 -6
  127. data/lib/sequel/extensions/pg_enum.rb +34 -18
  128. data/lib/sequel/extensions/pg_extended_date_support.rb +34 -14
  129. data/lib/sequel/extensions/pg_hstore.rb +6 -0
  130. data/lib/sequel/extensions/pg_hstore_ops.rb +2 -0
  131. data/lib/sequel/extensions/pg_inet.rb +15 -5
  132. data/lib/sequel/extensions/pg_interval.rb +2 -0
  133. data/lib/sequel/extensions/pg_json.rb +387 -123
  134. data/lib/sequel/extensions/pg_json_ops.rb +168 -0
  135. data/lib/sequel/extensions/pg_range.rb +20 -10
  136. data/lib/sequel/extensions/pg_range_ops.rb +2 -0
  137. data/lib/sequel/extensions/pg_row.rb +3 -2
  138. data/lib/sequel/extensions/pg_row_ops.rb +24 -0
  139. data/lib/sequel/extensions/pg_static_cache_updater.rb +2 -2
  140. data/lib/sequel/extensions/pg_timestamptz.rb +2 -0
  141. data/lib/sequel/extensions/query.rb +1 -0
  142. data/lib/sequel/extensions/run_transaction_hooks.rb +72 -0
  143. data/lib/sequel/extensions/s.rb +2 -0
  144. data/lib/sequel/extensions/schema_dumper.rb +13 -7
  145. data/lib/sequel/extensions/sequel_4_dataset_methods.rb +4 -2
  146. data/lib/sequel/extensions/server_block.rb +18 -7
  147. data/lib/sequel/extensions/sql_comments.rb +2 -2
  148. data/lib/sequel/extensions/symbol_aref_refinement.rb +2 -0
  149. data/lib/sequel/extensions/symbol_as_refinement.rb +2 -0
  150. data/lib/sequel/extensions/to_dot.rb +9 -3
  151. data/lib/sequel/model.rb +3 -1
  152. data/lib/sequel/model/associations.rb +403 -69
  153. data/lib/sequel/model/base.rb +170 -90
  154. data/lib/sequel/model/plugins.rb +105 -0
  155. data/lib/sequel/plugins/after_initialize.rb +1 -1
  156. data/lib/sequel/plugins/association_dependencies.rb +3 -3
  157. data/lib/sequel/plugins/association_lazy_eager_option.rb +66 -0
  158. data/lib/sequel/plugins/association_multi_add_remove.rb +85 -0
  159. data/lib/sequel/plugins/association_pks.rb +74 -22
  160. data/lib/sequel/plugins/association_proxies.rb +6 -2
  161. data/lib/sequel/plugins/auto_validations.rb +36 -17
  162. data/lib/sequel/plugins/blacklist_security.rb +1 -2
  163. data/lib/sequel/plugins/boolean_subsets.rb +4 -1
  164. data/lib/sequel/plugins/caching.rb +3 -0
  165. data/lib/sequel/plugins/class_table_inheritance.rb +62 -34
  166. data/lib/sequel/plugins/composition.rb +13 -9
  167. data/lib/sequel/plugins/csv_serializer.rb +28 -9
  168. data/lib/sequel/plugins/defaults_setter.rb +2 -2
  169. data/lib/sequel/plugins/dirty.rb +60 -22
  170. data/lib/sequel/plugins/eager_graph_eager.rb +139 -0
  171. data/lib/sequel/plugins/empty_failure_backtraces.rb +38 -0
  172. data/lib/sequel/plugins/finder.rb +2 -2
  173. data/lib/sequel/plugins/forbid_lazy_load.rb +216 -0
  174. data/lib/sequel/plugins/hook_class_methods.rb +17 -5
  175. data/lib/sequel/plugins/insert_conflict.rb +72 -0
  176. data/lib/sequel/plugins/instance_specific_default.rb +113 -0
  177. data/lib/sequel/plugins/inverted_subsets.rb +2 -2
  178. data/lib/sequel/plugins/json_serializer.rb +21 -14
  179. data/lib/sequel/plugins/lazy_attributes.rb +1 -1
  180. data/lib/sequel/plugins/list.rb +22 -10
  181. data/lib/sequel/plugins/many_through_many.rb +1 -1
  182. data/lib/sequel/plugins/nested_attributes.rb +27 -5
  183. data/lib/sequel/plugins/pg_array_associations.rb +12 -9
  184. data/lib/sequel/plugins/pg_auto_constraint_validations.rb +149 -61
  185. data/lib/sequel/plugins/prepared_statements.rb +6 -12
  186. data/lib/sequel/plugins/prepared_statements_safe.rb +1 -3
  187. data/lib/sequel/plugins/rcte_tree.rb +20 -22
  188. data/lib/sequel/plugins/sharding.rb +13 -7
  189. data/lib/sequel/plugins/single_table_inheritance.rb +20 -15
  190. data/lib/sequel/plugins/skip_saving_columns.rb +108 -0
  191. data/lib/sequel/plugins/static_cache.rb +36 -17
  192. data/lib/sequel/plugins/static_cache_cache.rb +53 -0
  193. data/lib/sequel/plugins/string_stripper.rb +1 -1
  194. data/lib/sequel/plugins/subclasses.rb +2 -0
  195. data/lib/sequel/plugins/subset_conditions.rb +2 -2
  196. data/lib/sequel/plugins/tactical_eager_loading.rb +73 -2
  197. data/lib/sequel/plugins/throw_failures.rb +110 -0
  198. data/lib/sequel/plugins/tree.rb +49 -31
  199. data/lib/sequel/plugins/typecast_on_load.rb +3 -2
  200. data/lib/sequel/plugins/validation_class_methods.rb +11 -5
  201. data/lib/sequel/plugins/validation_helpers.rb +2 -2
  202. data/lib/sequel/sql.rb +120 -30
  203. data/lib/sequel/timezones.rb +55 -14
  204. data/lib/sequel/version.rb +6 -1
  205. metadata +101 -361
  206. data/Rakefile +0 -151
  207. data/doc/release_notes/4.0.0.txt +0 -262
  208. data/doc/release_notes/4.1.0.txt +0 -85
  209. data/doc/release_notes/4.10.0.txt +0 -226
  210. data/doc/release_notes/4.11.0.txt +0 -147
  211. data/doc/release_notes/4.12.0.txt +0 -105
  212. data/doc/release_notes/4.13.0.txt +0 -169
  213. data/doc/release_notes/4.14.0.txt +0 -68
  214. data/doc/release_notes/4.15.0.txt +0 -56
  215. data/doc/release_notes/4.16.0.txt +0 -36
  216. data/doc/release_notes/4.17.0.txt +0 -38
  217. data/doc/release_notes/4.18.0.txt +0 -36
  218. data/doc/release_notes/4.19.0.txt +0 -45
  219. data/doc/release_notes/4.2.0.txt +0 -129
  220. data/doc/release_notes/4.20.0.txt +0 -79
  221. data/doc/release_notes/4.21.0.txt +0 -94
  222. data/doc/release_notes/4.22.0.txt +0 -72
  223. data/doc/release_notes/4.23.0.txt +0 -65
  224. data/doc/release_notes/4.24.0.txt +0 -99
  225. data/doc/release_notes/4.25.0.txt +0 -181
  226. data/doc/release_notes/4.26.0.txt +0 -44
  227. data/doc/release_notes/4.27.0.txt +0 -78
  228. data/doc/release_notes/4.28.0.txt +0 -57
  229. data/doc/release_notes/4.29.0.txt +0 -41
  230. data/doc/release_notes/4.3.0.txt +0 -40
  231. data/doc/release_notes/4.30.0.txt +0 -37
  232. data/doc/release_notes/4.31.0.txt +0 -57
  233. data/doc/release_notes/4.32.0.txt +0 -132
  234. data/doc/release_notes/4.33.0.txt +0 -88
  235. data/doc/release_notes/4.34.0.txt +0 -86
  236. data/doc/release_notes/4.35.0.txt +0 -130
  237. data/doc/release_notes/4.36.0.txt +0 -116
  238. data/doc/release_notes/4.37.0.txt +0 -50
  239. data/doc/release_notes/4.38.0.txt +0 -67
  240. data/doc/release_notes/4.39.0.txt +0 -127
  241. data/doc/release_notes/4.4.0.txt +0 -92
  242. data/doc/release_notes/4.40.0.txt +0 -179
  243. data/doc/release_notes/4.41.0.txt +0 -77
  244. data/doc/release_notes/4.42.0.txt +0 -221
  245. data/doc/release_notes/4.43.0.txt +0 -87
  246. data/doc/release_notes/4.44.0.txt +0 -125
  247. data/doc/release_notes/4.45.0.txt +0 -370
  248. data/doc/release_notes/4.46.0.txt +0 -404
  249. data/doc/release_notes/4.47.0.txt +0 -56
  250. data/doc/release_notes/4.48.0.txt +0 -293
  251. data/doc/release_notes/4.49.0.txt +0 -222
  252. data/doc/release_notes/4.5.0.txt +0 -34
  253. data/doc/release_notes/4.6.0.txt +0 -30
  254. data/doc/release_notes/4.7.0.txt +0 -103
  255. data/doc/release_notes/4.8.0.txt +0 -175
  256. data/doc/release_notes/4.9.0.txt +0 -190
  257. data/spec/adapter_spec.rb +0 -4
  258. data/spec/adapters/db2_spec.rb +0 -170
  259. data/spec/adapters/mssql_spec.rb +0 -804
  260. data/spec/adapters/mysql_spec.rb +0 -1041
  261. data/spec/adapters/oracle_spec.rb +0 -327
  262. data/spec/adapters/postgres_spec.rb +0 -4000
  263. data/spec/adapters/spec_helper.rb +0 -43
  264. data/spec/adapters/sqlanywhere_spec.rb +0 -97
  265. data/spec/adapters/sqlite_spec.rb +0 -600
  266. data/spec/bin_spec.rb +0 -269
  267. data/spec/core/connection_pool_spec.rb +0 -1228
  268. data/spec/core/database_spec.rb +0 -2673
  269. data/spec/core/dataset_spec.rb +0 -5419
  270. data/spec/core/deprecated_spec.rb +0 -70
  271. data/spec/core/expression_filters_spec.rb +0 -1344
  272. data/spec/core/mock_adapter_spec.rb +0 -722
  273. data/spec/core/object_graph_spec.rb +0 -306
  274. data/spec/core/placeholder_literalizer_spec.rb +0 -166
  275. data/spec/core/schema_generator_spec.rb +0 -214
  276. data/spec/core/schema_spec.rb +0 -1820
  277. data/spec/core/spec_helper.rb +0 -23
  278. data/spec/core/version_spec.rb +0 -7
  279. data/spec/core_extensions_spec.rb +0 -762
  280. data/spec/core_model_spec.rb +0 -2
  281. data/spec/core_spec.rb +0 -1
  282. data/spec/deprecation_helper.rb +0 -30
  283. data/spec/extensions/accessed_columns_spec.rb +0 -51
  284. data/spec/extensions/active_model_spec.rb +0 -99
  285. data/spec/extensions/after_initialize_spec.rb +0 -24
  286. data/spec/extensions/arbitrary_servers_spec.rb +0 -109
  287. data/spec/extensions/association_dependencies_spec.rb +0 -125
  288. data/spec/extensions/association_pks_spec.rb +0 -423
  289. data/spec/extensions/association_proxies_spec.rb +0 -100
  290. data/spec/extensions/auto_literal_strings_spec.rb +0 -205
  291. data/spec/extensions/auto_validations_spec.rb +0 -202
  292. data/spec/extensions/blacklist_security_spec.rb +0 -95
  293. data/spec/extensions/blank_spec.rb +0 -69
  294. data/spec/extensions/boolean_readers_spec.rb +0 -93
  295. data/spec/extensions/boolean_subsets_spec.rb +0 -47
  296. data/spec/extensions/caching_spec.rb +0 -273
  297. data/spec/extensions/class_table_inheritance_spec.rb +0 -568
  298. data/spec/extensions/column_conflicts_spec.rb +0 -75
  299. data/spec/extensions/column_select_spec.rb +0 -129
  300. data/spec/extensions/columns_introspection_spec.rb +0 -90
  301. data/spec/extensions/columns_updated_spec.rb +0 -35
  302. data/spec/extensions/composition_spec.rb +0 -248
  303. data/spec/extensions/connection_expiration_spec.rb +0 -133
  304. data/spec/extensions/connection_validator_spec.rb +0 -127
  305. data/spec/extensions/constraint_validations_plugin_spec.rb +0 -300
  306. data/spec/extensions/constraint_validations_spec.rb +0 -395
  307. data/spec/extensions/core_refinements_spec.rb +0 -528
  308. data/spec/extensions/csv_serializer_spec.rb +0 -183
  309. data/spec/extensions/current_datetime_timestamp_spec.rb +0 -27
  310. data/spec/extensions/dataset_associations_spec.rb +0 -365
  311. data/spec/extensions/dataset_source_alias_spec.rb +0 -51
  312. data/spec/extensions/date_arithmetic_spec.rb +0 -181
  313. data/spec/extensions/datetime_parse_to_time_spec.rb +0 -169
  314. data/spec/extensions/def_dataset_method_spec.rb +0 -100
  315. data/spec/extensions/defaults_setter_spec.rb +0 -141
  316. data/spec/extensions/delay_add_association_spec.rb +0 -73
  317. data/spec/extensions/dirty_spec.rb +0 -189
  318. data/spec/extensions/duplicate_columns_handler_spec.rb +0 -104
  319. data/spec/extensions/eager_each_spec.rb +0 -62
  320. data/spec/extensions/empty_array_consider_nulls_spec.rb +0 -24
  321. data/spec/extensions/error_splitter_spec.rb +0 -18
  322. data/spec/extensions/error_sql_spec.rb +0 -20
  323. data/spec/extensions/eval_inspect_spec.rb +0 -74
  324. data/spec/extensions/finder_spec.rb +0 -260
  325. data/spec/extensions/force_encoding_spec.rb +0 -126
  326. data/spec/extensions/freeze_datasets_spec.rb +0 -31
  327. data/spec/extensions/graph_each_spec.rb +0 -113
  328. data/spec/extensions/hook_class_methods_spec.rb +0 -380
  329. data/spec/extensions/identifier_mangling_spec.rb +0 -201
  330. data/spec/extensions/implicit_subquery_spec.rb +0 -58
  331. data/spec/extensions/index_caching_spec.rb +0 -66
  332. data/spec/extensions/inflector_spec.rb +0 -183
  333. data/spec/extensions/input_transformer_spec.rb +0 -69
  334. data/spec/extensions/insert_returning_select_spec.rb +0 -72
  335. data/spec/extensions/instance_filters_spec.rb +0 -79
  336. data/spec/extensions/instance_hooks_spec.rb +0 -246
  337. data/spec/extensions/integer64_spec.rb +0 -22
  338. data/spec/extensions/inverted_subsets_spec.rb +0 -33
  339. data/spec/extensions/json_serializer_spec.rb +0 -336
  340. data/spec/extensions/lazy_attributes_spec.rb +0 -183
  341. data/spec/extensions/list_spec.rb +0 -275
  342. data/spec/extensions/looser_typecasting_spec.rb +0 -43
  343. data/spec/extensions/many_through_many_spec.rb +0 -2177
  344. data/spec/extensions/migration_spec.rb +0 -840
  345. data/spec/extensions/modification_detection_spec.rb +0 -93
  346. data/spec/extensions/mssql_optimistic_locking_spec.rb +0 -92
  347. data/spec/extensions/named_timezones_spec.rb +0 -109
  348. data/spec/extensions/nested_attributes_spec.rb +0 -703
  349. data/spec/extensions/null_dataset_spec.rb +0 -85
  350. data/spec/extensions/optimistic_locking_spec.rb +0 -127
  351. data/spec/extensions/pagination_spec.rb +0 -116
  352. data/spec/extensions/pg_array_associations_spec.rb +0 -802
  353. data/spec/extensions/pg_array_ops_spec.rb +0 -144
  354. data/spec/extensions/pg_array_spec.rb +0 -398
  355. data/spec/extensions/pg_auto_constraint_validations_spec.rb +0 -165
  356. data/spec/extensions/pg_enum_spec.rb +0 -113
  357. data/spec/extensions/pg_extended_date_support_spec.rb +0 -126
  358. data/spec/extensions/pg_hstore_ops_spec.rb +0 -238
  359. data/spec/extensions/pg_hstore_spec.rb +0 -219
  360. data/spec/extensions/pg_inet_ops_spec.rb +0 -102
  361. data/spec/extensions/pg_inet_spec.rb +0 -72
  362. data/spec/extensions/pg_interval_spec.rb +0 -103
  363. data/spec/extensions/pg_json_ops_spec.rb +0 -289
  364. data/spec/extensions/pg_json_spec.rb +0 -262
  365. data/spec/extensions/pg_loose_count_spec.rb +0 -23
  366. data/spec/extensions/pg_range_ops_spec.rb +0 -60
  367. data/spec/extensions/pg_range_spec.rb +0 -487
  368. data/spec/extensions/pg_row_ops_spec.rb +0 -61
  369. data/spec/extensions/pg_row_plugin_spec.rb +0 -60
  370. data/spec/extensions/pg_row_spec.rb +0 -363
  371. data/spec/extensions/pg_static_cache_updater_spec.rb +0 -93
  372. data/spec/extensions/pg_timestamptz_spec.rb +0 -17
  373. data/spec/extensions/prepared_statements_safe_spec.rb +0 -66
  374. data/spec/extensions/prepared_statements_spec.rb +0 -182
  375. data/spec/extensions/pretty_table_spec.rb +0 -123
  376. data/spec/extensions/query_spec.rb +0 -94
  377. data/spec/extensions/rcte_tree_spec.rb +0 -381
  378. data/spec/extensions/round_timestamps_spec.rb +0 -39
  379. data/spec/extensions/s_spec.rb +0 -60
  380. data/spec/extensions/schema_caching_spec.rb +0 -64
  381. data/spec/extensions/schema_dumper_spec.rb +0 -868
  382. data/spec/extensions/select_remove_spec.rb +0 -38
  383. data/spec/extensions/sequel_4_dataset_methods_spec.rb +0 -121
  384. data/spec/extensions/serialization_modification_detection_spec.rb +0 -98
  385. data/spec/extensions/serialization_spec.rb +0 -365
  386. data/spec/extensions/server_block_spec.rb +0 -97
  387. data/spec/extensions/server_logging_spec.rb +0 -45
  388. data/spec/extensions/sharding_spec.rb +0 -189
  389. data/spec/extensions/shared_caching_spec.rb +0 -151
  390. data/spec/extensions/single_table_inheritance_spec.rb +0 -347
  391. data/spec/extensions/singular_table_names_spec.rb +0 -22
  392. data/spec/extensions/skip_create_refresh_spec.rb +0 -18
  393. data/spec/extensions/spec_helper.rb +0 -61
  394. data/spec/extensions/split_array_nil_spec.rb +0 -24
  395. data/spec/extensions/split_values_spec.rb +0 -57
  396. data/spec/extensions/sql_comments_spec.rb +0 -33
  397. data/spec/extensions/sql_expr_spec.rb +0 -59
  398. data/spec/extensions/static_cache_spec.rb +0 -410
  399. data/spec/extensions/string_agg_spec.rb +0 -90
  400. data/spec/extensions/string_date_time_spec.rb +0 -95
  401. data/spec/extensions/string_stripper_spec.rb +0 -68
  402. data/spec/extensions/subclasses_spec.rb +0 -79
  403. data/spec/extensions/subset_conditions_spec.rb +0 -38
  404. data/spec/extensions/symbol_aref_refinement_spec.rb +0 -28
  405. data/spec/extensions/symbol_as_refinement_spec.rb +0 -21
  406. data/spec/extensions/synchronize_sql_spec.rb +0 -124
  407. data/spec/extensions/table_select_spec.rb +0 -83
  408. data/spec/extensions/tactical_eager_loading_spec.rb +0 -141
  409. data/spec/extensions/thread_local_timezones_spec.rb +0 -67
  410. data/spec/extensions/timestamps_spec.rb +0 -209
  411. data/spec/extensions/to_dot_spec.rb +0 -153
  412. data/spec/extensions/touch_spec.rb +0 -226
  413. data/spec/extensions/tree_spec.rb +0 -284
  414. data/spec/extensions/typecast_on_load_spec.rb +0 -86
  415. data/spec/extensions/unlimited_update_spec.rb +0 -21
  416. data/spec/extensions/update_or_create_spec.rb +0 -83
  417. data/spec/extensions/update_primary_key_spec.rb +0 -105
  418. data/spec/extensions/update_refresh_spec.rb +0 -59
  419. data/spec/extensions/uuid_spec.rb +0 -101
  420. data/spec/extensions/validate_associated_spec.rb +0 -52
  421. data/spec/extensions/validation_class_methods_spec.rb +0 -1040
  422. data/spec/extensions/validation_contexts_spec.rb +0 -31
  423. data/spec/extensions/validation_helpers_spec.rb +0 -525
  424. data/spec/extensions/whitelist_security_spec.rb +0 -157
  425. data/spec/extensions/xml_serializer_spec.rb +0 -213
  426. data/spec/files/bad_down_migration/001_create_alt_basic.rb +0 -4
  427. data/spec/files/bad_down_migration/002_create_alt_advanced.rb +0 -4
  428. data/spec/files/bad_timestamped_migrations/1273253849_create_sessions.rb +0 -9
  429. data/spec/files/bad_timestamped_migrations/1273253851_create_nodes.rb +0 -9
  430. data/spec/files/bad_timestamped_migrations/1273253853_3_create_users.rb +0 -3
  431. data/spec/files/bad_up_migration/001_create_alt_basic.rb +0 -4
  432. data/spec/files/bad_up_migration/002_create_alt_advanced.rb +0 -3
  433. data/spec/files/convert_to_timestamp_migrations/001_create_sessions.rb +0 -9
  434. data/spec/files/convert_to_timestamp_migrations/002_create_nodes.rb +0 -9
  435. data/spec/files/convert_to_timestamp_migrations/003_3_create_users.rb +0 -4
  436. data/spec/files/convert_to_timestamp_migrations/1273253850_create_artists.rb +0 -9
  437. data/spec/files/convert_to_timestamp_migrations/1273253852_create_albums.rb +0 -9
  438. data/spec/files/double_migration/001_create_sessions.rb +0 -9
  439. data/spec/files/double_migration/002_create_nodes.rb +0 -19
  440. data/spec/files/double_migration/003_3_create_users.rb +0 -4
  441. data/spec/files/duplicate_integer_migrations/001_create_alt_advanced.rb +0 -4
  442. data/spec/files/duplicate_integer_migrations/001_create_alt_basic.rb +0 -4
  443. data/spec/files/duplicate_timestamped_migrations/1273253849_create_sessions.rb +0 -9
  444. data/spec/files/duplicate_timestamped_migrations/1273253853_create_nodes.rb +0 -9
  445. data/spec/files/duplicate_timestamped_migrations/1273253853_create_users.rb +0 -4
  446. data/spec/files/empty_migration/001_create_sessions.rb +0 -9
  447. data/spec/files/empty_migration/002_create_nodes.rb +0 -0
  448. data/spec/files/empty_migration/003_3_create_users.rb +0 -4
  449. data/spec/files/integer_migrations/001_create_sessions.rb +0 -9
  450. data/spec/files/integer_migrations/002_create_nodes.rb +0 -9
  451. data/spec/files/integer_migrations/003_3_create_users.rb +0 -4
  452. data/spec/files/interleaved_timestamped_migrations/1273253849_create_sessions.rb +0 -9
  453. data/spec/files/interleaved_timestamped_migrations/1273253850_create_artists.rb +0 -9
  454. data/spec/files/interleaved_timestamped_migrations/1273253851_create_nodes.rb +0 -9
  455. data/spec/files/interleaved_timestamped_migrations/1273253852_create_albums.rb +0 -9
  456. data/spec/files/interleaved_timestamped_migrations/1273253853_3_create_users.rb +0 -4
  457. data/spec/files/missing_integer_migrations/001_create_alt_basic.rb +0 -4
  458. data/spec/files/missing_integer_migrations/003_create_alt_advanced.rb +0 -4
  459. data/spec/files/missing_timestamped_migrations/1273253849_create_sessions.rb +0 -9
  460. data/spec/files/missing_timestamped_migrations/1273253853_3_create_users.rb +0 -4
  461. data/spec/files/reversible_migrations/001_reversible.rb +0 -5
  462. data/spec/files/reversible_migrations/002_reversible.rb +0 -5
  463. data/spec/files/reversible_migrations/003_reversible.rb +0 -5
  464. data/spec/files/reversible_migrations/004_reversible.rb +0 -5
  465. data/spec/files/reversible_migrations/005_reversible.rb +0 -10
  466. data/spec/files/reversible_migrations/006_reversible.rb +0 -10
  467. data/spec/files/reversible_migrations/007_reversible.rb +0 -10
  468. data/spec/files/timestamped_migrations/1273253849_create_sessions.rb +0 -9
  469. data/spec/files/timestamped_migrations/1273253851_create_nodes.rb +0 -9
  470. data/spec/files/timestamped_migrations/1273253853_3_create_users.rb +0 -4
  471. data/spec/files/transaction_specified_migrations/001_create_alt_basic.rb +0 -4
  472. data/spec/files/transaction_specified_migrations/002_create_basic.rb +0 -4
  473. data/spec/files/transaction_unspecified_migrations/001_create_alt_basic.rb +0 -3
  474. data/spec/files/transaction_unspecified_migrations/002_create_basic.rb +0 -3
  475. data/spec/files/uppercase_timestamped_migrations/1273253849_CREATE_SESSIONS.RB +0 -9
  476. data/spec/files/uppercase_timestamped_migrations/1273253851_CREATE_NODES.RB +0 -9
  477. data/spec/files/uppercase_timestamped_migrations/1273253853_3_CREATE_USERS.RB +0 -4
  478. data/spec/guards_helper.rb +0 -58
  479. data/spec/integration/associations_test.rb +0 -2513
  480. data/spec/integration/database_test.rb +0 -113
  481. data/spec/integration/dataset_test.rb +0 -1880
  482. data/spec/integration/eager_loader_test.rb +0 -687
  483. data/spec/integration/migrator_test.rb +0 -262
  484. data/spec/integration/model_test.rb +0 -203
  485. data/spec/integration/plugin_test.rb +0 -2302
  486. data/spec/integration/prepared_statement_test.rb +0 -398
  487. data/spec/integration/schema_test.rb +0 -869
  488. data/spec/integration/spec_helper.rb +0 -64
  489. data/spec/integration/timezone_test.rb +0 -86
  490. data/spec/integration/transaction_test.rb +0 -354
  491. data/spec/integration/type_test.rb +0 -127
  492. data/spec/model/association_reflection_spec.rb +0 -803
  493. data/spec/model/associations_spec.rb +0 -4538
  494. data/spec/model/base_spec.rb +0 -817
  495. data/spec/model/class_dataset_methods_spec.rb +0 -146
  496. data/spec/model/dataset_methods_spec.rb +0 -198
  497. data/spec/model/eager_loading_spec.rb +0 -2262
  498. data/spec/model/hooks_spec.rb +0 -370
  499. data/spec/model/inflector_spec.rb +0 -26
  500. data/spec/model/model_spec.rb +0 -953
  501. data/spec/model/plugins_spec.rb +0 -318
  502. data/spec/model/record_spec.rb +0 -2107
  503. data/spec/model/spec_helper.rb +0 -45
  504. data/spec/model/validations_spec.rb +0 -193
  505. data/spec/model_no_assoc_spec.rb +0 -1
  506. data/spec/model_spec.rb +0 -1
  507. data/spec/plugin_spec.rb +0 -1
  508. data/spec/sequel_coverage.rb +0 -15
  509. data/spec/sequel_warning.rb +0 -4
  510. data/spec/spec_config.rb +0 -12
@@ -1,64 +0,0 @@
1
- require 'logger'
2
- require_relative "../sequel_warning"
3
-
4
- if ENV['COVERAGE']
5
- require_relative "../sequel_coverage"
6
- SimpleCov.sequel_coverage(:group=>%r{lib/sequel/adapters})
7
- end
8
-
9
- $:.unshift(File.join(File.dirname(File.expand_path(__FILE__)), "../../lib/"))
10
- require_relative "../../lib/sequel"
11
-
12
- begin
13
- require_relative "../spec_config" unless defined?(DB)
14
- rescue LoadError
15
- end
16
- Sequel::Deprecation.backtrace_filter = lambda{|line, lineno| lineno < 4 || line =~ /_(spec|test)\.rb/}
17
-
18
- Sequel::DB = nil unless Sequel.constants.include?(:DB)
19
- Sequel.split_symbols = true if ENV['SEQUEL_SPLIT_SYMBOLS']
20
- Sequel::Database.extension :columns_introspection if ENV['SEQUEL_COLUMNS_INTROSPECTION']
21
- Sequel::Model.cache_associations = false if ENV['SEQUEL_NO_CACHE_ASSOCIATIONS']
22
- Sequel::Model.plugin :prepared_statements if ENV['SEQUEL_MODEL_PREPARED_STATEMENTS']
23
- Sequel::Model.use_transactions = false
24
- Sequel::Model.cache_anonymous_models = false
25
-
26
- require_relative '../guards_helper'
27
-
28
- DB = Sequel.connect(ENV['SEQUEL_INTEGRATION_URL']) unless defined?(DB)
29
-
30
- IDENTIFIER_MANGLING = !!ENV['SEQUEL_IDENTIFIER_MANGLING'] unless defined?(IDENTIFIER_MANGLING)
31
- DB.extension(:identifier_mangling) if IDENTIFIER_MANGLING
32
-
33
- if DB.adapter_scheme == :ibmdb || (DB.adapter_scheme == :ado && DB.database_type == :access)
34
- def DB.drop_table(*tables)
35
- super
36
- rescue Sequel::DatabaseError
37
- disconnect
38
- super
39
- end
40
- end
41
-
42
- DB.extension :index_caching if ENV['SEQUEL_INDEX_CACHING']
43
- DB.extension :error_sql if ENV['SEQUEL_ERROR_SQL']
44
- DB.extension :synchronize_sql if ENV['SEQUEL_SYNCHRONIZE_SQL']
45
- DB.extension :integer64 if ENV['SEQUEL_INTEGER64']
46
-
47
- if ENV['SEQUEL_CONNECTION_VALIDATOR']
48
- ENV['SEQUEL_NO_CHECK_SQLS'] = '1'
49
- DB.extension(:connection_validator)
50
- DB.pool.connection_validation_timeout = -1
51
- end
52
-
53
- if dch = ENV['SEQUEL_DUPLICATE_COLUMNS_HANDLER']
54
- DB.extension :duplicate_columns_handler
55
- DB.opts[:on_duplicate_columns] = dch.to_sym unless dch.empty?
56
- end
57
-
58
- if ENV['SEQUEL_FREEZE_DATABASE']
59
- DB.extension(:constraint_validations, :string_agg, :date_arithmetic)
60
- DB.extension(:pg_array) if DB.database_type == :postgres
61
- DB.freeze
62
- end
63
-
64
- puts "running #{defined?(SEQUEL_ADAPTER_TEST) ? SEQUEL_ADAPTER_TEST : "integration (database type: #{DB.database_type})"} specs on #{RUBY_ENGINE} #{defined?(JRUBY_VERSION) ? JRUBY_VERSION : RUBY_VERSION} with #{DB.adapter_scheme} adapter"
@@ -1,86 +0,0 @@
1
- require_relative "spec_helper"
2
-
3
- describe "Sequel timezone support" do
4
- def _test_timezone(timezone=Sequel.application_timezone)
5
- Sequel.datetime_class = Time
6
- # Tests should cover both DST and non-DST times.
7
- [Time.now, Time.local(2010,1,1,12), Time.local(2010,6,1,12)].each do |t|
8
- @db[:t].insert(t)
9
- t2 = @db[:t].single_value
10
- t2 = @db.to_application_timestamp(t2.to_s) unless t2.is_a?(Time)
11
- (t2 - t).must_be_close_to 0, 2
12
- t2.utc_offset.must_equal 0 if timezone == :utc
13
- t2.utc_offset.must_equal t.getlocal.utc_offset if timezone == :local
14
- @db[:t].delete
15
- end
16
-
17
- Sequel.datetime_class = DateTime
18
- local_dst_offset = Time.local(2010, 6).utc_offset/86400.0
19
- local_std_offset = Time.local(2010, 1).utc_offset/86400.0
20
- [DateTime.now, DateTime.civil(2010,1,1,12,0,0,local_std_offset), DateTime.civil(2010,6,1,12,0,0,local_dst_offset)].each do |dt|
21
- @db[:t].insert(dt)
22
- dt2 = @db[:t].single_value
23
- dt2 = @db.to_application_timestamp(dt2.to_s) unless dt2.is_a?(DateTime)
24
- (dt2 - dt).must_be_close_to 0, 0.00002
25
- dt2.offset.must_equal 0 if timezone == :utc
26
- dt2.offset.must_equal dt.offset if timezone == :local
27
- @db[:t].delete
28
- end
29
- end
30
-
31
- before do
32
- @db = DB
33
- @db.create_table!(:t){DateTime :t}
34
- end
35
- after do
36
- @db.timezone = nil
37
- Sequel.default_timezone = nil
38
- Sequel.datetime_class = Time
39
- @db.drop_table(:t)
40
- end
41
-
42
- cspecify "should support using UTC for database storage and local time for the application", [:tinytds], [:oracle] do
43
- Sequel.database_timezone = :utc
44
- Sequel.application_timezone = :local
45
- _test_timezone
46
- Sequel.database_timezone = nil
47
- @db.timezone = :utc
48
- _test_timezone
49
- end
50
-
51
- cspecify "should support using local time for database storage and UTC for the application", [:tinytds], [:oracle] do
52
- Sequel.database_timezone = :local
53
- Sequel.application_timezone = :utc
54
- _test_timezone
55
- Sequel.database_timezone = nil
56
- @db.timezone = :local
57
- _test_timezone
58
- end
59
-
60
- cspecify "should support using UTC for both database storage and for application", [:oracle] do
61
- Sequel.default_timezone = :utc
62
- _test_timezone
63
- Sequel.database_timezone = :local
64
- @db.timezone = :utc
65
- _test_timezone
66
- end
67
-
68
- cspecify "should support using local time for both database storage and for application", [:oracle] do
69
- Sequel.default_timezone = :local
70
- _test_timezone
71
- Sequel.database_timezone = :utc
72
- @db.timezone = :local
73
- _test_timezone
74
- end
75
-
76
- it "should allow overriding the database_timezone on a per-database basis" do
77
- Sequel.database_timezone = :utc
78
- @db.timezone = :local
79
- t = Time.now
80
- @db[:t].insert(t)
81
- s = @db[:t].get(Sequel.cast(:t, String))
82
- if o = Date._parse(s)[:offset]
83
- o.must_equal t.utc_offset
84
- end
85
- end
86
- end unless DB.frozen?
@@ -1,354 +0,0 @@
1
- require_relative "spec_helper"
2
-
3
- describe "Database transactions" do
4
- before(:all) do
5
- @db = DB
6
- @db.create_table!(:items, :engine=>'InnoDB'){String :name; Integer :value}
7
- @d = @db[:items]
8
- end
9
- before do
10
- @d.delete
11
- end
12
- after(:all) do
13
- @db.drop_table?(:items)
14
- end
15
-
16
- it "should support transactions" do
17
- @db.transaction{@d.insert(:name => 'abc', :value => 1)}
18
- @d.count.must_equal 1
19
- end
20
-
21
- it "should have #transaction yield the connection" do
22
- @db.transaction{|conn| conn.wont_equal nil}
23
- end
24
-
25
- it "should have #in_transaction? work correctly" do
26
- @db.in_transaction?.must_equal false
27
- c = nil
28
- @db.transaction{c = @db.in_transaction?}
29
- c.must_equal true
30
- end
31
-
32
- it "should correctly rollback transactions" do
33
- proc do
34
- @db.transaction do
35
- @d.insert(:name => 'abc', :value => 1)
36
- raise Interrupt, 'asdf'
37
- end
38
- end.must_raise(Interrupt)
39
-
40
- @db.transaction do
41
- @d.insert(:name => 'abc', :value => 1)
42
- raise Sequel::Rollback
43
- end.must_be_nil
44
-
45
- proc do
46
- @db.transaction(:rollback=>:reraise) do
47
- @d.insert(:name => 'abc', :value => 1)
48
- raise Sequel::Rollback
49
- end
50
- end.must_raise(Sequel::Rollback)
51
-
52
- @db.transaction(:rollback=>:always) do
53
- @d.insert(:name => 'abc', :value => 1)
54
- 2
55
- end.must_equal 2
56
-
57
- @d.count.must_equal 0
58
- end
59
-
60
- it "should support nested transactions" do
61
- @db.transaction do
62
- @db.transaction do
63
- @d.insert(:name => 'abc', :value => 1)
64
- end
65
- end
66
- @d.count.must_equal 1
67
-
68
- @d.delete
69
- @db.transaction do
70
- @d.insert(:name => 'abc', :value => 1)
71
- @db.transaction do
72
- raise Sequel::Rollback
73
- end
74
- end
75
- @d.count.must_equal 0
76
-
77
- proc {@db.transaction do
78
- @d.insert(:name => 'abc', :value => 1)
79
- @db.transaction do
80
- raise Interrupt, 'asdf'
81
- end
82
- end}.must_raise(Interrupt)
83
- @d.count.must_equal 0
84
- end
85
-
86
- if DB.supports_savepoints?
87
- it "should handle table_exists? failures inside transactions" do
88
- @db.transaction do
89
- @d.insert(:name => '1')
90
- @db.table_exists?(:asadf098asd9asd98sa).must_equal false
91
- @d.insert(:name => '2')
92
- end
93
- @d.select_order_map(:name).must_equal %w'1 2'
94
- end
95
-
96
- it "should handle :rollback=>:always inside transactions" do
97
- @db.transaction do
98
- @db.transaction(:rollback=>:always) do
99
- @d.insert(:name => 'abc', :value => 1)
100
- 2
101
- end.must_equal 2
102
- end
103
- @d.select_order_map(:value).must_equal []
104
- end
105
-
106
- it "should handle table_exists? failures inside savepoints" do
107
- @db.transaction do
108
- @d.insert(:name => '1')
109
- @db.transaction(:savepoint=>true) do
110
- @d.insert(:name => '2')
111
- @db.table_exists?(:asadf098asd9asd98sa).must_equal false
112
- @d.insert(:name => '3')
113
- end
114
- @d.insert(:name => '4')
115
- end
116
- @d.select_order_map(:name).must_equal %w'1 2 3 4'
117
- end
118
-
119
- it "should support nested transactions through savepoints using the savepoint option" do
120
- @db.transaction do
121
- @d.insert(:name => '1')
122
- @db.transaction(:savepoint=>true) do
123
- @d.insert(:name => '2')
124
- @db.transaction do
125
- @d.insert(:name => '3')
126
- raise Sequel::Rollback
127
- end
128
- end
129
- @d.insert(:name => '4')
130
- @db.transaction do
131
- @d.insert(:name => '6')
132
- @db.transaction(:savepoint=>true) do
133
- @d.insert(:name => '7')
134
- raise Sequel::Rollback
135
- end
136
- end
137
- @d.insert(:name => '5')
138
- end
139
-
140
- @d.order(:name).map(:name).must_equal %w{1 4 5 6}
141
- end
142
-
143
- it "should support nested transactions through savepoints using the auto_savepoint option" do
144
- @db.transaction(:auto_savepoint=>true) do
145
- @d.insert(:name => '1')
146
- @db.transaction do
147
- @d.insert(:name => '2')
148
- @db.transaction do
149
- @d.insert(:name => '3')
150
- raise Sequel::Rollback
151
- end
152
- end
153
- @d.insert(:name => '4')
154
- @db.transaction(:auto_savepoint=>true) do
155
- @d.insert(:name => '6')
156
- @db.transaction do
157
- @d.insert(:name => '7')
158
- raise Sequel::Rollback
159
- end
160
- end
161
- @d.insert(:name => '5')
162
- end
163
-
164
- @d.order(:name).map(:name).must_equal %w{1 4 5 6}
165
- end
166
- end
167
-
168
- it "should handle returning inside of the block by committing" do
169
- def ret_commit
170
- @db.transaction do
171
- @db[:items].insert(:name => 'abc')
172
- return
173
- end
174
- end
175
-
176
- @d.count.must_equal 0
177
- ret_commit
178
- @d.count.must_equal 1
179
- ret_commit
180
- @d.count.must_equal 2
181
- proc do
182
- @db.transaction do
183
- raise Interrupt, 'asdf'
184
- end
185
- end.must_raise(Interrupt)
186
-
187
- @d.count.must_equal 2
188
- end
189
-
190
- if DB.supports_prepared_transactions?
191
- it "should allow saving and destroying of model objects" do
192
- c = Class.new(Sequel::Model(@d))
193
- c.set_primary_key :name
194
- c.unrestrict_primary_key
195
- @db.transaction(:prepare=>'XYZ'){c.create(:name => '1'); c.create(:name => '2').destroy}
196
- @db.commit_prepared_transaction('XYZ')
197
- @d.select_order_map(:name).must_equal ['1']
198
- end
199
-
200
- it "should commit prepared transactions using commit_prepared_transaction" do
201
- @db.transaction(:prepare=>'XYZ'){@d.insert(:name => '1')}
202
- @db.commit_prepared_transaction('XYZ')
203
- @d.select_order_map(:name).must_equal ['1']
204
- end
205
-
206
- it "should rollback prepared transactions using rollback_prepared_transaction" do
207
- @db.transaction(:prepare=>'XYZ'){@d.insert(:name => '1')}
208
- @db.rollback_prepared_transaction('XYZ')
209
- @d.select_order_map(:name).must_equal []
210
- end
211
-
212
- if DB.supports_savepoints_in_prepared_transactions?
213
- it "should support savepoints when using prepared transactions" do
214
- @db.transaction(:prepare=>'XYZ'){@db.transaction(:savepoint=>true){@d.insert(:name => '1')}}
215
- @db.commit_prepared_transaction('XYZ')
216
- @d.select_order_map(:name).must_equal ['1']
217
- end
218
- end
219
- end
220
-
221
- it "should support all transaction isolation levels" do
222
- [:uncommitted, :committed, :repeatable, :serializable].each_with_index do |l, i|
223
- @db.transaction(:isolation=>l){@d.insert(:name => 'abc', :value => 1)}
224
- @d.count.must_equal i + 1
225
- end
226
- end
227
-
228
- it "should support after_commit outside transactions" do
229
- c = nil
230
- @db.after_commit{c = 1}
231
- c.must_equal 1
232
- end
233
-
234
- it "should support after_rollback outside transactions" do
235
- c = nil
236
- @db.after_rollback{c = 1}
237
- c.must_be_nil
238
- end
239
-
240
- it "should support after_commit inside transactions" do
241
- c = nil
242
- @db.transaction{@db.after_commit{c = 1}; c.must_be_nil}
243
- c.must_equal 1
244
- end
245
-
246
- it "should support after_rollback inside transactions" do
247
- c = nil
248
- @db.transaction{@db.after_rollback{c = 1}; c.must_be_nil}
249
- c.must_be_nil
250
- end
251
-
252
- it "should not call after_commit if the transaction rolls back" do
253
- c = nil
254
- @db.transaction{@db.after_commit{c = 1}; c.must_be_nil; raise Sequel::Rollback}
255
- c.must_be_nil
256
- end
257
-
258
- it "should call after_rollback if the transaction rolls back" do
259
- c = nil
260
- @db.transaction{@db.after_rollback{c = 1}; c.must_be_nil; raise Sequel::Rollback}
261
- c.must_equal 1
262
- end
263
-
264
- it "should support multiple after_commit blocks inside transactions" do
265
- c = []
266
- @db.transaction{@db.after_commit{c << 1}; @db.after_commit{c << 2}; c.must_equal []}
267
- c.must_equal [1, 2]
268
- end
269
-
270
- it "should support multiple after_rollback blocks inside transactions" do
271
- c = []
272
- @db.transaction{@db.after_rollback{c << 1}; @db.after_rollback{c << 2}; c.must_equal []; raise Sequel::Rollback}
273
- c.must_equal [1, 2]
274
- end
275
-
276
- it "should support after_commit inside nested transactions" do
277
- c = nil
278
- @db.transaction{@db.transaction{@db.after_commit{c = 1}}; c.must_be_nil}
279
- c.must_equal 1
280
- end
281
-
282
- it "should support after_rollback inside nested transactions" do
283
- c = nil
284
- @db.transaction{@db.transaction{@db.after_rollback{c = 1}}; c.must_be_nil; raise Sequel::Rollback}
285
- c.must_equal 1
286
- end
287
-
288
- if DB.supports_savepoints?
289
- it "should support after_commit inside savepoints" do
290
- c = nil
291
- @db.transaction{@db.transaction(:savepoint=>true){@db.after_commit{c = 1}}; c.must_be_nil}
292
- c.must_equal 1
293
- end
294
-
295
- it "should support after_rollback inside savepoints" do
296
- c = nil
297
- @db.transaction{@db.transaction(:savepoint=>true){@db.after_rollback{c = 1}}; c.must_be_nil; raise Sequel::Rollback}
298
- c.must_equal 1
299
- end
300
- end
301
-
302
- if DB.supports_prepared_transactions?
303
- it "should raise an error if you attempt to use after_commit or after_rollback inside a prepared transaction" do
304
- proc{@db.transaction(:prepare=>'XYZ'){@db.after_commit{}}}.must_raise(Sequel::Error)
305
- proc{@db.transaction(:prepare=>'XYZ'){@db.after_rollback{}}}.must_raise(Sequel::Error)
306
- end
307
-
308
- if DB.supports_savepoints_in_prepared_transactions?
309
- it "should raise an error if you attempt to use after_commit or after rollback inside a savepoint in a prepared transaction" do
310
- proc{@db.transaction(:prepare=>'XYZ'){@db.transaction(:savepoint=>true){@db.after_commit{}}}}.must_raise(Sequel::Error)
311
- proc{@db.transaction(:prepare=>'XYZ'){@db.transaction(:savepoint=>true){@db.after_rollback{}}}}.must_raise(Sequel::Error)
312
- end
313
- end
314
- end
315
- end
316
-
317
- describe "Database transaction retrying" do
318
- before(:all) do
319
- @db = DB
320
- @db.create_table!(:items, :engine=>'InnoDB'){String :a, :unique=>true, :null=>false}
321
- @d = @db[:items]
322
- end
323
- before do
324
- @d.delete
325
- end
326
- after(:all) do
327
- @db.drop_table?(:items)
328
- end
329
-
330
- it "should be supported using the :retry_on option" do
331
- @d.insert('b')
332
- @d.insert('c')
333
- s = 'a'
334
- @db.transaction(:retry_on=>Sequel::ConstraintViolation) do
335
- s = s.succ
336
- @d.insert(s)
337
- end
338
- @d.select_order_map(:a).must_equal %w'b c d'
339
- end
340
-
341
- it "should limit number of retries via the :num_retries option" do
342
- @d.insert('b')
343
- @d.insert('c')
344
- s = 'a'
345
- lambda do
346
- @db.transaction(:num_retries=>1, :retry_on=>Sequel::ConstraintViolation) do
347
- s = s.succ
348
- @d.insert(s)
349
- end
350
- end.must_raise(Sequel::UniqueConstraintViolation, Sequel::ConstraintViolation)
351
- @d.select_order_map(:a).must_equal %w'b c'
352
- end
353
- end
354
-