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,69 +0,0 @@
1
- require_relative "spec_helper"
2
-
3
- Sequel.extension :blank
4
-
5
- describe "Object#blank?" do
6
- it "it should be true if the object responds true to empty?" do
7
- [].blank?.must_equal true
8
- {}.blank?.must_equal true
9
- o = Object.new
10
- def o.empty?; true; end
11
- o.blank?.must_equal true
12
- end
13
-
14
- it "it should be false if the object doesn't respond true to empty?" do
15
- [2].blank?.must_equal false
16
- {1=>2}.blank?.must_equal false
17
- Object.new.blank?.must_equal false
18
- end
19
- end
20
-
21
- describe "Numeric#blank?" do
22
- it "it should always be false" do
23
- 1.blank?.must_equal false
24
- 0.blank?.must_equal false
25
- -1.blank?.must_equal false
26
- 1.0.blank?.must_equal false
27
- 0.0.blank?.must_equal false
28
- -1.0.blank?.must_equal false
29
- 10000000000000000.blank?.must_equal false
30
- -10000000000000000.blank?.must_equal false
31
- 10000000000000000.0.blank?.must_equal false
32
- -10000000000000000.0.blank?.must_equal false
33
- end
34
- end
35
-
36
- describe "NilClass#blank?" do
37
- it "it should always be true" do
38
- nil.blank?.must_equal true
39
- end
40
- end
41
-
42
- describe "TrueClass#blank?" do
43
- it "it should always be false" do
44
- true.blank?.must_equal false
45
- end
46
- end
47
-
48
- describe "FalseClass#blank?" do
49
- it "it should always be true" do
50
- false.blank?.must_equal true
51
- end
52
- end
53
-
54
- describe "String#blank?" do
55
- it "it should be true if the string is empty" do
56
- ''.blank?.must_equal true
57
- end
58
- it "it should be true if the string is composed of just whitespace" do
59
- ' '.blank?.must_equal true
60
- "\r\n\t".blank?.must_equal true
61
- (' '*4000).blank?.must_equal true
62
- ("\r\n\t"*4000).blank?.must_equal true
63
- end
64
- it "it should be false if the string has any non whitespace characters" do
65
- '1'.blank?.must_equal false
66
- ("\r\n\t"*4000 + 'a').blank?.must_equal false
67
- ("\r\na\t"*4000).blank?.must_equal false
68
- end
69
- end
@@ -1,93 +0,0 @@
1
- require_relative "spec_helper"
2
-
3
- describe Sequel::Model, "BooleanReaders plugin" do
4
- before do
5
- @db = Sequel.mock
6
- def @db.supports_schema_parsing?() true end
7
- def @db.schema(*args)
8
- [[:id, {}], [:z, {:type=>:integer, :db_type=>'tinyint(1)'}], [:b, {:type=>:boolean, :db_type=>'boolean'}]]
9
- end
10
-
11
- @c = Class.new(Sequel::Model(@db[:items]))
12
- @p = proc do
13
- @columns = [:id, :b, :z]
14
- def columns; @columns; end
15
- end
16
- @c.instance_eval(&@p)
17
- end
18
-
19
- it "should create attribute? readers for all boolean attributes" do
20
- @c.plugin(:boolean_readers)
21
- o = @c.new
22
- o.b?.must_be_nil
23
- o.b = '1'
24
- o.b?.must_equal true
25
- o.b = '0'
26
- o.b?.must_equal false
27
- o.b = ''
28
- o.b?.must_be_nil
29
- end
30
-
31
- it "should not create attribute? readers for non-boolean attributes" do
32
- @c.plugin(:boolean_readers)
33
- proc{@c.new.z?}.must_raise(NoMethodError)
34
- proc{@c.new.id?}.must_raise(NoMethodError)
35
- end
36
-
37
- it "should accept a block to determine if an attribute is boolean" do
38
- @c.plugin(:boolean_readers){|c| db_schema[c][:db_type] == 'tinyint(1)'}
39
- proc{@c.new.b?}.must_raise(NoMethodError)
40
- o = @c.new
41
- o.z.must_be_nil
42
- o.z?.must_be_nil
43
- o.z = '1'
44
- o.z.must_equal 1
45
- o.z?.must_equal true
46
- o.z = '0'
47
- o.z.must_equal 0
48
- o.z?.must_equal false
49
- o.z = ''
50
- o.z.must_be_nil
51
- o.z?.must_be_nil
52
- end
53
-
54
- it "should create boolean readers when set_dataset is defined" do
55
- c = Class.new(Sequel::Model(@db))
56
- c.instance_eval(&@p)
57
- c.plugin(:boolean_readers)
58
- c.set_dataset(@db[:a])
59
- o = c.new
60
- o.b?.must_be_nil
61
- o.b = '1'
62
- o.b?.must_equal true
63
- o.b = '0'
64
- o.b?.must_equal false
65
- o.b = ''
66
- o.b?.must_be_nil
67
- proc{o.i?}.must_raise(NoMethodError)
68
-
69
- c = Class.new(Sequel::Model(@db))
70
- c.instance_eval(&@p)
71
- c.plugin(:boolean_readers){|x| db_schema[x][:db_type] == 'tinyint(1)'}
72
- c.set_dataset(@db[:a])
73
- o = c.new
74
- o.z.must_be_nil
75
- o.z?.must_be_nil
76
- o.z = '1'
77
- o.z.must_equal 1
78
- o.z?.must_equal true
79
- o.z = '0'
80
- o.z.must_equal 0
81
- o.z?.must_equal false
82
- o.z = ''
83
- o.z.must_be_nil
84
- o.z?.must_be_nil
85
- proc{o.b?}.must_raise(NoMethodError)
86
- end
87
-
88
- it "should handle cases where getting the columns raises an error" do
89
- def @c.columns; raise Sequel::Error end
90
- @c.plugin(:boolean_readers)
91
- proc{@c.new.b?}.must_raise(NoMethodError)
92
- end
93
- end
@@ -1,47 +0,0 @@
1
- require_relative "spec_helper"
2
-
3
- describe "boolean_subsets plugin" do
4
- before do
5
- @db = Sequel.mock
6
- def @db.supports_schema_parsing?() true end
7
- def @db.schema(*args)
8
- [[:asdaf9898as, {}], [:active, {:type=>:boolean}]]
9
- end
10
-
11
- @c = Class.new(Sequel::Model(@db[:items]))
12
- @p = proc do
13
- @columns = [:asdaf9898as, :active]
14
- def columns; @columns; end
15
- end
16
- @c.instance_eval(&@p)
17
- end
18
-
19
- it "should create subsets only for boolean attributes" do
20
- @c.plugin(:boolean_subsets)
21
- @c.active.sql.must_equal "SELECT * FROM items WHERE (active IS TRUE)"
22
- @c.respond_to?(:asdaf9898as).must_equal false
23
- end
24
-
25
- it "should handle a block passed to the plugin" do
26
- @c.plugin(:boolean_subsets){|c| ["where_#{c}", c]}
27
- @c.where_active.sql.must_equal "SELECT * FROM items WHERE active"
28
- @c.respond_to?(:active).must_equal false
29
- end
30
-
31
- it "should create boolean subsets when set_dataset is called" do
32
- c = Class.new(Sequel::Model(@db))
33
- c.instance_eval(&@p)
34
- c.plugin(:boolean_subsets)
35
- c.respond_to?(:active).must_equal false
36
-
37
- c.set_dataset(@db[:items])
38
- c.active.sql.must_equal "SELECT * FROM items WHERE (active IS TRUE)"
39
- c.respond_to?(:asdaf9898as).must_equal false
40
- end
41
-
42
- it "should handle cases where getting the columns raises an error" do
43
- def @c.columns; raise Sequel::Error end
44
- @c.plugin(:boolean_subsets)
45
- @c.respond_to?(:active).must_equal false
46
- end
47
- end
@@ -1,273 +0,0 @@
1
- require_relative "spec_helper"
2
-
3
- describe Sequel::Model, "caching" do
4
- before do
5
- @cache_class = Class.new(Hash) do
6
- attr_accessor :ttl
7
- def set(k, v, ttl); self[k] = v; @ttl = ttl; end
8
- def get(k); self[k]; end
9
- end
10
- cache = @cache_class.new
11
- @cache = cache
12
-
13
- @memcached_class = Class.new(Hash) do
14
- attr_accessor :ttl
15
- def set(k, v, ttl); self[k] = v; @ttl = ttl; end
16
- def get(k); if self[k] then return self[k]; else raise ArgumentError; end end
17
- def delete(k); if self[k] then super; else raise ArgumentError; end end
18
- end
19
- cache2 = @memcached_class.new
20
- @memcached = cache2
21
-
22
- @c = Class.new(Sequel::Model(:items))
23
- @c.class_eval do
24
- plugin :caching, cache
25
- def self.name; 'Item' end
26
-
27
- columns :name, :id
28
- end
29
-
30
- @c3 = Class.new(Sequel::Model(:items))
31
- @c3.class_eval do
32
- plugin :caching, cache2
33
- def self.name; 'Item' end
34
-
35
- columns :name, :id
36
- end
37
-
38
- @c4 = Class.new(Sequel::Model(:items))
39
- @c4.class_eval do
40
- plugin :caching, cache2, :ignore_exceptions => true
41
- def self.name; 'Item' end
42
-
43
- columns :name, :id
44
- end
45
-
46
-
47
- @c2 = Class.new(@c) do
48
- def self.name; 'SubItem' end
49
- end
50
-
51
- [@c, @c2, @c3, @c4].each do |c|
52
- c.dataset = c.dataset.with_fetch(:name => 'sharon'.dup, :id => 1).with_numrows(1)
53
- end
54
-
55
- @c.db.reset
56
- end
57
-
58
- it "should set the model's cache store" do
59
- @c.cache_store.wont_be_nil
60
- @c2.cache_store.wont_be_nil
61
- end
62
-
63
- it "should have a default ttl of 3600" do
64
- @c.cache_ttl.must_equal 3600
65
- @c2.cache_ttl.must_equal 3600
66
- end
67
-
68
- it "should take a ttl option" do
69
- c = Class.new(Sequel::Model(:items))
70
- c.plugin :caching, @cache, :ttl => 1234
71
- c.cache_ttl.must_equal 1234
72
- Class.new(c).cache_ttl.must_equal 1234
73
- end
74
-
75
- it "should allow overriding the ttl option via a plugin :caching call" do
76
- @c.plugin :caching, @cache, :ttl => 1234
77
- @c.cache_ttl.must_equal 1234
78
- Class.new(@c).cache_ttl.must_equal 1234
79
- end
80
-
81
- it "should offer a set_cache_ttl method for setting the ttl" do
82
- @c.cache_ttl.must_equal 3600
83
- @c.set_cache_ttl 1234
84
- @c.cache_ttl.must_equal 1234
85
- Class.new(@c).cache_ttl.must_equal 1234
86
- end
87
-
88
- it "should generate a cache key appropriate to the class via the Model#cache_key" do
89
- m = @c.new
90
- m.values[:id] = 1
91
- m.cache_key.must_equal "#{m.class}:1"
92
- m = @c2.new
93
- m.values[:id] = 1
94
- m.cache_key.must_equal "#{m.class}:1"
95
-
96
- # custom primary key
97
- @c.set_primary_key :ttt
98
- m = @c.new
99
- m.values[:ttt] = 333
100
- m.cache_key.must_equal "#{m.class}:333"
101
- c = Class.new(@c)
102
- m = c.new
103
- m.values[:ttt] = 333
104
- m.cache_key.must_equal "#{m.class}:333"
105
-
106
- # composite primary key
107
- @c.set_primary_key [:a, :b, :c]
108
- m = @c.new
109
- m.values[:a] = 123
110
- m.values[:c] = 456
111
- m.values[:b] = 789
112
- m.cache_key.must_equal "#{m.class}:123,789,456"
113
- c = Class.new(@c)
114
- m = c.new
115
- m.values[:a] = 123
116
- m.values[:c] = 456
117
- m.values[:b] = 789
118
- m.cache_key.must_equal "#{m.class}:123,789,456"
119
- end
120
-
121
- it "should generate a cache key via the Model.cache_key method" do
122
- @c.cache_key(1).must_equal "#{@c}:1"
123
- @c.cache_key([1, 2]).must_equal "#{@c}:1,2"
124
- end
125
-
126
- it "should raise error if attempting to generate cache_key and primary key value is null" do
127
- m = @c.new
128
- proc {m.cache_key}.must_raise(Sequel::Error)
129
- m.values[:id] = 1
130
- m.cache_key
131
-
132
- m = @c2.new
133
- proc {m.cache_key}.must_raise(Sequel::Error)
134
- m.values[:id] = 1
135
- m.cache_key
136
- end
137
-
138
- it "should not raise error if trying to save a new record" do
139
- @c.new(:name=>'blah').save
140
- @c.create(:name=>'blah')
141
- @c2.new(:name=>'blah').save
142
- @c2.create(:name=>'blah')
143
- end
144
-
145
- it "should set the cache when reading from the database" do
146
- @c.db.sqls.must_equal []
147
- @cache.must_be :empty?
148
-
149
- m = @c[1]
150
- @c.db.sqls.must_equal ['SELECT * FROM items WHERE id = 1']
151
- m.values.must_equal(:name=>"sharon", :id=>1)
152
- @cache[m.cache_key].must_equal m
153
- m2 = @c[1]
154
- @c.db.sqls.must_equal []
155
- m2.must_equal m
156
- m2.values.must_equal(:name=>"sharon", :id=>1)
157
-
158
- m = @c2[1]
159
- @c.db.sqls.must_equal ['SELECT * FROM items WHERE id = 1']
160
- m.values.must_equal(:name=>"sharon", :id=>1)
161
- @cache[m.cache_key].must_equal m
162
- m2 = @c2[1]
163
- @c.db.sqls.must_equal []
164
- m2.must_equal m
165
- m2.values.must_equal(:name=>"sharon", :id=>1)
166
- end
167
-
168
- it "should handle lookups by nil primary keys" do
169
- @c[nil].must_be_nil
170
- @c.db.sqls.must_equal []
171
- end
172
-
173
- it "should delete the cache when writing to the database" do
174
- m = @c[1]
175
- @cache[m.cache_key].must_equal m
176
- m.name = 'hey'
177
- m.save
178
- @cache.has_key?(m.cache_key).must_equal false
179
- @c.db.sqls.must_equal ["SELECT * FROM items WHERE id = 1", "UPDATE items SET name = 'hey' WHERE (id = 1)"]
180
-
181
- m = @c2[1]
182
- @cache[m.cache_key].must_equal m
183
- m.name = 'hey'
184
- m.save
185
- @cache.has_key?(m.cache_key).must_equal false
186
- @c.db.sqls.must_equal ["SELECT * FROM items WHERE id = 1", "UPDATE items SET name = 'hey' WHERE (id = 1)"]
187
- end
188
-
189
- it "should delete the cache when deleting the record" do
190
- m = @c[1]
191
- @cache[m.cache_key].must_equal m
192
- m.delete
193
- @cache.has_key?(m.cache_key).must_equal false
194
- @c.db.sqls.must_equal ["SELECT * FROM items WHERE id = 1", "DELETE FROM items WHERE id = 1"]
195
-
196
- m = @c2[1]
197
- @cache[m.cache_key].must_equal m
198
- m.delete
199
- @cache.has_key?(m.cache_key).must_equal false
200
- @c.db.sqls.must_equal ["SELECT * FROM items WHERE id = 1", "DELETE FROM items WHERE id = 1"]
201
- end
202
-
203
- it "should support #[] as a shortcut to #find with hash" do
204
- m = @c[:id => 3]
205
- @cache[m.cache_key].must_be_nil
206
- @c.db.sqls.must_equal ["SELECT * FROM items WHERE (id = 3) LIMIT 1"]
207
- m = @c[1]
208
- @cache[m.cache_key].must_equal m
209
- @c.db.sqls.must_equal ["SELECT * FROM items WHERE id = 1"]
210
- @c[:id => 4]
211
- @c.db.sqls.must_equal ["SELECT * FROM items WHERE (id = 4) LIMIT 1"]
212
-
213
- m = @c2[:id => 3]
214
- @cache[m.cache_key].must_be_nil
215
- @c.db.sqls.must_equal ["SELECT * FROM items WHERE (id = 3) LIMIT 1"]
216
- m = @c2[1]
217
- @cache[m.cache_key].must_equal m
218
- @c.db.sqls.must_equal ["SELECT * FROM items WHERE id = 1"]
219
- @c2[:id => 4]
220
- @c.db.sqls.must_equal ["SELECT * FROM items WHERE (id = 4) LIMIT 1"]
221
- end
222
-
223
- it "should support ignore_exception option" do
224
- c = Class.new(Sequel::Model(:items))
225
- c.plugin :caching, @cache, :ignore_exceptions => true
226
- Class.new(c).cache_ignore_exceptions.must_equal true
227
- end
228
-
229
- it "should raise an exception if cache_store is memcached and ignore_exception is not enabled" do
230
- proc{@c3[1]}.must_raise ArgumentError
231
- m = @c3.new.save
232
- proc{m.update({:name=>'blah'})}.must_raise ArgumentError
233
- end
234
-
235
- it "should rescue an exception if cache_store is memcached and ignore_exception is enabled" do
236
- @c4[1].values.must_equal(:name => 'sharon', :id => 1)
237
- @c4.dataset = @c4.dataset.with_fetch(:name => 'sharon', :id => 1, :x=>1)
238
- m = @c4.new.save
239
- m.update({:name=>'blah'})
240
- m.values.must_equal(:name => 'blah', :id => 1, :x => 1)
241
- end
242
-
243
- it "should support Model.cache_get_pk for getting a value from the cache by primary key" do
244
- @c.cache_get_pk(1).must_be_nil
245
- m = @c[1]
246
- @c.cache_get_pk(1).must_equal m
247
- end
248
-
249
- it "should support Model.cache_delete_pk for removing a value from the cache by primary key" do
250
- @c[1]
251
- @c.cache_get_pk(1).wont_equal nil
252
- @c.cache_delete_pk(1).must_be_nil
253
- @c.cache_get_pk(1).must_be_nil
254
- end
255
-
256
- it "should support overriding the cache key prefix" do
257
- c2 = Class.new(@c)
258
- def c2.cache_key_prefix; "ceetwo" end
259
- c3 = Class.new(c2)
260
- @c.cache_key(:id).wont_equal c2.cache_key(:id)
261
- c2.cache_key(:id).must_equal c3.cache_key(:id)
262
-
263
- @c[1]
264
- c2.cache_get_pk(1).must_be_nil
265
- m = c2[1]
266
- c2.cache_get_pk(1).values.must_equal @c[1].values
267
- c3.cache_get_pk(1).values.must_equal m.values
268
-
269
- m.name << m.name
270
- m.save
271
- c2[1].values.must_equal c3[1].values
272
- end
273
- end