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,201 +0,0 @@
1
- require_relative "spec_helper"
2
-
3
- describe "identifier_mangling extension" do
4
- it "should respect the :quote_identifiers option" do
5
- db = Sequel::Database.new(:quote_identifiers=>false).extension(:identifier_mangling)
6
- db.quote_identifiers?.must_equal false
7
- db = Sequel::Database.new(:quote_identifiers=>true).extension(:identifier_mangling)
8
- db.quote_identifiers?.must_equal true
9
- end
10
-
11
- it "should respect the :quote_identifiers setting" do
12
- db = Sequel::Database.new.extension(:identifier_mangling)
13
- db.quote_identifiers?.must_equal true
14
- db.quote_identifiers = false
15
- db.quote_identifiers?.must_equal false
16
- end
17
-
18
- it "should upcase on input and downcase on output by default" do
19
- db = Sequel::Database.new.extension(:identifier_mangling)
20
- db.send(:identifier_input_method_default).must_equal :upcase
21
- db.send(:identifier_output_method_default).must_equal :downcase
22
- end
23
-
24
- it "should respect the :identifier_input_method option" do
25
- db = Sequel::Database.new.extension(:identifier_mangling)
26
- db.identifier_input_method.must_equal :upcase
27
- db.identifier_input_method = nil
28
- db.identifier_input_method.must_be_nil
29
- db = Sequel::Database.new(:identifier_input_method=>nil).extension(:identifier_mangling)
30
- db.identifier_input_method.must_be_nil
31
- db.identifier_input_method = :downcase
32
- db.identifier_input_method.must_equal :downcase
33
- db = Sequel::Database.new(:identifier_input_method=>:upcase).extension(:identifier_mangling)
34
- db.identifier_input_method.must_equal :upcase
35
- db.identifier_input_method = nil
36
- db.identifier_input_method.must_be_nil
37
- end
38
-
39
- it "should respect the :identifier_output_method option" do
40
- db = Sequel::Database.new.extension(:identifier_mangling)
41
- db.identifier_output_method.must_equal :downcase
42
- db.identifier_output_method = nil
43
- db.identifier_output_method.must_be_nil
44
- db = Sequel::Database.new(:identifier_output_method=>nil).extension(:identifier_mangling)
45
- db.identifier_output_method.must_be_nil
46
- db.identifier_output_method = :downcase
47
- db.identifier_output_method.must_equal :downcase
48
- db = Sequel::Database.new(:identifier_output_method=>:upcase).extension(:identifier_mangling)
49
- db.identifier_output_method.must_equal :upcase
50
- db.identifier_output_method = nil
51
- db.identifier_output_method.must_be_nil
52
- end
53
-
54
- it "should respect the identifier_input_method_default method if Sequel.identifier_input_method is not called" do
55
- class Sequel::Database
56
- @identifier_input_method = nil
57
- end
58
- x = Class.new(Sequel::Database){def dataset_class_default; Sequel::Dataset end; def identifier_input_method_default; :downcase end}
59
- x.new.extension(:identifier_mangling).identifier_input_method.must_equal :downcase
60
- y = Class.new(Sequel::Database){def dataset_class_default; Sequel::Dataset end; def identifier_input_method_default; :camelize end}
61
- y.new.extension(:identifier_mangling).identifier_input_method.must_equal :camelize
62
- end
63
-
64
- it "should respect the identifier_output_method_default method if Sequel.identifier_output_method is not called" do
65
- class Sequel::Database
66
- @identifier_output_method = nil
67
- end
68
- x = Class.new(Sequel::Database){def dataset_class_default; Sequel::Dataset end; def identifier_output_method_default; :upcase end}
69
- x.new.extension(:identifier_mangling).identifier_output_method.must_equal :upcase
70
- y = Class.new(Sequel::Database){def dataset_class_default; Sequel::Dataset end; def identifier_output_method_default; :underscore end}
71
- y.new.extension(:identifier_mangling).identifier_output_method.must_equal :underscore
72
- end
73
- end
74
-
75
- describe "Database#input_identifier_meth" do
76
- it "should be the input_identifer method of a default dataset for this database" do
77
- db = Sequel::Database.new.extension(:identifier_mangling)
78
- db.identifier_input_method = nil
79
- db.send(:input_identifier_meth).call(:a).must_equal 'a'
80
- db.identifier_input_method = :upcase
81
- db.send(:input_identifier_meth).call(:a).must_equal 'A'
82
- end
83
- end
84
-
85
- describe "Database#output_identifier_meth" do
86
- it "should be the output_identifer method of a default dataset for this database" do
87
- db = Sequel::Database.new.extension(:identifier_mangling)
88
- db.identifier_output_method = nil
89
- db.send(:output_identifier_meth).call('A').must_equal :A
90
- db.identifier_output_method = :downcase
91
- db.send(:output_identifier_meth).call('A').must_equal :a
92
- end
93
- end
94
-
95
- describe "Database#metadata_dataset" do
96
- it "should be a dataset with the default settings for identifier_mangling" do
97
- ds = Sequel::Database.new.extension(:identifier_mangling).send(:metadata_dataset)
98
- ds.literal(:a).must_equal "\"A\""
99
- ds.send(:output_identifier, 'A').must_equal :a
100
- end
101
- end
102
-
103
- describe "Dataset" do
104
- before do
105
- @dataset = Sequel.mock.extension(:identifier_mangling).dataset
106
- end
107
-
108
- it "should get quote_identifiers default from database" do
109
- db = Sequel::Database.new(:quote_identifiers=>true).extension(:identifier_mangling)
110
- db[:a].quote_identifiers?.must_equal true
111
- db = Sequel::Database.new(:quote_identifiers=>false).extension(:identifier_mangling)
112
- db[:a].quote_identifiers?.must_equal false
113
- end
114
-
115
- it "should get identifier_input_method default from database" do
116
- db = Sequel::Database.new(:identifier_input_method=>:upcase).extension(:identifier_mangling)
117
- db[:a].identifier_input_method.must_equal :upcase
118
- db = Sequel::Database.new(:identifier_input_method=>:downcase).extension(:identifier_mangling)
119
- db[:a].identifier_input_method.must_equal :downcase
120
- end
121
-
122
- it "should get identifier_output_method default from database" do
123
- db = Sequel::Database.new(:identifier_output_method=>:upcase).extension(:identifier_mangling)
124
- db[:a].identifier_output_method.must_equal :upcase
125
- db = Sequel::Database.new(:identifier_output_method=>:downcase).extension(:identifier_mangling)
126
- db[:a].identifier_output_method.must_equal :downcase
127
- end
128
-
129
- it "should have with_quote_identifiers method which returns cloned dataset with changed literalization of identifiers" do
130
- @dataset.with_quote_identifiers(true).literal(:a).must_equal '"a"'
131
- @dataset.with_quote_identifiers(false).literal(:a).must_equal 'a'
132
- ds = @dataset.freeze.with_quote_identifiers(false)
133
- ds.literal(:a).must_equal 'a'
134
- ds.frozen?.must_equal true
135
- end
136
-
137
- it "should have with_identifier_input_method method which returns cloned dataset with changed literalization of identifiers" do
138
- @dataset.with_identifier_input_method(:upcase).literal(:a).must_equal 'A'
139
- @dataset.with_identifier_input_method(:downcase).literal(:A).must_equal 'a'
140
- @dataset.with_identifier_input_method(:reverse).literal(:at_b).must_equal 'b_ta'
141
- ds = @dataset.freeze.with_identifier_input_method(:reverse)
142
- ds.frozen?.must_equal true
143
- ds.literal(:at_b).must_equal 'b_ta'
144
- end
145
-
146
- it "should have with_identifier_output_method method which returns cloned dataset with changed identifiers returned from the database" do
147
- @dataset.send(:output_identifier, "at_b_C").must_equal :at_b_C
148
- @dataset.with_identifier_output_method(:upcase).send(:output_identifier, "at_b_C").must_equal :AT_B_C
149
- @dataset.with_identifier_output_method(:downcase).send(:output_identifier, "at_b_C").must_equal :at_b_c
150
- @dataset.with_identifier_output_method(:reverse).send(:output_identifier, "at_b_C").must_equal :C_b_ta
151
- ds = @dataset.freeze.with_identifier_output_method(:reverse)
152
- ds.send(:output_identifier, "at_b_C").must_equal :C_b_ta
153
- ds.frozen?.must_equal true
154
- end
155
-
156
- it "should have output_identifier handle empty identifiers" do
157
- @dataset.send(:output_identifier, "").must_equal :untitled
158
- @dataset.with_identifier_output_method(:upcase).send(:output_identifier, "").must_equal :UNTITLED
159
- @dataset.with_identifier_output_method(:downcase).send(:output_identifier, "").must_equal :untitled
160
- @dataset.with_identifier_output_method(:reverse).send(:output_identifier, "").must_equal :deltitnu
161
- end
162
- end
163
-
164
- describe "identifier_mangling extension" do
165
- it "should be able to load dialects based on the database name" do
166
- Sequel.mock(:host=>'access').select(Date.new(2011, 12, 13)).sql.must_equal 'SELECT #2011-12-13#'
167
- Sequel.mock(:host=>'db2').select(1).sql.must_equal 'SELECT 1 FROM "SYSIBM"."SYSDUMMY1"'
168
- Sequel.mock(:host=>'mssql')[:a].full_text_search(:b, 'c').sql.must_equal "SELECT * FROM [A] WHERE (CONTAINS ([B], 'c'))"
169
- Sequel.mock(:host=>'mysql')[:a].full_text_search(:b, 'c').sql.must_equal "SELECT * FROM `a` WHERE (MATCH (`b`) AGAINST ('c'))"
170
- Sequel.mock(:host=>'oracle')[:a].limit(1).sql.must_equal 'SELECT * FROM (SELECT * FROM "A") "T1" WHERE (ROWNUM <= 1)'
171
- Sequel.mock(:host=>'postgres')[:a].full_text_search(:b, 'c').sql.must_equal "SELECT * FROM \"a\" WHERE (to_tsvector(CAST('simple' AS regconfig), (COALESCE(\"b\", ''))) @@ to_tsquery(CAST('simple' AS regconfig), 'c'))"
172
- Sequel.mock(:host=>'sqlanywhere').from(:a).offset(1).sql.must_equal 'SELECT TOP 2147483647 START AT (1 + 1) * FROM "A"'
173
- Sequel.mock(:host=>'sqlite')[Sequel[:a].as(:b)].sql.must_equal "SELECT * FROM `a` AS 'b'"
174
- end
175
- end
176
-
177
- describe Sequel::Model, ".[] optimization" do
178
- before do
179
- @db = Sequel.mock(:quote_identifiers=>true).extension(:identifier_mangling)
180
- def @db.schema(*) [[:id, {:primary_key=>true}]] end
181
- def @db.supports_schema_parsing?() true end
182
- @c = Class.new(Sequel::Model(@db))
183
- @ds = @db.dataset.with_quote_identifiers(true)
184
- end
185
-
186
- it "should have simple_pk and simple_table respect dataset's identifier input methods" do
187
- ds = @db.from(:ab).with_identifier_input_method(:reverse)
188
- @c.set_dataset ds
189
- @c.simple_table.must_equal '"ba"'
190
- @c.set_primary_key :cd
191
- @c.simple_pk.must_equal '"dc"'
192
- @c.set_dataset ds.from(Sequel[:ef][:gh])
193
- @c.simple_table.must_equal '"fe"."hg"'
194
- end
195
-
196
- with_symbol_splitting "should have simple_pk and simple_table respect dataset's identifier input methods when using splittable symbols" do
197
- ds = @db.from(:ab).with_identifier_input_method(:reverse)
198
- @c.set_dataset ds.from(:ef__gh)
199
- @c.simple_table.must_equal '"fe"."hg"'
200
- end
201
- end
@@ -1,58 +0,0 @@
1
- require_relative "spec_helper"
2
-
3
- describe "Sequel::Dataset::ImplicitSubquery" do
4
- it "should implicitly use a subquery for most dataset query methods" do
5
- db = Sequel.mock
6
- db.extend_datasets{def supports_cte?; true end}
7
- ds = db["SELECT * FROM table"].extension(:implicit_subquery)
8
- ds.columns(:id, :a)
9
- ods = db[:c]
10
- ods.columns(:id, :b)
11
-
12
- ds.cross_join(:c).sql.must_equal "SELECT * FROM (SELECT * FROM table) AS t1 CROSS JOIN c"
13
- ds.distinct.sql.must_equal "SELECT DISTINCT * FROM (SELECT * FROM table) AS t1"
14
- ds.except(ods).sql.must_equal "SELECT * FROM (SELECT * FROM (SELECT * FROM table) AS t1 EXCEPT SELECT * FROM c) AS t1"
15
- ds.exclude(:c).sql.must_equal "SELECT * FROM (SELECT * FROM table) AS t1 WHERE NOT c"
16
- ds.exclude_having(:c).sql.must_equal "SELECT * FROM (SELECT * FROM table) AS t1 HAVING NOT c"
17
- ds.filter(:c).sql.must_equal "SELECT * FROM (SELECT * FROM table) AS t1 WHERE c"
18
- ds.for_update.sql.must_equal "SELECT * FROM (SELECT * FROM table) AS t1 FOR UPDATE"
19
- ds.full_join(:c).sql.must_equal "SELECT * FROM (SELECT * FROM table) AS t1 FULL JOIN c"
20
- ds.full_outer_join(:c).sql.must_equal "SELECT * FROM (SELECT * FROM table) AS t1 FULL OUTER JOIN c"
21
- ds.graph(ods).sql.must_equal "SELECT t1.id, t1.a, c.id AS c_id, c.b FROM (SELECT * FROM table) AS t1 LEFT OUTER JOIN c"
22
- ds.grep(:c, 'a').sql.must_equal "SELECT * FROM (SELECT * FROM table) AS t1 WHERE ((c LIKE 'a' ESCAPE '\\'))"
23
- ds.group(:c).sql.must_equal "SELECT * FROM (SELECT * FROM table) AS t1 GROUP BY c"
24
- ds.group_append(:c).sql.must_equal "SELECT * FROM (SELECT * FROM table) AS t1 GROUP BY c"
25
- ds.group_and_count(:c).sql.must_equal "SELECT c, count(*) AS count FROM (SELECT * FROM table) AS t1 GROUP BY c"
26
- ds.group_by(:c).sql.must_equal "SELECT * FROM (SELECT * FROM table) AS t1 GROUP BY c"
27
- ds.having(:c).sql.must_equal "SELECT * FROM (SELECT * FROM table) AS t1 HAVING c"
28
- ds.inner_join(:c, [:d]).sql.must_equal "SELECT * FROM (SELECT * FROM table) AS t1 INNER JOIN c USING (d)"
29
- ds.intersect(ods).sql.must_equal "SELECT * FROM (SELECT * FROM (SELECT * FROM table) AS t1 INTERSECT SELECT * FROM c) AS t1"
30
- ds.invert.sql.must_equal "SELECT * FROM (SELECT * FROM table) AS t1 WHERE 'f'"
31
- ds.join(:c, [:d]).sql.must_equal "SELECT * FROM (SELECT * FROM table) AS t1 INNER JOIN c USING (d)"
32
- ds.join_table(:inner, :c, [:d]).sql.must_equal "SELECT * FROM (SELECT * FROM table) AS t1 INNER JOIN c USING (d)"
33
- ds.left_join(:c, [:d]).sql.must_equal "SELECT * FROM (SELECT * FROM table) AS t1 LEFT JOIN c USING (d)"
34
- ds.left_outer_join(:c, [:d]).sql.must_equal "SELECT * FROM (SELECT * FROM table) AS t1 LEFT OUTER JOIN c USING (d)"
35
- ds.limit(1).sql.must_equal "SELECT * FROM (SELECT * FROM table) AS t1 LIMIT 1"
36
- ds.lock_style('FOR UPDATE').sql.must_equal "SELECT * FROM (SELECT * FROM table) AS t1 FOR UPDATE"
37
- ds.natural_full_join(:c).sql.must_equal "SELECT * FROM (SELECT * FROM table) AS t1 NATURAL FULL JOIN c"
38
- ds.natural_join(:c).sql.must_equal "SELECT * FROM (SELECT * FROM table) AS t1 NATURAL JOIN c"
39
- ds.natural_left_join(:c).sql.must_equal "SELECT * FROM (SELECT * FROM table) AS t1 NATURAL LEFT JOIN c"
40
- ds.natural_right_join(:c).sql.must_equal "SELECT * FROM (SELECT * FROM table) AS t1 NATURAL RIGHT JOIN c"
41
- ds.offset(1).sql.must_equal "SELECT * FROM (SELECT * FROM table) AS t1 OFFSET 1"
42
- ds.order(:c).sql.must_equal "SELECT * FROM (SELECT * FROM table) AS t1 ORDER BY c"
43
- ds.order_append(:c).sql.must_equal "SELECT * FROM (SELECT * FROM table) AS t1 ORDER BY c"
44
- ds.order_by(:c).sql.must_equal "SELECT * FROM (SELECT * FROM table) AS t1 ORDER BY c"
45
- ds.order_more(:c).sql.must_equal "SELECT * FROM (SELECT * FROM table) AS t1 ORDER BY c"
46
- ds.order_prepend(:c).sql.must_equal "SELECT * FROM (SELECT * FROM table) AS t1 ORDER BY c"
47
- ds.right_join(:c, [:d]).sql.must_equal "SELECT * FROM (SELECT * FROM table) AS t1 RIGHT JOIN c USING (d)"
48
- ds.right_outer_join(:c, [:d]).sql.must_equal "SELECT * FROM (SELECT * FROM table) AS t1 RIGHT OUTER JOIN c USING (d)"
49
- ds.select(:c).sql.must_equal "SELECT c FROM (SELECT * FROM table) AS t1"
50
- ds.select_append(:c).sql.must_equal "SELECT *, c FROM (SELECT * FROM table) AS t1"
51
- ds.select_group(:c).sql.must_equal "SELECT c FROM (SELECT * FROM table) AS t1 GROUP BY c"
52
- ds.select_more(:c).sql.must_equal "SELECT *, c FROM (SELECT * FROM table) AS t1"
53
- ds.union(ods).sql.must_equal "SELECT * FROM (SELECT * FROM (SELECT * FROM table) AS t1 UNION SELECT * FROM c) AS t1"
54
- ds.where(:c).sql.must_equal "SELECT * FROM (SELECT * FROM table) AS t1 WHERE c"
55
- ds.with(:d, ods).sql.must_equal "WITH d AS (SELECT * FROM c) SELECT * FROM (SELECT * FROM table) AS t1"
56
- ds.with_recursive(:d, ods, ods).sql.must_equal "WITH d AS (SELECT * FROM c UNION ALL SELECT * FROM c) SELECT * FROM (SELECT * FROM table) AS t1"
57
- end
58
- end
@@ -1,66 +0,0 @@
1
- require_relative "spec_helper"
2
-
3
- describe "index_caching extension" do
4
- before do
5
- @db = Sequel.connect('mock://postgres').extension(:index_caching)
6
- @indexes = {'"table"'=>{:table_idx_unique=>{:columns=>[:first_col, :second_col], :unique=>true, :deferrable=>nil}}}
7
- @filename = "spec/files/test_indexes_#$$.dump"
8
- @db.instance_variable_set(:@indexes, @indexes)
9
- end
10
- after do
11
- File.delete(@filename) if File.exist?(@filename)
12
- end
13
-
14
- it "#indexes should return cached index information" do
15
- @db.indexes(:table).must_equal @indexes['"table"']
16
- @db.indexes(:table, {}).must_equal @indexes['"table"']
17
- end
18
-
19
- it "#indexes should skip cached information if given options" do
20
- @db.indexes(:table, :schema=>:b).must_equal({})
21
- end
22
-
23
- it "Database should remove cached indexes when schema is changed" do
24
- @db.create_table(:table){Integer :a}
25
- @db.indexes(:table).must_equal({})
26
- end
27
-
28
- it "Database#freeze should allow cached information to work" do
29
- @db.freeze.indexes(:table).must_equal @indexes['"table"']
30
- end
31
-
32
- it "Database#freeze should allow removing index information" do
33
- @db.freeze
34
- @db.create_table(:table){Integer :a}
35
- @db.indexes(:table).must_equal({})
36
- end
37
-
38
- it "Database#dump_index_cache should dump the index cache to the given file" do
39
- File.exist?(@filename).must_equal false
40
- @db.dump_index_cache(@filename)
41
- File.exist?(@filename).must_equal true
42
- File.size(@filename).must_be :>, 0
43
- end
44
-
45
- it "Database#load_index_cache should load the index cache from the given file dumped by #dump_index_cache" do
46
- @db.dump_index_cache(@filename)
47
- db = Sequel::Database.new.extension(:index_caching)
48
- db.load_index_cache(@filename)
49
- db.extension(:index_caching)
50
- @db.instance_variable_get(:@indexes).must_equal @indexes
51
- end
52
-
53
- it "Database#dump_index_cache? should dump the index cache to the given file unless the file exists" do
54
- File.open(@filename, 'wb'){|f|}
55
- File.size(@filename).must_equal 0
56
- @db.dump_index_cache?(@filename)
57
- File.size(@filename).must_equal 0
58
- end
59
-
60
- it "Database#load_index_cache? should load the index cache from the given file if it exists" do
61
- db = Sequel::Database.new.extension(:index_caching)
62
- File.exist?(@filename).must_equal false
63
- db.load_index_cache?(@filename)
64
- db.instance_variable_get(:@indexes).must_equal({})
65
- end
66
- end
@@ -1,183 +0,0 @@
1
- require_relative "spec_helper"
2
-
3
- Sequel.extension :inflector
4
-
5
- describe String do
6
- it "#camelize and #camelcase should transform the word to CamelCase" do
7
- "egg_and_hams".camelize.must_equal "EggAndHams"
8
- "egg_and_hams".camelize(false).must_equal "eggAndHams"
9
- "post".camelize.must_equal "Post"
10
- "post".camelcase.must_equal "Post"
11
- end
12
-
13
- it "#constantize should eval the string to get a constant" do
14
- "String".constantize.must_equal String
15
- "String::Inflections".constantize.must_equal String::Inflections
16
- proc{"BKSDDF".constantize}.must_raise NameError
17
- proc{"++A++".constantize}.must_raise NameError
18
- end
19
-
20
- it "#dasherize should transform underscores to dashes" do
21
- "egg_and_hams".dasherize.must_equal "egg-and-hams"
22
- "post".dasherize.must_equal "post"
23
- end
24
-
25
- it "#demodulize should remove any preceding modules" do
26
- "String::Inflections::Blah".demodulize.must_equal "Blah"
27
- "String::Inflections".demodulize.must_equal "Inflections"
28
- "String".demodulize.must_equal "String"
29
- end
30
-
31
- it "#humanize should remove _i, transform underscore to spaces, and capitalize" do
32
- "egg_and_hams".humanize.must_equal "Egg and hams"
33
- "post".humanize.must_equal "Post"
34
- "post_id".humanize.must_equal "Post"
35
- end
36
-
37
- it "#titleize and #titlecase should underscore, humanize, and capitalize all words" do
38
- "egg-and: hams".titleize.must_equal "Egg And: Hams"
39
- "post".titleize.must_equal "Post"
40
- "post".titlecase.must_equal "Post"
41
- end
42
-
43
- it "#underscore should add underscores between CamelCased words, change :: to / and - to _, and downcase" do
44
- "EggAndHams".underscore.must_equal "egg_and_hams"
45
- "EGGAndHams".underscore.must_equal "egg_and_hams"
46
- "Egg::And::Hams".underscore.must_equal "egg/and/hams"
47
- "post".underscore.must_equal "post"
48
- "post-id".underscore.must_equal "post_id"
49
- end
50
-
51
- it "#pluralize should transform words from singular to plural" do
52
- "post".pluralize.must_equal "posts"
53
- "octopus".pluralize.must_equal"octopuses"
54
- "the blue mailman".pluralize.must_equal "the blue mailmen"
55
- "CamelOctopus".pluralize.must_equal "CamelOctopuses"
56
- end
57
-
58
- it "#singularize should transform words from plural to singular" do
59
- "posts".singularize.must_equal "post"
60
- "octopuses".singularize.must_equal "octopus"
61
- "the blue mailmen".singularize.must_equal "the blue mailman"
62
- "CamelOctopuses".singularize.must_equal "CamelOctopus"
63
- end
64
-
65
- it "#tableize should transform class names to table names" do
66
- "RawScaledScorer".tableize.must_equal "raw_scaled_scorers"
67
- "egg_and_ham".tableize.must_equal "egg_and_hams"
68
- "fancyCategory".tableize.must_equal "fancy_categories"
69
- end
70
-
71
- it "#classify should tranform table names to class names" do
72
- "egg_and_hams".classify.must_equal "EggAndHam"
73
- "post".classify.must_equal "Post"
74
- end
75
-
76
- it "#foreign_key should create a foreign key name from a class name" do
77
- "Message".foreign_key.must_equal "message_id"
78
- "Message".foreign_key(false).must_equal "messageid"
79
- "Admin::Post".foreign_key.must_equal "post_id"
80
- end
81
- end
82
-
83
- describe String::Inflections do
84
- before do
85
- @plurals, @singulars, @uncountables = String.inflections.plurals.dup, String.inflections.singulars.dup, String.inflections.uncountables.dup
86
- end
87
- after do
88
- String.inflections.plurals.replace(@plurals)
89
- String.inflections.singulars.replace(@singulars)
90
- String.inflections.uncountables.replace(@uncountables)
91
- end
92
-
93
- it "should be possible to clear the list of singulars, plurals, and uncountables" do
94
- String.inflections.clear(:plurals)
95
- String.inflections.plurals.must_equal []
96
- String.inflections.plural('blah', 'blahs')
97
- String.inflections.clear
98
- String.inflections.plurals.must_equal []
99
- String.inflections.singulars.must_equal []
100
- String.inflections.uncountables.must_equal []
101
- end
102
-
103
- it "should be able to specify new inflection rules" do
104
- String.inflections do |i|
105
- i.plural(/xx$/i, 'xxx')
106
- i.singular(/ttt$/i, 'tt')
107
- i.irregular('yy', 'yyy')
108
- i.uncountable(%w'zz')
109
- end
110
- 'roxx'.pluralize.must_equal 'roxxx'
111
- 'rottt'.singularize.must_equal 'rott'
112
- 'yy'.pluralize.must_equal 'yyy'
113
- 'yyy'.singularize.must_equal 'yy'
114
- 'zz'.pluralize.must_equal 'zz'
115
- 'zz'.singularize.must_equal 'zz'
116
- end
117
-
118
- it "should be yielded and returned by String.inflections" do
119
- String.inflections{|i| i.must_equal String::Inflections}.must_equal String::Inflections
120
- end
121
- end
122
-
123
- describe 'Default inflections' do
124
- it "should support the default inflection rules" do
125
- {
126
- :test=>:tests,
127
- :ax=>:axes,
128
- :testis=>:testes,
129
- :octopus=>:octopuses,
130
- :virus=>:viruses,
131
- :alias=>:aliases,
132
- :status=>:statuses,
133
- :bus=>:buses,
134
- :buffalo=>:buffaloes,
135
- :tomato=>:tomatoes,
136
- :datum=>:data,
137
- :bacterium=>:bacteria,
138
- :analysis=>:analyses,
139
- :basis=>:bases,
140
- :diagnosis=>:diagnoses,
141
- :parenthesis=>:parentheses,
142
- :prognosis=>:prognoses,
143
- :synopsis=>:synopses,
144
- :thesis=>:theses,
145
- :wife=>:wives,
146
- :giraffe=>:giraffes,
147
- :self=>:selves,
148
- :dwarf=>:dwarves,
149
- :hive=>:hives,
150
- :fly=>:flies,
151
- :buy=>:buys,
152
- :soliloquy=>:soliloquies,
153
- :day=>:days,
154
- :attorney=>:attorneys,
155
- :boy=>:boys,
156
- :hoax=>:hoaxes,
157
- :lunch=>:lunches,
158
- :princess=>:princesses,
159
- :matrix=>:matrices,
160
- :vertex=>:vertices,
161
- :index=>:indices,
162
- :mouse=>:mice,
163
- :louse=>:lice,
164
- :quiz=>:quizzes,
165
- :motive=>:motives,
166
- :movie=>:movies,
167
- :series=>:series,
168
- :crisis=>:crises,
169
- :person=>:people,
170
- :man=>:men,
171
- :woman=>:women,
172
- :child=>:children,
173
- :sex=>:sexes,
174
- :move=>:moves
175
- }.each do |k, v|
176
- k.to_s.pluralize.must_equal v.to_s
177
- v.to_s.singularize.must_equal k.to_s
178
- end
179
- [:equipment, :information, :rice, :money, :species, :series, :fish, :sheep, :news].each do |a|
180
- a.to_s.pluralize.must_equal a.to_s.singularize
181
- end
182
- end
183
- end