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,165 +0,0 @@
1
- require_relative "spec_helper"
2
-
3
- describe "pg_auto_constraint_validations plugin" do
4
- def create_model(ds)
5
- @ds = ds
6
- @ds.send(:columns=, [:id, :i])
7
- @db.fetch = @metadata_results.dup
8
- c = Sequel::Model(@ds)
9
- c.plugin :pg_auto_constraint_validations
10
- c
11
- end
12
-
13
- before do
14
- info = @info = {:schema=>'public', :table=>'items'}
15
- error = @error = []
16
- @db = Sequel.mock(:host=>'postgres')
17
- def @db.schema(*) [[:i, {}], [:id, {}]] end
18
- @set_error = lambda{|ec, ei| @db.fetch = @db.autoid = @db.numrows = ec; info.merge!(ei)}
19
- @db.define_singleton_method(:error_info){|e| info}
20
- @metadata_results = [
21
- [{:constraint=>'items_i_check', :column=>'i', :definition=>'CHECK i'}, {:constraint=>'items_i_id_check', :column=>'i', :definition=>'CHECK i + id < 20'}, {:constraint=>'items_i_id_check', :column=>'id', :definition=>'CHECK i + id < 20'}],
22
- [{:name=>'items_i_uidx', :unique=>true, :column=>'i', :deferrable=>false}, {:name=>'items_i2_idx', :unique=>false, :column=>'i', :deferrable=>false}],
23
- [{:name=>'items_i_fk', :column=>'i', :on_update=>'a', :on_delete=>'a', :table=>'items2', :refcolumn=>'id', :schema=>'public'}],
24
- [{:name=>'items2_i_fk', :column=>'id', :on_update=>'a', :on_delete=>'a', :table=>'items2', :refcolumn=>'i', :schema=>'public'}],
25
- [{:nspname=>'public', :relname=>'items'}]
26
- ]
27
- @c = create_model(@db[:items])
28
- end
29
-
30
- it "should handle check constraint failures as validation errors when creating" do
31
- o = @c.new(:i=>12)
32
- @set_error[Sequel::CheckConstraintViolation, :constraint=>'items_i_check']
33
- proc{o.save}.must_raise Sequel::ValidationFailed
34
- o.errors.must_equal(:i=>['is invalid'])
35
- end
36
-
37
- it "should handle check constraint failures as validation errors when updating" do
38
- o = @c.load(:i=>3)
39
- @set_error[Sequel::CheckConstraintViolation, :constraint=>'items_i_check']
40
- proc{o.update(:i=>12)}.must_raise Sequel::ValidationFailed
41
- o.errors.must_equal(:i=>['is invalid'])
42
- end
43
-
44
- it "should handle unique constraint failures as validation errors when creating" do
45
- o = @c.new(:i=>2)
46
- @set_error[Sequel::UniqueConstraintViolation, :constraint=>'items_i_uidx']
47
- proc{o.save}.must_raise Sequel::ValidationFailed
48
- o.errors.must_equal(:i=>['is already taken'])
49
- end
50
-
51
- it "should handle unique constraint failures as validation errors when updating" do
52
- o = @c.load(:id=>5, :i=>3)
53
- @set_error[Sequel::UniqueConstraintViolation, :constraint=>'items_i_uidx']
54
- proc{o.update(:i=>2)}.must_raise Sequel::ValidationFailed
55
- o.errors.must_equal(:i=>['is already taken'])
56
- end
57
-
58
- it "should handle not null constraint failures as validation errors when creating" do
59
- o = @c.new(:i=>5)
60
- @set_error[Sequel::NotNullConstraintViolation, :column=>'i']
61
- proc{o.save}.must_raise Sequel::ValidationFailed
62
- o.errors.must_equal(:i=>['is not present'])
63
- end
64
-
65
- it "should handle not null constraint failures as validation errors when updating" do
66
- o = @c.load(:i=>3)
67
- @set_error[Sequel::NotNullConstraintViolation, :column=>'i']
68
- proc{o.update(:i=>nil)}.must_raise Sequel::ValidationFailed
69
- o.errors.must_equal(:i=>['is not present'])
70
- end
71
-
72
- it "should handle foreign key constraint failures as validation errors when creating" do
73
- o = @c.new(:i=>3)
74
- @set_error[Sequel::ForeignKeyConstraintViolation, :constraint=>'items_i_fk', :message_primary=>'insert or']
75
- proc{o.save}.must_raise Sequel::ValidationFailed
76
- o.errors.must_equal(:i=>['is invalid'])
77
- end
78
-
79
- it "should handle foreign key constraint failures as validation errors when updating" do
80
- o = @c.load(:i=>1)
81
- @set_error[Sequel::ForeignKeyConstraintViolation, :constraint=>'items_i_fk', :message_primary=>'insert or']
82
- proc{o.update(:i=>3)}.must_raise Sequel::ValidationFailed
83
- o.errors.must_equal(:i=>['is invalid'])
84
- end
85
-
86
- it "should handle foreign key constraint failures in other tables as validation errors when updating" do
87
- o = @c.load(:i=>1)
88
- @set_error[Sequel::ForeignKeyConstraintViolation, :constraint=>'items2_i_fk', :message_primary=>'update or', :schema=>'public', :table=>'items2']
89
- proc{o.update(:i=>3)}.must_raise Sequel::ValidationFailed
90
- o.errors.must_equal(:i=>['cannot be changed currently'])
91
- end
92
-
93
- it "should handle symbol, string, and identifier table names" do
94
- [@db[:items], @db.from('items'), @db.from{items}, @db.from{public[:items]}].each do |ds|
95
- c = create_model(ds)
96
- @set_error[Sequel::CheckConstraintViolation, :constraint=>'items_i_check']
97
- o = c.new(:i=>3)
98
- proc{o.save}.must_raise Sequel::ValidationFailed
99
- o.errors.must_equal(:i=>['is invalid'])
100
- end
101
- end
102
-
103
- it "should skip handling of other table types such as subqueries and functions" do
104
- [@db.from{foo(:bar)}, @db[:a, :b]].each do |ds|
105
- @db.fetch = @metadata_results.dup
106
- @c.dataset = ds
107
- o = @c.new(:i=>3)
108
- @set_error[Sequel::CheckConstraintViolation, :constraint=>'items_i_check']
109
- proc{o.save}.must_raise Sequel::CheckConstraintViolation
110
- end
111
- end
112
-
113
- it "should skip handling if the error_info method is not supported" do
114
- @db.singleton_class.send(:remove_method, :error_info)
115
- c = create_model(@db[:items])
116
- @set_error[Sequel::CheckConstraintViolation, :constraint=>'items_i_check']
117
- o = c.new(:i=>3)
118
- proc{o.save}.must_raise Sequel::CheckConstraintViolation
119
- end
120
-
121
- it "should not handle constraint failures if they can't be converted" do
122
- o = @c.new(:i=>12)
123
- @set_error[Sequel::NotNullConstraintViolation, {}]
124
- proc{o.save}.must_raise Sequel::NotNullConstraintViolation
125
- end
126
-
127
- it "should reraise original exception if there is an error" do
128
- o = @c.new(:i=>12)
129
- def o.add_pg_constraint_validation_error; end
130
- @set_error[Sequel::NotNullConstraintViolation, :column=>'i']
131
- proc{o.save}.must_raise Sequel::NotNullConstraintViolation
132
- end
133
-
134
- it "should not handle constraint failures if schema or table do not match" do
135
- o = @c.new(:i=>12)
136
- @set_error[Sequel::CheckConstraintViolation, :constraint=>'items_i_check', :schema=>'x']
137
- proc{o.save}.must_raise Sequel::CheckConstraintViolation
138
- @set_error[Sequel::CheckConstraintViolation, :constraint=>'items_i_check', :schema=>'public', :table=>'x']
139
- proc{o.save}.must_raise Sequel::CheckConstraintViolation
140
- end
141
-
142
- it "should handle constraint failures when disabling insert returning" do
143
- c = create_model(@db[:items].disable_insert_returning)
144
- o = c.new(:i=>12)
145
- o.id = 1
146
- @set_error[Sequel::CheckConstraintViolation, :constraint=>'items_i_check']
147
- proc{o.save}.must_raise Sequel::ValidationFailed
148
- o.errors.must_equal(:i=>['is invalid'])
149
- end
150
-
151
- it "should handle multi-column constraint failures as validation errors" do
152
- o = @c.new(:i=>12)
153
- @set_error[Sequel::CheckConstraintViolation, :constraint=>'items_i_id_check']
154
- proc{o.save}.must_raise Sequel::ValidationFailed
155
- o.errors.must_equal([:i, :id]=>['is invalid'])
156
- end
157
-
158
- it "should handle multi-column constraint failures as validation errors when using the error_splitter plugin" do
159
- @c.plugin :error_splitter
160
- o = @c.new(:i=>12)
161
- @set_error[Sequel::CheckConstraintViolation, :constraint=>'items_i_id_check']
162
- proc{o.save}.must_raise Sequel::ValidationFailed
163
- o.errors.must_equal(:i=>['is invalid'], :id=>['is invalid'])
164
- end
165
- end
@@ -1,113 +0,0 @@
1
- require_relative "spec_helper"
2
-
3
- Sequel.extension :migration
4
-
5
- describe "pg_enum extension" do
6
- before do
7
- @db = Sequel.connect('mock://postgres')
8
- @db.extend_datasets{def quote_identifiers?; false end}
9
- @db.extend(Module.new do
10
- def schema_parse_table(*)
11
- [[:a, {:oid=>1}]]
12
- end
13
- def _metadata_dataset
14
- super.with_fetch([[{:v=>1, :enumlabel=>'a'}, {:v=>1, :enumlabel=>'b'}, {:v=>1, :enumlabel=>'c'}], [{:typname=>'enum1', :v=>212389}]])
15
- end
16
- end)
17
- @db.extension(:pg_array, :pg_enum)
18
- @db.sqls
19
- end
20
-
21
- it "should include enum information in the schema entry" do
22
- @db.schema(:a).must_equal [[:a, {:oid=>1, :ruby_default=>nil, :type=>:enum, :enum_values=>%w'a b c'}]]
23
- end
24
-
25
- it "should typecast objects to string" do
26
- @db.typecast_value(:enum, :a).must_equal 'a'
27
- end
28
-
29
- it "should add array parsers for enum values" do
30
- @db.conversion_procs[212389].call('{a,b,c}').must_equal %w'a b c'
31
- end
32
-
33
- it "should support #create_enum method for adding a new enum" do
34
- @db.create_enum(:foo, [:a, :b, :c])
35
- @db.sqls.first.must_equal "CREATE TYPE foo AS ENUM ('a', 'b', 'c')"
36
- @db.create_enum(Sequel[:sch][:foo], %w'a b c')
37
- @db.sqls.first.must_equal "CREATE TYPE sch.foo AS ENUM ('a', 'b', 'c')"
38
- end
39
-
40
- with_symbol_splitting "should support #create_enum method for adding a new enum with qualified symbol" do
41
- @db.create_enum(:sch__foo, %w'a b c')
42
- @db.sqls.first.must_equal "CREATE TYPE sch.foo AS ENUM ('a', 'b', 'c')"
43
- end
44
-
45
- it "should support #rename_enum method for renameing an enum" do
46
- @db.rename_enum(:foo, :bar)
47
- @db.sqls.first.must_equal "ALTER TYPE foo RENAME TO bar"
48
- @db.rename_enum(Sequel[:sch][:foo], Sequel[:sch][:bar])
49
- @db.sqls.first.must_equal "ALTER TYPE sch.foo RENAME TO sch.bar"
50
- end
51
-
52
- it "should support #drop_enum method for dropping an enum" do
53
- @db.drop_enum(:foo)
54
- @db.sqls.first.must_equal "DROP TYPE foo"
55
- @db.drop_enum(Sequel[:sch][:foo], :if_exists=>true)
56
- @db.sqls.first.must_equal "DROP TYPE IF EXISTS sch.foo"
57
- @db.drop_enum('foo', :cascade=>true)
58
- @db.sqls.first.must_equal "DROP TYPE foo CASCADE"
59
- end
60
-
61
- with_symbol_splitting "should support #drop_enum method for dropping an enum with a splittable symbol" do
62
- @db.drop_enum(:sch__foo, :if_exists=>true)
63
- @db.sqls.first.must_equal "DROP TYPE IF EXISTS sch.foo"
64
- end
65
-
66
- it "should support #add_enum_value method for adding value to an existing enum" do
67
- @db.add_enum_value(:foo, :a)
68
- @db.sqls.first.must_equal "ALTER TYPE foo ADD VALUE 'a'"
69
- end
70
-
71
- it "should support :before option for #add_enum_value method for adding value before an existing enum value" do
72
- @db.add_enum_value('foo', :a, :before=>:b)
73
- @db.sqls.first.must_equal "ALTER TYPE foo ADD VALUE 'a' BEFORE 'b'"
74
- end
75
-
76
- it "should support :after option for #add_enum_value method for adding value after an existing enum value" do
77
- @db.add_enum_value(Sequel[:sch][:foo], :a, :after=>:b)
78
- @db.sqls.first.must_equal "ALTER TYPE sch.foo ADD VALUE 'a' AFTER 'b'"
79
- end
80
-
81
- with_symbol_splitting "should support :after option for #add_enum_value method for adding value after an existing enum value with splittable symbol" do
82
- @db.add_enum_value(:sch__foo, :a, :after=>:b)
83
- @db.sqls.first.must_equal "ALTER TYPE sch.foo ADD VALUE 'a' AFTER 'b'"
84
- end
85
-
86
- it "should support :if_not_exists option for #add_enum_value method for not adding the value if it exists" do
87
- @db.add_enum_value(:foo, :a, :if_not_exists=>true)
88
- @db.sqls.first.must_equal "ALTER TYPE foo ADD VALUE IF NOT EXISTS 'a'"
89
- end
90
-
91
- it "should reverse a create_enum directive in a migration" do
92
- m = Sequel.migration{change{create_enum(:type_name, %w'value1 value2 value3')}}
93
- m.apply(@db, :up)
94
- @db.sqls.must_equal ["CREATE TYPE type_name AS ENUM ('value1', 'value2', 'value3')",
95
- "SELECT CAST(enumtypid AS integer) AS v, enumlabel FROM pg_enum ORDER BY enumtypid, enumsortorder",
96
- "SELECT typname, CAST(typarray AS integer) AS v FROM pg_type WHERE ((1 = 0) AND (typarray != 0))"]
97
- m.apply(@db, :down)
98
- @db.sqls.must_equal ["DROP TYPE type_name", "SELECT CAST(enumtypid AS integer) AS v, enumlabel FROM pg_enum ORDER BY enumtypid, enumsortorder",
99
- "SELECT typname, CAST(typarray AS integer) AS v FROM pg_type WHERE ((1 = 0) AND (typarray != 0))"]
100
- end
101
-
102
- it "should reverse a rename_enum directive in a migration" do
103
- m = Sequel.migration{change{rename_enum(:old_type_name, :new_type_name)}}
104
- m.apply(@db, :up)
105
- @db.sqls.must_equal ["ALTER TYPE old_type_name RENAME TO new_type_name",
106
- "SELECT CAST(enumtypid AS integer) AS v, enumlabel FROM pg_enum ORDER BY enumtypid, enumsortorder",
107
- "SELECT typname, CAST(typarray AS integer) AS v FROM pg_type WHERE ((1 = 0) AND (typarray != 0))"]
108
- m.apply(@db, :down)
109
- @db.sqls.must_equal ["ALTER TYPE new_type_name RENAME TO old_type_name",
110
- "SELECT CAST(enumtypid AS integer) AS v, enumlabel FROM pg_enum ORDER BY enumtypid, enumsortorder",
111
- "SELECT typname, CAST(typarray AS integer) AS v FROM pg_type WHERE ((1 = 0) AND (typarray != 0))"]
112
- end
113
- end
@@ -1,126 +0,0 @@
1
- require_relative "spec_helper"
2
-
3
- describe "pg_extended_date_support extension" do
4
- before do
5
- @db = Sequel.mock(:host=>'postgres', :fetch=>{:v=>1}).extension(:pg_extended_date_support)
6
- @db.extend_datasets{def quote_identifiers?; false end}
7
- end
8
- after do
9
- Sequel.datetime_class = Time
10
- Sequel.default_timezone = nil
11
- end
12
-
13
- it "should convert infinite timestamps and dates as configured" do
14
- cp = @db.conversion_procs
15
- d = lambda{|v| cp[1082].call(v)}
16
- t = lambda{|v| cp[1114].call(v)}
17
- pi = 'infinity'
18
- ni = '-infinity'
19
- today = Date.today
20
- now = Time.now
21
-
22
- d.(today.to_s).must_equal today
23
- t.(now.strftime("%Y-%m-%d %H:%M:%S.%N")).must_equal now
24
- proc{@db.typecast_value(:date, pi)}.must_raise Sequel::InvalidValue
25
- proc{@db.typecast_value(:datetime, pi)}.must_raise Sequel::InvalidValue
26
-
27
- [:nil, 'nil'].each do |v|
28
- @db.convert_infinite_timestamps = v
29
- d.(pi).must_be_nil
30
- t.(pi).must_be_nil
31
- d.(ni).must_be_nil
32
- t.(ni).must_be_nil
33
- @db.typecast_value(:date, pi).must_equal pi
34
- @db.typecast_value(:datetime, pi).must_equal pi
35
- @db.typecast_value(:date, ni).must_equal ni
36
- @db.typecast_value(:datetime, ni).must_equal ni
37
- end
38
-
39
- d.(today.to_s).must_equal today
40
- t.(now.strftime("%Y-%m-%d %H:%M:%S.%N")).must_equal now
41
- @db.typecast_value(:date, today.to_s).must_equal today
42
- @db.typecast_value(:datetime, now.strftime("%Y-%m-%d %H:%M:%S.%N")).must_equal now
43
-
44
- [:string, 'string'].each do |v|
45
- @db.convert_infinite_timestamps = v
46
- d.(pi).must_equal pi
47
- t.(pi).must_equal pi
48
- d.(ni).must_equal ni
49
- t.(ni).must_equal ni
50
- end
51
-
52
- [:date, 'date'].each do |v|
53
- @db.convert_infinite_timestamps = v
54
- d.(pi).must_equal Date::Infinity.new
55
- t.(pi).must_equal Date::Infinity.new
56
- d.(ni).must_equal(-Date::Infinity.new)
57
- t.(ni).must_equal(-Date::Infinity.new)
58
- end
59
-
60
- [:float, 'float', 't', true].each do |v|
61
- @db.convert_infinite_timestamps = v
62
- d.(pi).must_equal 1.0/0.0
63
- t.(pi).must_equal 1.0/0.0
64
- d.(ni).must_equal(-1.0/0.0)
65
- t.(ni).must_equal(-1.0/0.0)
66
- end
67
-
68
- ['f', false].each do |v|
69
- @db.convert_infinite_timestamps = v
70
- proc{d.(pi)}.must_raise ArgumentError, Sequel::InvalidValue
71
- proc{t.(pi)}.must_raise ArgumentError, Sequel::InvalidValue
72
- proc{d.(ni)}.must_raise ArgumentError, Sequel::InvalidValue
73
- proc{t.(ni)}.must_raise ArgumentError, Sequel::InvalidValue
74
- end
75
- end
76
-
77
- it "should handle parsing BC dates" do
78
- @db.conversion_procs[1082].call("1092-10-20 BC").must_equal Date.new(-1091, 10, 20)
79
- end
80
-
81
- it "should handle parsing BC timestamps as Time values" do
82
- @db.conversion_procs[1114].call("1200-02-15 14:13:20-00:00 BC").must_equal Time.at(-100000000000).utc
83
- @db.conversion_procs[1114].call("1200-02-15 14:13:20-00:00:00 BC").must_equal Time.at(-100000000000).utc
84
- Sequel.default_timezone = :utc
85
- @db.conversion_procs[1114].call("1200-02-15 14:13:20 BC").must_equal Time.at(-100000000000).utc
86
- Sequel.default_timezone = nil
87
- end
88
-
89
- it "should handle parsing BC timestamps as DateTime values" do
90
- Sequel.datetime_class = DateTime
91
- @db.conversion_procs[1114].call("1200-02-15 14:13:20-00:00 BC").must_equal DateTime.new(-1199, 2, 15, 14, 13, 20)
92
- @db.conversion_procs[1114].call("1200-02-15 14:13:20-00:00:00 BC").must_equal DateTime.new(-1199, 2, 15, 14, 13, 20)
93
- Sequel.default_timezone = :utc
94
- @db.conversion_procs[1114].call("1200-02-15 14:13:20 BC").must_equal DateTime.new(-1199, 2, 15, 14, 13, 20)
95
- end
96
-
97
- it "should handle parsing AD timestamps with offset seconds" do
98
- @db.conversion_procs[1114].call("1200-02-15 14:13:20-00:00:00").must_equal DateTime.new(1200, 2, 15, 14, 13, 20).to_time
99
- Sequel.datetime_class = DateTime
100
- @db.conversion_procs[1114].call("1200-02-15 14:13:20-00:00:00").must_equal DateTime.new(1200, 2, 15, 14, 13, 20)
101
- end
102
-
103
- it "should format Date::Infinity values" do
104
- @db.literal(Date::Infinity.new).must_equal "'infinity'"
105
- @db.literal(-Date::Infinity.new).must_equal "'-infinity'"
106
- end
107
-
108
- it "should raise errors for literalizing random Objects" do
109
- proc{@db.literal(Object.new)}.must_raise Sequel::Error
110
- end
111
-
112
- it "should format BC dates" do
113
- @db.literal(Date.new(-1091, 10, 20)).must_equal "'1092-10-20 BC'"
114
- @db.literal(Date.new(1092, 10, 20)).must_equal "'1092-10-20'"
115
- end
116
-
117
- it "should format BC datetimes" do
118
- @db.literal(DateTime.new(-1199, 2, 15, 14, 13, 20)).must_equal "'1200-02-15 14:13:20.000000000+0000 BC'"
119
- @db.literal(DateTime.new(1200, 2, 15, 14, 13, 20)).must_equal "'1200-02-15 14:13:20.000000+0000'"
120
- end
121
-
122
- it "should format BC times" do
123
- @db.literal(Time.at(-100000000000).utc).must_equal "'1200-02-15 14:13:20.000000000+0000 BC'"
124
- @db.literal(Time.at(100000000000).utc).must_equal "'5138-11-16 09:46:40.000000+0000'"
125
- end
126
- end
@@ -1,238 +0,0 @@
1
- require_relative "spec_helper"
2
-
3
- Sequel.extension :pg_array, :pg_array_ops, :pg_hstore, :pg_hstore_ops
4
-
5
- describe "Sequel::Postgres::HStoreOp" do
6
- before do
7
- @db = Sequel.connect('mock://postgres')
8
- @db.extend_datasets{def quote_identifiers?; false end}
9
- @ds = @db.dataset
10
- @h = Sequel.hstore_op(:h)
11
- end
12
-
13
- it "#- should use the - operator" do
14
- @ds.literal(@h - :a).must_equal "(h - a)"
15
- end
16
-
17
- it "#- should cast String argument to text when using - operator" do
18
- @ds.literal(@h - 'a').must_equal "(h - CAST('a' AS text))"
19
- end
20
-
21
- it "#- should not cast LiteralString argument to text when using - operator" do
22
- @ds.literal(@h - Sequel.lit('a')).must_equal "(h - a)"
23
- end
24
-
25
- it "#- should handle arrays" do
26
- @ds.literal(@h - %w'a').must_equal "(h - ARRAY['a'])"
27
- end
28
-
29
- it "#- should handle hashes" do
30
- @ds.literal(@h - {'a'=>'b'}).must_equal "(h - '\"a\"=>\"b\"'::hstore)"
31
- end
32
-
33
- it "#- should return an HStoreOp" do
34
- @ds.literal((@h - :a)['a']).must_equal "((h - a) -> 'a')"
35
- end
36
-
37
- it "#[] should use the -> operator" do
38
- @ds.literal(@h['a']).must_equal "(h -> 'a')"
39
- end
40
-
41
- it "#[] should handle arrays" do
42
- @ds.literal(@h[%w'a']).must_equal "(h -> ARRAY['a'])"
43
- end
44
-
45
- it "#[] should return a PGArrayOp if given an array" do
46
- @ds.literal(@h[%w'a'][0]).must_equal "(h -> ARRAY['a'])[0]"
47
- end
48
-
49
- it "#[] should not return a PGArrayOp if given an array but pg_array_op is not supported" do
50
- begin
51
- module Sequel::Postgres::HStoreOp::Sequel
52
- SQL = ::Sequel::SQL
53
- end
54
- @ds.literal(@h[%w'a']).wont_be_kind_of(Sequel::Postgres::ArrayOp)
55
- ensure
56
- Sequel::Postgres::HStoreOp.send(:remove_const, :Sequel)
57
- end
58
- end
59
-
60
- it "#[] should return a PGArrayOp if given a PGArray" do
61
- @ds.literal(@h[Sequel.pg_array(%w'a')][0]).must_equal "(h -> ARRAY['a'])[0]"
62
- end
63
-
64
- it "#[] should return a PGArrayOp if given a PGArrayOp" do
65
- @ds.literal(@h[Sequel.pg_array_op(:a)][0]).must_equal "(h -> a)[0]"
66
- end
67
-
68
- it "#[] should return a string expression" do
69
- @ds.literal(@h['a'] + 'b').must_equal "((h -> 'a') || 'b')"
70
- end
71
-
72
- it "#concat and #merge should use the || operator" do
73
- @ds.literal(@h.concat(:h1)).must_equal "(h || h1)"
74
- @ds.literal(@h.merge(:h1)).must_equal "(h || h1)"
75
- end
76
-
77
- it "#concat and #merge should handle hashes" do
78
- @ds.literal(@h.concat('a'=>'b')).must_equal "(h || '\"a\"=>\"b\"'::hstore)"
79
- @ds.literal(@h.merge('a'=>'b')).must_equal "(h || '\"a\"=>\"b\"'::hstore)"
80
- end
81
-
82
- it "#concat should return an HStoreOp" do
83
- @ds.literal(@h.concat(:h1)['a']).must_equal "((h || h1) -> 'a')"
84
- end
85
-
86
- it "#contain_all should use the ?& operator" do
87
- @ds.literal(@h.contain_all(:h1)).must_equal "(h ?& h1)"
88
- end
89
-
90
- it "#contain_all handle arrays" do
91
- @ds.literal(@h.contain_all(%w'h1')).must_equal "(h ?& ARRAY['h1'])"
92
- end
93
-
94
- it "#contain_any should use the ?| operator" do
95
- @ds.literal(@h.contain_any(:h1)).must_equal "(h ?| h1)"
96
- end
97
-
98
- it "#contain_any should handle arrays" do
99
- @ds.literal(@h.contain_any(%w'h1')).must_equal "(h ?| ARRAY['h1'])"
100
- end
101
-
102
- it "#contains should use the @> operator" do
103
- @ds.literal(@h.contains(:h1)).must_equal "(h @> h1)"
104
- end
105
-
106
- it "#contains should handle hashes" do
107
- @ds.literal(@h.contains('a'=>'b')).must_equal "(h @> '\"a\"=>\"b\"'::hstore)"
108
- end
109
-
110
- it "#contained_by should use the <@ operator" do
111
- @ds.literal(@h.contained_by(:h1)).must_equal "(h <@ h1)"
112
- end
113
-
114
- it "#contained_by should handle hashes" do
115
- @ds.literal(@h.contained_by('a'=>'b')).must_equal "(h <@ '\"a\"=>\"b\"'::hstore)"
116
- end
117
-
118
- it "#defined should use the defined function" do
119
- @ds.literal(@h.defined('a')).must_equal "defined(h, 'a')"
120
- end
121
-
122
- it "#delete should use the delete function" do
123
- @ds.literal(@h.delete('a')).must_equal "delete(h, 'a')"
124
- end
125
-
126
- it "#delete should handle arrays" do
127
- @ds.literal(@h.delete(%w'a')).must_equal "delete(h, ARRAY['a'])"
128
- end
129
-
130
- it "#delete should handle hashes" do
131
- @ds.literal(@h.delete('a'=>'b')).must_equal "delete(h, '\"a\"=>\"b\"'::hstore)"
132
- end
133
-
134
- it "#delete should return an HStoreOp" do
135
- @ds.literal(@h.delete('a')['a']).must_equal "(delete(h, 'a') -> 'a')"
136
- end
137
-
138
- it "#each should use the each function" do
139
- @ds.literal(@h.each).must_equal "each(h)"
140
- end
141
-
142
- it "#has_key? and aliases should use the ? operator" do
143
- @ds.literal(@h.has_key?('a')).must_equal "(h ? 'a')"
144
- @ds.literal(@h.key?('a')).must_equal "(h ? 'a')"
145
- @ds.literal(@h.member?('a')).must_equal "(h ? 'a')"
146
- @ds.literal(@h.include?('a')).must_equal "(h ? 'a')"
147
- @ds.literal(@h.exist?('a')).must_equal "(h ? 'a')"
148
- end
149
-
150
- it "#hstore should return the receiver" do
151
- @h.hstore.must_be_same_as(@h)
152
- end
153
-
154
- it "#keys and #akeys should use the akeys function" do
155
- @ds.literal(@h.keys).must_equal "akeys(h)"
156
- @ds.literal(@h.akeys).must_equal "akeys(h)"
157
- end
158
-
159
- it "#keys and #akeys should return PGArrayOps" do
160
- @ds.literal(@h.keys[0]).must_equal "akeys(h)[0]"
161
- @ds.literal(@h.akeys[0]).must_equal "akeys(h)[0]"
162
- end
163
-
164
- it "#populate should use the populate_record function" do
165
- @ds.literal(@h.populate(:a)).must_equal "populate_record(a, h)"
166
- end
167
-
168
- it "#record_set should use the #= operator" do
169
- @ds.literal(@h.record_set(:a)).must_equal "(a #= h)"
170
- end
171
-
172
- it "#skeys should use the skeys function" do
173
- @ds.literal(@h.skeys).must_equal "skeys(h)"
174
- end
175
-
176
- it "#slice should should use the slice function" do
177
- @ds.literal(@h.slice(:a)).must_equal "slice(h, a)"
178
- end
179
-
180
- it "#slice should handle arrays" do
181
- @ds.literal(@h.slice(%w'a')).must_equal "slice(h, ARRAY['a'])"
182
- end
183
-
184
- it "#slice should return an HStoreOp" do
185
- @ds.literal(@h.slice(:a)['a']).must_equal "(slice(h, a) -> 'a')"
186
- end
187
-
188
- it "#svals should use the svals function" do
189
- @ds.literal(@h.svals).must_equal "svals(h)"
190
- end
191
-
192
- it "#to_array should use the hstore_to_array function" do
193
- @ds.literal(@h.to_array).must_equal "hstore_to_array(h)"
194
- end
195
-
196
- it "#to_array should return a PGArrayOp" do
197
- @ds.literal(@h.to_array[0]).must_equal "hstore_to_array(h)[0]"
198
- end
199
-
200
- it "#to_matrix should use the hstore_to_matrix function" do
201
- @ds.literal(@h.to_matrix).must_equal "hstore_to_matrix(h)"
202
- end
203
-
204
- it "#to_matrix should return a PGArrayOp" do
205
- @ds.literal(@h.to_matrix[0]).must_equal "hstore_to_matrix(h)[0]"
206
- end
207
-
208
- it "#values and #avals should use the avals function" do
209
- @ds.literal(@h.values).must_equal "avals(h)"
210
- @ds.literal(@h.avals).must_equal "avals(h)"
211
- end
212
-
213
- it "#values and #avals should return PGArrayOps" do
214
- @ds.literal(@h.values[0]).must_equal "avals(h)[0]"
215
- @ds.literal(@h.avals[0]).must_equal "avals(h)[0]"
216
- end
217
-
218
- it "should have Sequel.hstore_op return HStoreOp instances as-is" do
219
- Sequel.hstore_op(@h).must_be_same_as(@h)
220
- end
221
-
222
- it "should have Sequel.hstore return HStoreOp instances" do
223
- Sequel.hstore(:h).must_equal @h
224
- end
225
-
226
- it "should be able to turn expressions into hstore ops using hstore" do
227
- @ds.literal(Sequel.qualify(:b, :a).hstore['a']).must_equal "(b.a -> 'a')"
228
- @ds.literal(Sequel.function(:a, :b).hstore['a']).must_equal "(a(b) -> 'a')"
229
- end
230
-
231
- it "should be able to turn literal strings into hstore ops using hstore" do
232
- @ds.literal(Sequel.lit('a').hstore['a']).must_equal "(a -> 'a')"
233
- end
234
-
235
- it "should allow transforming HStore instances into HStoreOp instances" do
236
- @ds.literal(Sequel.hstore('a'=>'b').op['a']).must_equal "('\"a\"=>\"b\"'::hstore -> 'a')"
237
- end
238
- end