ibm_db 5.2.0 → 5.3.1

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 (622) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGES +6 -0
  3. data/LICENSE +55 -18
  4. data/ext/Makefile +12 -12
  5. data/ext/ibm_db.c +62 -57
  6. data/ext/ibm_db.o +0 -0
  7. data/ext/ibm_db.so +0 -0
  8. data/ext/mkmf.log +11 -11
  9. data/ext/ruby_ibm_db_cli.c +1 -0
  10. data/ext/ruby_ibm_db_cli.o +0 -0
  11. data/lib/active_record/connection_adapters/ibm_db_adapter.rb +1458 -1279
  12. data/test/active_record/connection_adapters/fake_adapter.rb +5 -2
  13. data/test/activejob/destroy_association_async_test.rb +305 -0
  14. data/test/activejob/destroy_async_job_not_present_test.rb +31 -0
  15. data/test/activejob/helper.rb +15 -0
  16. data/test/assets/schema_dump_5_1.yml +345 -0
  17. data/test/cases/adapter_prevent_writes_test.rb +334 -0
  18. data/test/cases/adapter_test.rb +432 -218
  19. data/test/cases/adapters/mysql2/active_schema_test.rb +85 -75
  20. data/test/cases/adapters/mysql2/auto_increment_test.rb +34 -0
  21. data/test/cases/adapters/mysql2/bind_parameter_test.rb +5 -3
  22. data/test/cases/adapters/mysql2/boolean_test.rb +6 -4
  23. data/test/cases/adapters/mysql2/case_sensitivity_test.rb +26 -24
  24. data/test/cases/adapters/mysql2/charset_collation_test.rb +20 -17
  25. data/test/cases/adapters/mysql2/connection_test.rb +48 -50
  26. data/test/cases/adapters/mysql2/count_deleted_rows_with_lock_test.rb +28 -0
  27. data/test/cases/adapters/mysql2/datetime_precision_quoting_test.rb +23 -19
  28. data/test/cases/adapters/mysql2/enum_test.rb +32 -11
  29. data/test/cases/adapters/mysql2/explain_test.rb +13 -11
  30. data/test/cases/adapters/mysql2/json_test.rb +17 -188
  31. data/test/cases/adapters/mysql2/mysql2_adapter_prevent_writes_test.rb +208 -0
  32. data/test/cases/adapters/mysql2/mysql2_adapter_test.rb +183 -28
  33. data/test/cases/adapters/mysql2/nested_deadlock_test.rb +75 -0
  34. data/test/cases/adapters/mysql2/optimizer_hints_test.rb +69 -0
  35. data/test/cases/adapters/mysql2/schema_migrations_test.rb +26 -21
  36. data/test/cases/adapters/mysql2/schema_test.rb +24 -22
  37. data/test/cases/adapters/mysql2/set_test.rb +32 -0
  38. data/test/cases/adapters/mysql2/sp_test.rb +10 -8
  39. data/test/cases/adapters/mysql2/sql_types_test.rb +8 -6
  40. data/test/cases/adapters/mysql2/table_options_test.rb +93 -10
  41. data/test/cases/adapters/mysql2/transaction_test.rb +151 -0
  42. data/test/cases/adapters/mysql2/unsigned_type_test.rb +11 -9
  43. data/test/cases/adapters/mysql2/virtual_column_test.rb +66 -0
  44. data/test/cases/adapters/postgresql/active_schema_test.rb +40 -25
  45. data/test/cases/adapters/postgresql/array_test.rb +118 -63
  46. data/test/cases/adapters/postgresql/bit_string_test.rb +12 -10
  47. data/test/cases/adapters/postgresql/bytea_test.rb +26 -25
  48. data/test/cases/adapters/postgresql/case_insensitive_test.rb +10 -9
  49. data/test/cases/adapters/postgresql/change_schema_test.rb +7 -5
  50. data/test/cases/adapters/postgresql/cidr_test.rb +2 -0
  51. data/test/cases/adapters/postgresql/citext_test.rb +58 -58
  52. data/test/cases/adapters/postgresql/collation_test.rb +17 -15
  53. data/test/cases/adapters/postgresql/composite_test.rb +25 -23
  54. data/test/cases/adapters/postgresql/connection_test.rb +73 -85
  55. data/test/cases/adapters/postgresql/create_unlogged_tables_test.rb +74 -0
  56. data/test/cases/adapters/postgresql/datatype_test.rb +19 -22
  57. data/test/cases/adapters/postgresql/date_test.rb +42 -0
  58. data/test/cases/adapters/postgresql/domain_test.rb +9 -7
  59. data/test/cases/adapters/postgresql/enum_test.rb +12 -10
  60. data/test/cases/adapters/postgresql/explain_test.rb +10 -8
  61. data/test/cases/adapters/postgresql/extension_migration_test.rb +13 -12
  62. data/test/cases/adapters/postgresql/foreign_table_test.rb +109 -0
  63. data/test/cases/adapters/postgresql/full_text_test.rb +8 -6
  64. data/test/cases/adapters/postgresql/geometric_test.rb +57 -63
  65. data/test/cases/adapters/postgresql/hstore_test.rb +288 -280
  66. data/test/cases/adapters/postgresql/infinity_test.rb +54 -15
  67. data/test/cases/adapters/postgresql/integer_test.rb +2 -0
  68. data/test/cases/adapters/postgresql/interval_test.rb +99 -0
  69. data/test/cases/adapters/postgresql/json_test.rb +16 -201
  70. data/test/cases/adapters/postgresql/ltree_test.rb +14 -16
  71. data/test/cases/adapters/postgresql/money_test.rb +47 -16
  72. data/test/cases/adapters/postgresql/network_test.rb +36 -28
  73. data/test/cases/adapters/postgresql/numbers_test.rb +7 -5
  74. data/test/cases/adapters/postgresql/optimizer_hints_test.rb +71 -0
  75. data/test/cases/adapters/postgresql/partitions_test.rb +22 -0
  76. data/test/cases/adapters/postgresql/postgresql_adapter_prevent_writes_test.rb +205 -0
  77. data/test/cases/adapters/postgresql/postgresql_adapter_test.rb +178 -136
  78. data/test/cases/adapters/postgresql/prepared_statements_disabled_test.rb +27 -0
  79. data/test/cases/adapters/postgresql/quoting_test.rb +12 -6
  80. data/test/cases/adapters/postgresql/range_test.rb +406 -292
  81. data/test/cases/adapters/postgresql/referential_integrity_test.rb +16 -15
  82. data/test/cases/adapters/postgresql/rename_table_test.rb +9 -8
  83. data/test/cases/adapters/postgresql/schema_authorization_test.rb +14 -23
  84. data/test/cases/adapters/postgresql/schema_test.rb +207 -91
  85. data/test/cases/adapters/postgresql/serial_test.rb +9 -7
  86. data/test/cases/adapters/postgresql/statement_pool_test.rb +26 -6
  87. data/test/cases/adapters/postgresql/timestamp_test.rb +17 -15
  88. data/test/cases/adapters/postgresql/transaction_nested_test.rb +114 -0
  89. data/test/cases/adapters/postgresql/transaction_test.rb +189 -0
  90. data/test/cases/adapters/postgresql/type_lookup_test.rb +12 -10
  91. data/test/cases/adapters/postgresql/utils_test.rb +11 -9
  92. data/test/cases/adapters/postgresql/uuid_test.rb +226 -109
  93. data/test/cases/adapters/postgresql/xml_test.rb +10 -14
  94. data/test/cases/adapters/sqlite3/collation_test.rb +26 -15
  95. data/test/cases/adapters/sqlite3/copy_table_test.rb +31 -28
  96. data/test/cases/adapters/sqlite3/explain_test.rb +13 -11
  97. data/test/cases/adapters/sqlite3/json_test.rb +29 -0
  98. data/test/cases/adapters/sqlite3/quoting_test.rb +35 -57
  99. data/test/cases/adapters/sqlite3/sqlite3_adapter_prevent_writes_test.rb +186 -0
  100. data/test/cases/adapters/sqlite3/sqlite3_adapter_test.rb +318 -131
  101. data/test/cases/adapters/sqlite3/sqlite3_create_folder_test.rb +11 -11
  102. data/test/cases/adapters/sqlite3/statement_pool_test.rb +7 -6
  103. data/test/cases/adapters/sqlite3/transaction_test.rb +123 -0
  104. data/test/cases/aggregations_test.rb +14 -12
  105. data/test/cases/annotate_test.rb +46 -0
  106. data/test/cases/ar_schema_test.rb +153 -86
  107. data/test/cases/arel/attributes/attribute_test.rb +1145 -0
  108. data/test/cases/arel/attributes/math_test.rb +83 -0
  109. data/test/cases/arel/attributes_test.rb +27 -0
  110. data/test/cases/arel/collectors/bind_test.rb +40 -0
  111. data/test/cases/arel/collectors/composite_test.rb +47 -0
  112. data/test/cases/arel/collectors/sql_string_test.rb +41 -0
  113. data/test/cases/arel/collectors/substitute_bind_collector_test.rb +48 -0
  114. data/test/cases/arel/crud_test.rb +65 -0
  115. data/test/cases/arel/delete_manager_test.rb +53 -0
  116. data/test/cases/arel/factory_methods_test.rb +46 -0
  117. data/test/cases/arel/helper.rb +45 -0
  118. data/test/cases/arel/insert_manager_test.rb +241 -0
  119. data/test/cases/arel/nodes/and_test.rb +30 -0
  120. data/test/cases/arel/nodes/as_test.rb +36 -0
  121. data/test/cases/arel/nodes/ascending_test.rb +46 -0
  122. data/test/cases/arel/nodes/bin_test.rb +35 -0
  123. data/test/cases/arel/nodes/binary_test.rb +29 -0
  124. data/test/cases/arel/nodes/bind_param_test.rb +22 -0
  125. data/test/cases/arel/nodes/case_test.rb +96 -0
  126. data/test/cases/arel/nodes/casted_test.rb +18 -0
  127. data/test/cases/arel/nodes/comment_test.rb +22 -0
  128. data/test/cases/arel/nodes/count_test.rb +35 -0
  129. data/test/cases/arel/nodes/delete_statement_test.rb +36 -0
  130. data/test/cases/arel/nodes/descending_test.rb +46 -0
  131. data/test/cases/arel/nodes/distinct_test.rb +21 -0
  132. data/test/cases/arel/nodes/equality_test.rb +62 -0
  133. data/test/cases/arel/nodes/extract_test.rb +43 -0
  134. data/test/cases/arel/nodes/false_test.rb +21 -0
  135. data/test/cases/arel/nodes/grouping_test.rb +26 -0
  136. data/test/cases/arel/nodes/infix_operation_test.rb +42 -0
  137. data/test/cases/arel/nodes/insert_statement_test.rb +44 -0
  138. data/test/cases/arel/nodes/named_function_test.rb +48 -0
  139. data/test/cases/arel/nodes/node_test.rb +22 -0
  140. data/test/cases/arel/nodes/not_test.rb +31 -0
  141. data/test/cases/arel/nodes/or_test.rb +36 -0
  142. data/test/cases/arel/nodes/over_test.rb +69 -0
  143. data/test/cases/arel/nodes/select_core_test.rb +79 -0
  144. data/test/cases/arel/nodes/select_statement_test.rb +51 -0
  145. data/test/cases/arel/nodes/sql_literal_test.rb +75 -0
  146. data/test/cases/arel/nodes/sum_test.rb +35 -0
  147. data/test/cases/arel/nodes/table_alias_test.rb +29 -0
  148. data/test/cases/arel/nodes/true_test.rb +21 -0
  149. data/test/cases/arel/nodes/unary_operation_test.rb +41 -0
  150. data/test/cases/arel/nodes/update_statement_test.rb +60 -0
  151. data/test/cases/arel/nodes/window_test.rb +81 -0
  152. data/test/cases/arel/nodes_test.rb +34 -0
  153. data/test/cases/arel/select_manager_test.rb +1238 -0
  154. data/test/cases/arel/support/fake_record.rb +135 -0
  155. data/test/cases/arel/table_test.rb +216 -0
  156. data/test/cases/arel/update_manager_test.rb +126 -0
  157. data/test/cases/arel/visitors/dispatch_contamination_test.rb +78 -0
  158. data/test/cases/arel/visitors/dot_test.rb +90 -0
  159. data/test/cases/arel/visitors/mysql_test.rb +157 -0
  160. data/test/cases/arel/visitors/postgres_test.rb +366 -0
  161. data/test/cases/arel/visitors/sqlite_test.rb +75 -0
  162. data/test/cases/arel/visitors/to_sql_test.rb +750 -0
  163. data/test/cases/associations/belongs_to_associations_test.rb +510 -158
  164. data/test/cases/associations/bidirectional_destroy_dependencies_test.rb +4 -2
  165. data/test/cases/associations/callbacks_test.rb +56 -38
  166. data/test/cases/associations/cascaded_eager_loading_test.rb +118 -61
  167. data/test/cases/associations/eager_load_includes_full_sti_class_test.rb +138 -18
  168. data/test/cases/associations/eager_load_nested_include_test.rb +38 -37
  169. data/test/cases/associations/eager_singularization_test.rb +21 -21
  170. data/test/cases/associations/eager_test.rb +559 -415
  171. data/test/cases/associations/extension_test.rb +18 -12
  172. data/test/cases/associations/has_and_belongs_to_many_associations_test.rb +234 -213
  173. data/test/cases/associations/has_many_associations_test.rb +1038 -465
  174. data/test/cases/associations/has_many_through_associations_test.rb +558 -249
  175. data/test/cases/associations/has_one_associations_test.rb +294 -129
  176. data/test/cases/associations/has_one_through_associations_test.rb +121 -75
  177. data/test/cases/associations/inner_join_association_test.rb +114 -38
  178. data/test/cases/associations/inverse_associations_test.rb +606 -398
  179. data/test/cases/associations/join_model_test.rb +158 -148
  180. data/test/cases/associations/left_outer_join_association_test.rb +59 -24
  181. data/test/cases/associations/nested_through_associations_test.rb +166 -109
  182. data/test/cases/associations/required_test.rb +35 -10
  183. data/test/cases/associations_test.rb +241 -110
  184. data/test/cases/attribute_methods/read_test.rb +11 -11
  185. data/test/cases/attribute_methods_test.rb +413 -298
  186. data/test/cases/attributes_test.rb +145 -27
  187. data/test/cases/autosave_association_test.rb +681 -436
  188. data/test/cases/base_prevent_writes_test.rb +229 -0
  189. data/test/cases/base_test.rb +599 -542
  190. data/test/cases/batches_test.rb +288 -82
  191. data/test/cases/binary_test.rb +26 -31
  192. data/test/cases/bind_parameter_test.rb +194 -21
  193. data/test/cases/boolean_test.rb +52 -0
  194. data/test/cases/cache_key_test.rb +110 -5
  195. data/test/cases/calculations_test.rb +737 -174
  196. data/test/cases/callbacks_test.rb +74 -207
  197. data/test/cases/clone_test.rb +15 -10
  198. data/test/cases/coders/json_test.rb +2 -0
  199. data/test/cases/coders/yaml_column_test.rb +16 -13
  200. data/test/cases/collection_cache_key_test.rb +177 -20
  201. data/test/cases/column_alias_test.rb +9 -7
  202. data/test/cases/column_definition_test.rb +10 -68
  203. data/test/cases/comment_test.rb +166 -107
  204. data/test/cases/connection_adapters/adapter_leasing_test.rb +14 -10
  205. data/test/cases/connection_adapters/connection_handler_test.rb +358 -51
  206. data/test/cases/connection_adapters/connection_handlers_multi_db_test.rb +400 -0
  207. data/test/cases/connection_adapters/connection_handlers_multi_pool_config_test.rb +103 -0
  208. data/test/cases/connection_adapters/connection_handlers_sharding_db_test.rb +499 -0
  209. data/test/cases/connection_adapters/connection_swapping_nested_test.rb +457 -0
  210. data/test/cases/connection_adapters/legacy_connection_handlers_multi_db_test.rb +486 -0
  211. data/test/cases/connection_adapters/legacy_connection_handlers_sharding_db_test.rb +586 -0
  212. data/test/cases/connection_adapters/merge_and_resolve_default_url_config_test.rb +319 -138
  213. data/test/cases/connection_adapters/mysql_type_lookup_test.rb +62 -50
  214. data/test/cases/connection_adapters/schema_cache_test.rb +259 -26
  215. data/test/cases/connection_adapters/type_lookup_test.rb +96 -95
  216. data/test/cases/connection_management_test.rb +13 -11
  217. data/test/cases/connection_pool_test.rb +316 -83
  218. data/test/cases/core_test.rb +82 -58
  219. data/test/cases/counter_cache_test.rb +204 -50
  220. data/test/cases/custom_locking_test.rb +5 -3
  221. data/test/cases/database_configurations/hash_config_test.rb +74 -0
  222. data/test/cases/database_configurations/resolver_test.rb +150 -0
  223. data/test/cases/database_configurations_test.rb +145 -0
  224. data/test/cases/database_selector_test.rb +296 -0
  225. data/test/cases/database_statements_test.rb +18 -16
  226. data/test/cases/date_test.rb +8 -16
  227. data/test/cases/date_time_precision_test.rb +100 -78
  228. data/test/cases/date_time_test.rb +23 -8
  229. data/test/cases/defaults_test.rb +106 -71
  230. data/test/cases/delegated_type_test.rb +57 -0
  231. data/test/cases/dirty_test.rb +419 -223
  232. data/test/cases/disconnected_test.rb +6 -6
  233. data/test/cases/dup_test.rb +54 -27
  234. data/test/cases/enum_test.rb +461 -82
  235. data/test/cases/errors_test.rb +7 -7
  236. data/test/cases/explain_subscriber_test.rb +17 -15
  237. data/test/cases/explain_test.rb +11 -19
  238. data/test/cases/filter_attributes_test.rb +153 -0
  239. data/test/cases/finder_respond_to_test.rb +14 -14
  240. data/test/cases/finder_test.rb +669 -287
  241. data/test/cases/fixture_set/file_test.rb +34 -38
  242. data/test/cases/fixtures_test.rb +833 -176
  243. data/test/cases/forbidden_attributes_protection_test.rb +32 -67
  244. data/test/cases/habtm_destroy_order_test.rb +25 -25
  245. data/test/cases/helper.rb +78 -49
  246. data/test/cases/hot_compatibility_test.rb +33 -32
  247. data/test/cases/i18n_test.rb +18 -17
  248. data/test/cases/inheritance_test.rb +180 -115
  249. data/test/cases/insert_all_test.rb +489 -0
  250. data/test/cases/instrumentation_test.rb +101 -0
  251. data/test/cases/integration_test.rb +119 -31
  252. data/test/cases/invalid_connection_test.rb +18 -16
  253. data/test/cases/invertible_migration_test.rb +183 -43
  254. data/test/cases/json_attribute_test.rb +35 -0
  255. data/test/cases/json_serialization_test.rb +57 -58
  256. data/test/cases/json_shared_test_cases.rb +290 -0
  257. data/test/cases/locking_test.rb +413 -119
  258. data/test/cases/log_subscriber_test.rb +68 -26
  259. data/test/cases/marshal_serialization_test.rb +39 -0
  260. data/test/cases/migration/change_schema_test.rb +118 -72
  261. data/test/cases/migration/change_table_test.rb +138 -30
  262. data/test/cases/migration/check_constraint_test.rb +162 -0
  263. data/test/cases/migration/column_attributes_test.rb +45 -35
  264. data/test/cases/migration/column_positioning_test.rb +18 -6
  265. data/test/cases/migration/columns_test.rb +93 -77
  266. data/test/cases/migration/command_recorder_test.rb +121 -34
  267. data/test/cases/migration/compatibility_test.rb +578 -23
  268. data/test/cases/migration/create_join_table_test.rb +35 -25
  269. data/test/cases/migration/foreign_key_test.rb +503 -284
  270. data/test/cases/migration/helper.rb +4 -3
  271. data/test/cases/migration/index_test.rb +119 -70
  272. data/test/cases/migration/logger_test.rb +9 -6
  273. data/test/cases/migration/pending_migrations_test.rb +88 -34
  274. data/test/cases/migration/references_foreign_key_test.rb +164 -150
  275. data/test/cases/migration/references_index_test.rb +38 -19
  276. data/test/cases/migration/references_statements_test.rb +15 -14
  277. data/test/cases/migration/rename_table_test.rb +53 -30
  278. data/test/cases/migration_test.rb +637 -269
  279. data/test/cases/migrator_test.rb +191 -135
  280. data/test/cases/mixin_test.rb +7 -11
  281. data/test/cases/modules_test.rb +36 -34
  282. data/test/cases/multi_db_migrator_test.rb +223 -0
  283. data/test/cases/multiparameter_attributes_test.rb +60 -33
  284. data/test/cases/multiple_db_test.rb +16 -22
  285. data/test/cases/nested_attributes_test.rb +341 -320
  286. data/test/cases/nested_attributes_with_callbacks_test.rb +26 -24
  287. data/test/cases/null_relation_test.rb +84 -0
  288. data/test/cases/numeric_data_test.rb +93 -0
  289. data/test/cases/persistence_test.rb +361 -269
  290. data/test/cases/pooled_connections_test.rb +18 -26
  291. data/test/cases/prepared_statement_status_test.rb +48 -0
  292. data/test/cases/primary_keys_test.rb +210 -104
  293. data/test/cases/query_cache_test.rb +610 -141
  294. data/test/cases/quoting_test.rb +132 -31
  295. data/test/cases/readonly_test.rb +49 -48
  296. data/test/cases/reaper_test.rb +146 -32
  297. data/test/cases/reflection_test.rb +167 -156
  298. data/test/cases/relation/delegation_test.rb +49 -36
  299. data/test/cases/relation/delete_all_test.rb +117 -0
  300. data/test/cases/relation/merging_test.rb +319 -42
  301. data/test/cases/relation/mutation_test.rb +55 -93
  302. data/test/cases/relation/or_test.rb +129 -29
  303. data/test/cases/relation/predicate_builder_test.rb +21 -6
  304. data/test/cases/relation/record_fetch_warning_test.rb +5 -3
  305. data/test/cases/relation/select_test.rb +67 -0
  306. data/test/cases/relation/update_all_test.rb +317 -0
  307. data/test/cases/relation/where_chain_test.rb +68 -32
  308. data/test/cases/relation/where_clause_test.rb +136 -61
  309. data/test/cases/relation/where_test.rb +155 -48
  310. data/test/cases/relation_test.rb +266 -112
  311. data/test/cases/relations_test.rb +969 -744
  312. data/test/cases/reload_models_test.rb +13 -9
  313. data/test/cases/reserved_word_test.rb +141 -0
  314. data/test/cases/result_test.rb +68 -17
  315. data/test/cases/sanitize_test.rb +87 -71
  316. data/test/cases/schema_dumper_test.rb +221 -128
  317. data/test/cases/schema_loading_test.rb +3 -2
  318. data/test/cases/scoping/default_scoping_test.rb +185 -144
  319. data/test/cases/scoping/named_scoping_test.rb +177 -89
  320. data/test/cases/scoping/relation_scoping_test.rb +197 -75
  321. data/test/cases/secure_token_test.rb +18 -3
  322. data/test/cases/serialization_test.rb +30 -28
  323. data/test/cases/serialized_attribute_test.rb +133 -42
  324. data/test/cases/signed_id_test.rb +168 -0
  325. data/test/cases/statement_cache_test.rb +41 -24
  326. data/test/cases/statement_invalid_test.rb +42 -0
  327. data/test/cases/store_test.rb +180 -55
  328. data/test/cases/strict_loading_test.rb +473 -0
  329. data/test/cases/suppressor_test.rb +26 -12
  330. data/test/cases/tasks/database_tasks_test.rb +1258 -194
  331. data/test/cases/tasks/mysql_rake_test.rb +370 -298
  332. data/test/cases/tasks/postgresql_rake_test.rb +481 -251
  333. data/test/cases/tasks/sqlite_rake_test.rb +225 -178
  334. data/test/cases/test_case.rb +51 -40
  335. data/test/cases/test_databases_test.rb +79 -0
  336. data/test/cases/test_fixtures_test.rb +79 -19
  337. data/test/cases/time_precision_test.rb +98 -76
  338. data/test/cases/timestamp_test.rb +102 -99
  339. data/test/cases/touch_later_test.rb +12 -10
  340. data/test/cases/transaction_callbacks_test.rb +344 -90
  341. data/test/cases/transaction_isolation_test.rb +12 -12
  342. data/test/cases/transactions_test.rb +612 -162
  343. data/test/cases/type/adapter_specific_registry_test.rb +14 -2
  344. data/test/cases/type/date_time_test.rb +4 -2
  345. data/test/cases/type/integer_test.rb +4 -2
  346. data/test/cases/type/string_test.rb +10 -8
  347. data/test/cases/type/time_test.rb +28 -0
  348. data/test/cases/type/type_map_test.rb +29 -28
  349. data/test/cases/type/unsigned_integer_test.rb +19 -0
  350. data/test/cases/type_test.rb +2 -0
  351. data/test/cases/types_test.rb +3 -1
  352. data/test/cases/unconnected_test.rb +14 -1
  353. data/test/cases/unsafe_raw_sql_test.rb +274 -0
  354. data/test/cases/validations/absence_validation_test.rb +19 -17
  355. data/test/cases/validations/association_validation_test.rb +30 -28
  356. data/test/cases/validations/i18n_generate_message_validation_test.rb +34 -16
  357. data/test/cases/validations/i18n_validation_test.rb +22 -21
  358. data/test/cases/validations/length_validation_test.rb +34 -33
  359. data/test/cases/validations/numericality_validation_test.rb +181 -0
  360. data/test/cases/validations/presence_validation_test.rb +21 -19
  361. data/test/cases/validations/uniqueness_validation_test.rb +156 -86
  362. data/test/cases/validations_repair_helper.rb +2 -0
  363. data/test/cases/validations_test.rb +61 -26
  364. data/test/cases/view_test.rb +122 -116
  365. data/test/cases/yaml_serialization_test.rb +79 -34
  366. data/test/config.example.yml +19 -19
  367. data/test/config.rb +3 -1
  368. data/test/config.yml +16 -6
  369. data/test/fixtures/admin/randomly_named_a9.yml +7 -7
  370. data/test/fixtures/admin/randomly_named_b0.yml +7 -7
  371. data/test/fixtures/all/namespaced/accounts.yml +2 -0
  372. data/test/fixtures/author_addresses.yml +1 -8
  373. data/test/fixtures/authors.yml +1 -7
  374. data/test/fixtures/binaries.yml +4 -0
  375. data/test/fixtures/books.yml +9 -2
  376. data/test/fixtures/categories_posts.yml +3 -0
  377. data/test/fixtures/citations.yml +5 -0
  378. data/test/fixtures/comments.yml +7 -0
  379. data/test/fixtures/companies.yml +5 -0
  380. data/test/fixtures/computers.yml +2 -0
  381. data/test/fixtures/customers.yml +10 -1
  382. data/test/fixtures/developers.yml +1 -1
  383. data/test/fixtures/essays.yml +10 -0
  384. data/test/fixtures/faces.yml +3 -3
  385. data/test/fixtures/humans.yml +5 -0
  386. data/test/fixtures/interests.yml +7 -7
  387. data/test/fixtures/memberships.yml +7 -0
  388. data/test/fixtures/minimalistics.yml +3 -0
  389. data/test/fixtures/mixed_case_monkeys.yml +2 -2
  390. data/test/fixtures/naked/yml/courses_with_invalid_key.yml +3 -0
  391. data/test/fixtures/naked/yml/parrots.yml +1 -0
  392. data/test/fixtures/other_books.yml +26 -0
  393. data/test/fixtures/other_posts.yml +1 -0
  394. data/test/fixtures/parrots.yml +7 -1
  395. data/test/fixtures/pirates.yml +3 -0
  396. data/test/fixtures/posts.yml +11 -3
  397. data/test/fixtures/randomly_named_a9.yml +7 -7
  398. data/test/fixtures/readers.yml +6 -0
  399. data/test/fixtures/reserved_words/values.yml +2 -2
  400. data/test/fixtures/sponsors.yml +3 -0
  401. data/test/fixtures/strict_zines.yml +2 -0
  402. data/test/fixtures/subscribers.yml +1 -1
  403. data/test/fixtures/tasks.yml +1 -1
  404. data/test/fixtures/warehouse-things.yml +3 -0
  405. data/test/migrations/10_urban/9_add_expressions.rb +2 -0
  406. data/test/migrations/decimal/1_give_me_big_numbers.rb +6 -4
  407. data/test/migrations/magic/1_currencies_have_symbols.rb +3 -2
  408. data/test/migrations/missing/1000_people_have_middle_names.rb +2 -0
  409. data/test/migrations/missing/1_people_have_last_names.rb +2 -0
  410. data/test/migrations/missing/3_we_need_reminders.rb +2 -0
  411. data/test/migrations/missing/4_innocent_jointable.rb +3 -1
  412. data/test/migrations/rename/1_we_need_things.rb +2 -0
  413. data/test/migrations/rename/2_rename_things.rb +2 -0
  414. data/test/migrations/to_copy/1_people_have_hobbies.rb +3 -1
  415. data/test/migrations/to_copy/2_people_have_descriptions.rb +3 -1
  416. data/test/migrations/to_copy2/1_create_articles.rb +2 -0
  417. data/test/migrations/to_copy2/2_create_comments.rb +3 -1
  418. data/test/migrations/to_copy_with_name_collision/1_people_have_hobbies.rb +3 -1
  419. data/test/migrations/to_copy_with_timestamps/20090101010101_people_have_hobbies.rb +3 -1
  420. data/test/migrations/to_copy_with_timestamps/20090101010202_people_have_descriptions.rb +3 -1
  421. data/test/migrations/to_copy_with_timestamps2/20090101010101_create_articles.rb +2 -0
  422. data/test/migrations/to_copy_with_timestamps2/20090101010202_create_comments.rb +2 -0
  423. data/test/migrations/valid/1_valid_people_have_last_names.rb +2 -0
  424. data/test/migrations/valid/2_we_need_reminders.rb +2 -0
  425. data/test/migrations/valid/3_innocent_jointable.rb +3 -1
  426. data/test/migrations/valid_with_subdirectories/1_valid_people_have_last_names.rb +2 -0
  427. data/test/migrations/valid_with_subdirectories/sub/2_we_need_reminders.rb +2 -0
  428. data/test/migrations/valid_with_subdirectories/sub1/3_innocent_jointable.rb +3 -1
  429. data/test/migrations/valid_with_timestamps/20100101010101_valid_with_timestamps_people_have_last_names.rb +2 -0
  430. data/test/migrations/valid_with_timestamps/20100201010101_valid_with_timestamps_we_need_reminders.rb +2 -0
  431. data/test/migrations/valid_with_timestamps/20100301010101_valid_with_timestamps_innocent_jointable.rb +3 -1
  432. data/test/migrations/version_check/20131219224947_migration_version_check.rb +2 -0
  433. data/test/models/account.rb +46 -0
  434. data/test/models/admin/account.rb +3 -1
  435. data/test/models/admin/randomly_named_c1.rb +2 -0
  436. data/test/models/admin/user.rb +16 -8
  437. data/test/models/admin.rb +4 -2
  438. data/test/models/aircraft.rb +3 -1
  439. data/test/models/arunit2_model.rb +2 -0
  440. data/test/models/author.rb +153 -102
  441. data/test/models/auto_id.rb +2 -0
  442. data/test/models/autoloadable/extra_firm.rb +2 -0
  443. data/test/models/binary.rb +3 -1
  444. data/test/models/binary_field.rb +6 -0
  445. data/test/models/bird.rb +13 -1
  446. data/test/models/book.rb +14 -4
  447. data/test/models/book_destroy_async.rb +24 -0
  448. data/test/models/boolean.rb +5 -0
  449. data/test/models/bulb.rb +13 -4
  450. data/test/models/cake_designer.rb +2 -0
  451. data/test/models/car.rb +17 -10
  452. data/test/models/carrier.rb +2 -0
  453. data/test/models/cart.rb +5 -0
  454. data/test/models/cat.rb +2 -0
  455. data/test/models/categorization.rb +8 -6
  456. data/test/models/category.rb +28 -16
  457. data/test/models/chef.rb +2 -0
  458. data/test/models/citation.rb +5 -1
  459. data/test/models/club.rb +13 -10
  460. data/test/models/college.rb +4 -2
  461. data/test/models/column.rb +2 -0
  462. data/test/models/column_name.rb +2 -0
  463. data/test/models/comment.rb +32 -10
  464. data/test/models/company.rb +102 -106
  465. data/test/models/company_in_module.rb +27 -26
  466. data/test/models/computer.rb +3 -1
  467. data/test/models/contact.rb +15 -13
  468. data/test/models/content.rb +5 -3
  469. data/test/models/contract.rb +21 -3
  470. data/test/models/country.rb +2 -4
  471. data/test/models/course.rb +3 -1
  472. data/test/models/customer.rb +10 -8
  473. data/test/models/customer_carrier.rb +2 -0
  474. data/test/models/dashboard.rb +2 -0
  475. data/test/models/default.rb +2 -0
  476. data/test/models/department.rb +2 -0
  477. data/test/models/destroy_async_parent.rb +15 -0
  478. data/test/models/destroy_async_parent_soft_delete.rb +20 -0
  479. data/test/models/developer.rb +152 -85
  480. data/test/models/dl_keyed_belongs_to.rb +13 -0
  481. data/test/models/dl_keyed_belongs_to_soft_delete.rb +19 -0
  482. data/test/models/dl_keyed_has_many.rb +5 -0
  483. data/test/models/dl_keyed_has_many_through.rb +5 -0
  484. data/test/models/dl_keyed_has_one.rb +5 -0
  485. data/test/models/dl_keyed_join.rb +10 -0
  486. data/test/models/dog.rb +2 -0
  487. data/test/models/dog_lover.rb +2 -0
  488. data/test/models/doubloon.rb +3 -1
  489. data/test/models/drink_designer.rb +17 -0
  490. data/test/models/edge.rb +4 -2
  491. data/test/models/electron.rb +2 -0
  492. data/test/models/engine.rb +3 -2
  493. data/test/models/entrant.rb +2 -0
  494. data/test/models/entry.rb +5 -0
  495. data/test/models/essay.rb +6 -3
  496. data/test/models/essay_destroy_async.rb +12 -0
  497. data/test/models/event.rb +3 -1
  498. data/test/models/eye.rb +5 -3
  499. data/test/models/face.rb +14 -6
  500. data/test/models/family.rb +6 -0
  501. data/test/models/family_tree.rb +6 -0
  502. data/test/models/friendship.rb +5 -3
  503. data/test/models/frog.rb +8 -0
  504. data/test/models/guid.rb +3 -1
  505. data/test/models/guitar.rb +2 -0
  506. data/test/models/hotel.rb +5 -3
  507. data/test/models/human.rb +39 -0
  508. data/test/models/image.rb +3 -1
  509. data/test/models/interest.rb +14 -3
  510. data/test/models/invoice.rb +4 -2
  511. data/test/models/item.rb +3 -1
  512. data/test/models/job.rb +5 -3
  513. data/test/models/joke.rb +4 -2
  514. data/test/models/keyboard.rb +3 -1
  515. data/test/models/legacy_thing.rb +2 -0
  516. data/test/models/lesson.rb +2 -0
  517. data/test/models/line_item.rb +3 -1
  518. data/test/models/liquid.rb +2 -0
  519. data/test/models/matey.rb +3 -1
  520. data/test/models/measurement.rb +4 -0
  521. data/test/models/member.rb +23 -20
  522. data/test/models/member_detail.rb +3 -0
  523. data/test/models/member_type.rb +2 -0
  524. data/test/models/membership.rb +4 -1
  525. data/test/models/mentor.rb +3 -1
  526. data/test/models/message.rb +5 -0
  527. data/test/models/minimalistic.rb +2 -0
  528. data/test/models/minivan.rb +3 -2
  529. data/test/models/mixed_case_monkey.rb +3 -1
  530. data/test/models/molecule.rb +2 -0
  531. data/test/models/mouse.rb +6 -0
  532. data/test/models/movie.rb +2 -0
  533. data/test/models/node.rb +4 -2
  534. data/test/models/non_primary_key.rb +2 -0
  535. data/test/models/notification.rb +2 -0
  536. data/test/models/numeric_data.rb +12 -0
  537. data/test/models/order.rb +4 -2
  538. data/test/models/organization.rb +9 -7
  539. data/test/models/other_dog.rb +3 -1
  540. data/test/models/owner.rb +6 -4
  541. data/test/models/parrot.rb +12 -4
  542. data/test/models/person.rb +59 -54
  543. data/test/models/personal_legacy_thing.rb +3 -1
  544. data/test/models/pet.rb +4 -2
  545. data/test/models/pet_treasure.rb +2 -0
  546. data/test/models/pirate.rb +67 -43
  547. data/test/models/possession.rb +3 -1
  548. data/test/models/post.rb +184 -86
  549. data/test/models/price_estimate.rb +11 -1
  550. data/test/models/professor.rb +3 -1
  551. data/test/models/project.rb +14 -12
  552. data/test/models/publisher/article.rb +2 -0
  553. data/test/models/publisher/magazine.rb +2 -0
  554. data/test/models/publisher.rb +2 -0
  555. data/test/models/randomly_named_c1.rb +2 -0
  556. data/test/models/rating.rb +5 -1
  557. data/test/models/reader.rb +7 -5
  558. data/test/models/recipe.rb +2 -0
  559. data/test/models/record.rb +2 -0
  560. data/test/models/reference.rb +6 -3
  561. data/test/models/reply.rb +39 -21
  562. data/test/models/room.rb +6 -0
  563. data/test/models/section.rb +6 -0
  564. data/test/models/seminar.rb +6 -0
  565. data/test/models/session.rb +6 -0
  566. data/test/models/ship.rb +12 -9
  567. data/test/models/ship_part.rb +5 -3
  568. data/test/models/shop.rb +4 -2
  569. data/test/models/shop_account.rb +2 -0
  570. data/test/models/speedometer.rb +2 -0
  571. data/test/models/sponsor.rb +8 -5
  572. data/test/models/squeak.rb +6 -0
  573. data/test/models/strict_zine.rb +7 -0
  574. data/test/models/string_key_object.rb +2 -0
  575. data/test/models/student.rb +2 -0
  576. data/test/models/subscriber.rb +4 -2
  577. data/test/models/subscription.rb +5 -1
  578. data/test/models/tag.rb +6 -3
  579. data/test/models/tagging.rb +13 -6
  580. data/test/models/task.rb +2 -0
  581. data/test/models/topic.rb +54 -19
  582. data/test/models/toy.rb +4 -0
  583. data/test/models/traffic_light.rb +2 -0
  584. data/test/models/treasure.rb +5 -3
  585. data/test/models/treaty.rb +2 -4
  586. data/test/models/tree.rb +2 -0
  587. data/test/models/tuning_peg.rb +2 -0
  588. data/test/models/tyre.rb +2 -0
  589. data/test/models/user.rb +12 -4
  590. data/test/models/uuid_child.rb +2 -0
  591. data/test/models/uuid_item.rb +2 -0
  592. data/test/models/uuid_parent.rb +2 -0
  593. data/test/models/vegetables.rb +12 -3
  594. data/test/models/vertex.rb +6 -4
  595. data/test/models/warehouse_thing.rb +2 -0
  596. data/test/models/wheel.rb +3 -1
  597. data/test/models/without_table.rb +3 -1
  598. data/test/models/zine.rb +3 -1
  599. data/test/schema/mysql2_specific_schema.rb +49 -35
  600. data/test/schema/oracle_specific_schema.rb +13 -15
  601. data/test/schema/postgresql_specific_schema.rb +51 -40
  602. data/test/schema/schema.rb +334 -154
  603. data/test/schema/sqlite_specific_schema.rb +9 -16
  604. data/test/support/config.rb +26 -26
  605. data/test/support/connection.rb +14 -8
  606. data/test/support/connection_helper.rb +3 -1
  607. data/test/support/ddl_helper.rb +2 -0
  608. data/test/support/marshal_compatibility_fixtures/IBM_DB/rails_6_0_topic.dump +0 -0
  609. data/test/support/marshal_compatibility_fixtures/IBM_DB/rails_6_0_topic_associations.dump +0 -0
  610. data/test/support/marshal_compatibility_fixtures/Mysql2/rails_6_0_topic.dump +0 -0
  611. data/test/support/marshal_compatibility_fixtures/Mysql2/rails_6_0_topic_associations.dump +0 -0
  612. data/test/support/marshal_compatibility_fixtures/PostgreSQL/rails_6_0_topic.dump +0 -0
  613. data/test/support/marshal_compatibility_fixtures/PostgreSQL/rails_6_0_topic_associations.dump +0 -0
  614. data/test/support/marshal_compatibility_fixtures/SQLite/rails_6_0_topic.dump +0 -0
  615. data/test/support/marshal_compatibility_fixtures/SQLite/rails_6_0_topic_associations.dump +0 -0
  616. data/test/support/marshal_compatibility_fixtures/legacy_6_0_record_mysql.dump +0 -0
  617. data/test/support/marshal_compatibility_fixtures/legacy_relation.dump +0 -0
  618. data/test/support/schema_dumping_helper.rb +2 -0
  619. data/test/support/stubs/strong_parameters.rb +40 -0
  620. data/test/support/yaml_compatibility_fixtures/rails_v1_mysql.yml +206 -0
  621. data/test/support/yaml_compatibility_fixtures/rails_v2.yml +55 -0
  622. metadata +185 -4
@@ -0,0 +1,241 @@
1
+ # frozen_string_literal: true
2
+
3
+ require_relative "helper"
4
+
5
+ module Arel
6
+ class InsertManagerTest < Arel::Spec
7
+ describe "new" do
8
+ it "takes an engine" do
9
+ Arel::InsertManager.new
10
+ end
11
+ end
12
+
13
+ describe "insert" do
14
+ it "can create a ValuesList node" do
15
+ manager = Arel::InsertManager.new
16
+ values = manager.create_values_list([%w{ a b }, %w{ c d }])
17
+
18
+ assert_kind_of Arel::Nodes::ValuesList, values
19
+ assert_equal [%w{ a b }, %w{ c d }], values.rows
20
+ end
21
+
22
+ it "allows sql literals" do
23
+ manager = Arel::InsertManager.new
24
+ manager.into Table.new(:users)
25
+ manager.values = manager.create_values([Arel.sql("*")])
26
+ _(manager.to_sql).must_be_like %{
27
+ INSERT INTO \"users\" VALUES (*)
28
+ }
29
+ end
30
+
31
+ it "works with multiple values" do
32
+ table = Table.new(:users)
33
+ manager = Arel::InsertManager.new
34
+ manager.into table
35
+
36
+ manager.columns << table[:id]
37
+ manager.columns << table[:name]
38
+
39
+ manager.values = manager.create_values_list([
40
+ %w{1 david},
41
+ %w{2 kir},
42
+ ["3", Arel.sql("DEFAULT")],
43
+ ])
44
+
45
+ _(manager.to_sql).must_be_like %{
46
+ INSERT INTO \"users\" (\"id\", \"name\") VALUES ('1', 'david'), ('2', 'kir'), ('3', DEFAULT)
47
+ }
48
+ end
49
+
50
+ it "literals in multiple values are not escaped" do
51
+ table = Table.new(:users)
52
+ manager = Arel::InsertManager.new
53
+ manager.into table
54
+
55
+ manager.columns << table[:name]
56
+
57
+ manager.values = manager.create_values_list([
58
+ [Arel.sql("*")],
59
+ [Arel.sql("DEFAULT")],
60
+ ])
61
+
62
+ _(manager.to_sql).must_be_like %{
63
+ INSERT INTO \"users\" (\"name\") VALUES (*), (DEFAULT)
64
+ }
65
+ end
66
+
67
+ it "works with multiple single values" do
68
+ table = Table.new(:users)
69
+ manager = Arel::InsertManager.new
70
+ manager.into table
71
+
72
+ manager.columns << table[:name]
73
+
74
+ manager.values = manager.create_values_list([
75
+ %w{david},
76
+ %w{kir},
77
+ [Arel.sql("DEFAULT")],
78
+ ])
79
+
80
+ _(manager.to_sql).must_be_like %{
81
+ INSERT INTO \"users\" (\"name\") VALUES ('david'), ('kir'), (DEFAULT)
82
+ }
83
+ end
84
+
85
+ it "inserts false" do
86
+ table = Table.new(:users)
87
+ manager = Arel::InsertManager.new
88
+
89
+ manager.insert [[table[:bool], false]]
90
+ _(manager.to_sql).must_be_like %{
91
+ INSERT INTO "users" ("bool") VALUES ('f')
92
+ }
93
+ end
94
+
95
+ it "inserts null" do
96
+ table = Table.new(:users)
97
+ manager = Arel::InsertManager.new
98
+ manager.insert [[table[:id], nil]]
99
+ _(manager.to_sql).must_be_like %{
100
+ INSERT INTO "users" ("id") VALUES (NULL)
101
+ }
102
+ end
103
+
104
+ it "inserts time" do
105
+ table = Table.new(:users)
106
+ manager = Arel::InsertManager.new
107
+
108
+ time = Time.now
109
+ attribute = table[:created_at]
110
+
111
+ manager.insert [[attribute, time]]
112
+ _(manager.to_sql).must_be_like %{
113
+ INSERT INTO "users" ("created_at") VALUES (#{Table.engine.connection.quote time})
114
+ }
115
+ end
116
+
117
+ it "takes a list of lists" do
118
+ table = Table.new(:users)
119
+ manager = Arel::InsertManager.new
120
+ manager.into table
121
+ manager.insert [[table[:id], 1], [table[:name], "aaron"]]
122
+ _(manager.to_sql).must_be_like %{
123
+ INSERT INTO "users" ("id", "name") VALUES (1, 'aaron')
124
+ }
125
+ end
126
+
127
+ it "defaults the table" do
128
+ table = Table.new(:users)
129
+ manager = Arel::InsertManager.new
130
+ manager.insert [[table[:id], 1], [table[:name], "aaron"]]
131
+ _(manager.to_sql).must_be_like %{
132
+ INSERT INTO "users" ("id", "name") VALUES (1, 'aaron')
133
+ }
134
+ end
135
+
136
+ it "noop for empty list" do
137
+ table = Table.new(:users)
138
+ manager = Arel::InsertManager.new
139
+ manager.insert [[table[:id], 1]]
140
+ manager.insert []
141
+ _(manager.to_sql).must_be_like %{
142
+ INSERT INTO "users" ("id") VALUES (1)
143
+ }
144
+ end
145
+
146
+ it "is chainable" do
147
+ table = Table.new(:users)
148
+ manager = Arel::InsertManager.new
149
+ insert_result = manager.insert [[table[:id], 1]]
150
+ assert_equal manager, insert_result
151
+ end
152
+ end
153
+
154
+ describe "into" do
155
+ it "takes a Table and chains" do
156
+ manager = Arel::InsertManager.new
157
+ _(manager.into(Table.new(:users))).must_equal manager
158
+ end
159
+
160
+ it "converts to sql" do
161
+ table = Table.new :users
162
+ manager = Arel::InsertManager.new
163
+ manager.into table
164
+ _(manager.to_sql).must_be_like %{
165
+ INSERT INTO "users"
166
+ }
167
+ end
168
+ end
169
+
170
+ describe "columns" do
171
+ it "converts to sql" do
172
+ table = Table.new :users
173
+ manager = Arel::InsertManager.new
174
+ manager.into table
175
+ manager.columns << table[:id]
176
+ _(manager.to_sql).must_be_like %{
177
+ INSERT INTO "users" ("id")
178
+ }
179
+ end
180
+ end
181
+
182
+ describe "values" do
183
+ it "converts to sql" do
184
+ table = Table.new :users
185
+ manager = Arel::InsertManager.new
186
+ manager.into table
187
+
188
+ manager.values = Nodes::ValuesList.new([[1], [2]])
189
+ _(manager.to_sql).must_be_like %{
190
+ INSERT INTO "users" VALUES (1), (2)
191
+ }
192
+ end
193
+
194
+ it "accepts sql literals" do
195
+ table = Table.new :users
196
+ manager = Arel::InsertManager.new
197
+ manager.into table
198
+
199
+ manager.values = Arel.sql("DEFAULT VALUES")
200
+ _(manager.to_sql).must_be_like %{
201
+ INSERT INTO "users" DEFAULT VALUES
202
+ }
203
+ end
204
+ end
205
+
206
+ describe "combo" do
207
+ it "combines columns and values list in order" do
208
+ table = Table.new :users
209
+ manager = Arel::InsertManager.new
210
+ manager.into table
211
+
212
+ manager.values = Nodes::ValuesList.new([[1, "aaron"], [2, "david"]])
213
+ manager.columns << table[:id]
214
+ manager.columns << table[:name]
215
+ _(manager.to_sql).must_be_like %{
216
+ INSERT INTO "users" ("id", "name") VALUES (1, 'aaron'), (2, 'david')
217
+ }
218
+ end
219
+ end
220
+
221
+ describe "select" do
222
+ it "accepts a select query in place of a VALUES clause" do
223
+ table = Table.new :users
224
+
225
+ manager = Arel::InsertManager.new
226
+ manager.into table
227
+
228
+ select = Arel::SelectManager.new
229
+ select.project Arel.sql("1")
230
+ select.project Arel.sql('"aaron"')
231
+
232
+ manager.select select
233
+ manager.columns << table[:id]
234
+ manager.columns << table[:name]
235
+ _(manager.to_sql).must_be_like %{
236
+ INSERT INTO "users" ("id", "name") (SELECT 1, "aaron")
237
+ }
238
+ end
239
+ end
240
+ end
241
+ end
@@ -0,0 +1,30 @@
1
+ # frozen_string_literal: true
2
+
3
+ require_relative "../helper"
4
+
5
+ module Arel
6
+ module Nodes
7
+ describe "And" do
8
+ describe "equality" do
9
+ it "is equal with equal ivars" do
10
+ array = [And.new(["foo", "bar"]), And.new(["foo", "bar"])]
11
+ assert_equal 1, array.uniq.size
12
+ end
13
+
14
+ it "is not equal with different ivars" do
15
+ array = [And.new(["foo", "bar"]), And.new(["foo", "baz"])]
16
+ assert_equal 2, array.uniq.size
17
+ end
18
+ end
19
+
20
+ describe "functions as node expression" do
21
+ it "allows aliasing" do
22
+ aliased = And.new(["foo", "bar"]).as("baz")
23
+
24
+ assert_kind_of As, aliased
25
+ assert_kind_of SqlLiteral, aliased.right
26
+ end
27
+ end
28
+ end
29
+ end
30
+ end
@@ -0,0 +1,36 @@
1
+ # frozen_string_literal: true
2
+
3
+ require_relative "../helper"
4
+
5
+ module Arel
6
+ module Nodes
7
+ describe "As" do
8
+ describe "#as" do
9
+ it "makes an AS node" do
10
+ attr = Table.new(:users)[:id]
11
+ as = attr.as(Arel.sql("foo"))
12
+ assert_equal attr, as.left
13
+ assert_equal "foo", as.right
14
+ end
15
+
16
+ it "converts right to SqlLiteral if a string" do
17
+ attr = Table.new(:users)[:id]
18
+ as = attr.as("foo")
19
+ assert_kind_of Arel::Nodes::SqlLiteral, as.right
20
+ end
21
+ end
22
+
23
+ describe "equality" do
24
+ it "is equal with equal ivars" do
25
+ array = [As.new("foo", "bar"), As.new("foo", "bar")]
26
+ assert_equal 1, array.uniq.size
27
+ end
28
+
29
+ it "is not equal with different ivars" do
30
+ array = [As.new("foo", "bar"), As.new("foo", "baz")]
31
+ assert_equal 2, array.uniq.size
32
+ end
33
+ end
34
+ end
35
+ end
36
+ end
@@ -0,0 +1,46 @@
1
+ # frozen_string_literal: true
2
+
3
+ require_relative "../helper"
4
+
5
+ module Arel
6
+ module Nodes
7
+ class TestAscending < Arel::Test
8
+ def test_construct
9
+ ascending = Ascending.new "zomg"
10
+ assert_equal "zomg", ascending.expr
11
+ end
12
+
13
+ def test_reverse
14
+ ascending = Ascending.new "zomg"
15
+ descending = ascending.reverse
16
+ assert_kind_of Descending, descending
17
+ assert_equal ascending.expr, descending.expr
18
+ end
19
+
20
+ def test_direction
21
+ ascending = Ascending.new "zomg"
22
+ assert_equal :asc, ascending.direction
23
+ end
24
+
25
+ def test_ascending?
26
+ ascending = Ascending.new "zomg"
27
+ assert ascending.ascending?
28
+ end
29
+
30
+ def test_descending?
31
+ ascending = Ascending.new "zomg"
32
+ assert_not ascending.descending?
33
+ end
34
+
35
+ def test_equality_with_same_ivars
36
+ array = [Ascending.new("zomg"), Ascending.new("zomg")]
37
+ assert_equal 1, array.uniq.size
38
+ end
39
+
40
+ def test_inequality_with_different_ivars
41
+ array = [Ascending.new("zomg"), Ascending.new("zomg!")]
42
+ assert_equal 2, array.uniq.size
43
+ end
44
+ end
45
+ end
46
+ end
@@ -0,0 +1,35 @@
1
+ # frozen_string_literal: true
2
+
3
+ require_relative "../helper"
4
+
5
+ module Arel
6
+ module Nodes
7
+ class TestBin < Arel::Test
8
+ def test_new
9
+ assert Arel::Nodes::Bin.new("zomg")
10
+ end
11
+
12
+ def test_default_to_sql
13
+ viz = Arel::Visitors::ToSql.new Table.engine.connection_pool
14
+ node = Arel::Nodes::Bin.new(Arel.sql("zomg"))
15
+ assert_equal "zomg", viz.accept(node, Collectors::SQLString.new).value
16
+ end
17
+
18
+ def test_mysql_to_sql
19
+ viz = Arel::Visitors::MySQL.new Table.engine.connection_pool
20
+ node = Arel::Nodes::Bin.new(Arel.sql("zomg"))
21
+ assert_equal "BINARY zomg", viz.accept(node, Collectors::SQLString.new).value
22
+ end
23
+
24
+ def test_equality_with_same_ivars
25
+ array = [Bin.new("zomg"), Bin.new("zomg")]
26
+ assert_equal 1, array.uniq.size
27
+ end
28
+
29
+ def test_inequality_with_different_ivars
30
+ array = [Bin.new("zomg"), Bin.new("zomg!")]
31
+ assert_equal 2, array.uniq.size
32
+ end
33
+ end
34
+ end
35
+ end
@@ -0,0 +1,29 @@
1
+ # frozen_string_literal: true
2
+
3
+ require_relative "../helper"
4
+
5
+ module Arel
6
+ module Nodes
7
+ class NodesTest < Arel::Spec
8
+ describe "Binary" do
9
+ describe "#hash" do
10
+ it "generates a hash based on its value" do
11
+ eq = Equality.new("foo", "bar")
12
+ eq2 = Equality.new("foo", "bar")
13
+ eq3 = Equality.new("bar", "baz")
14
+
15
+ assert_equal eq.hash, eq2.hash
16
+ assert_not_equal eq.hash, eq3.hash
17
+ end
18
+
19
+ it "generates a hash specific to its class" do
20
+ eq = Equality.new("foo", "bar")
21
+ neq = NotEqual.new("foo", "bar")
22
+
23
+ assert_not_equal eq.hash, neq.hash
24
+ end
25
+ end
26
+ end
27
+ end
28
+ end
29
+ end
@@ -0,0 +1,22 @@
1
+ # frozen_string_literal: true
2
+
3
+ require_relative "../helper"
4
+
5
+ module Arel
6
+ module Nodes
7
+ describe "BindParam" do
8
+ it "is equal to other bind params with the same value" do
9
+ _(BindParam.new(1)).must_equal(BindParam.new(1))
10
+ _(BindParam.new("foo")).must_equal(BindParam.new("foo"))
11
+ end
12
+
13
+ it "is not equal to other nodes" do
14
+ _(BindParam.new(nil)).wont_equal(Node.new)
15
+ end
16
+
17
+ it "is not equal to bind params with different values" do
18
+ _(BindParam.new(1)).wont_equal(BindParam.new(2))
19
+ end
20
+ end
21
+ end
22
+ end
@@ -0,0 +1,96 @@
1
+ # frozen_string_literal: true
2
+
3
+ require_relative "../helper"
4
+
5
+ module Arel
6
+ module Nodes
7
+ class NodesTest < Arel::Spec
8
+ describe "Case" do
9
+ describe "#initialize" do
10
+ it "sets case expression from first argument" do
11
+ node = Case.new "foo"
12
+
13
+ assert_equal "foo", node.case
14
+ end
15
+
16
+ it "sets default case from second argument" do
17
+ node = Case.new nil, "bar"
18
+
19
+ assert_equal "bar", node.default
20
+ end
21
+ end
22
+
23
+ describe "#clone" do
24
+ it "clones case, conditions and default" do
25
+ foo = Nodes.build_quoted "foo"
26
+
27
+ node = Case.new
28
+ node.case = foo
29
+ node.conditions = [When.new(foo, foo)]
30
+ node.default = foo
31
+
32
+ dolly = node.clone
33
+
34
+ assert_equal dolly.case, node.case
35
+ assert_not_same dolly.case, node.case
36
+
37
+ assert_equal dolly.conditions, node.conditions
38
+ assert_not_same dolly.conditions, node.conditions
39
+
40
+ assert_equal dolly.default, node.default
41
+ assert_not_same dolly.default, node.default
42
+ end
43
+ end
44
+
45
+ describe "equality" do
46
+ it "is equal with equal ivars" do
47
+ foo = Nodes.build_quoted "foo"
48
+ one = Nodes.build_quoted 1
49
+ zero = Nodes.build_quoted 0
50
+
51
+ case1 = Case.new foo
52
+ case1.conditions = [When.new(foo, one)]
53
+ case1.default = Else.new zero
54
+
55
+ case2 = Case.new foo
56
+ case2.conditions = [When.new(foo, one)]
57
+ case2.default = Else.new zero
58
+
59
+ array = [case1, case2]
60
+
61
+ assert_equal 1, array.uniq.size
62
+ end
63
+
64
+ it "is not equal with different ivars" do
65
+ foo = Nodes.build_quoted "foo"
66
+ bar = Nodes.build_quoted "bar"
67
+ one = Nodes.build_quoted 1
68
+ zero = Nodes.build_quoted 0
69
+
70
+ case1 = Case.new foo
71
+ case1.conditions = [When.new(foo, one)]
72
+ case1.default = Else.new zero
73
+
74
+ case2 = Case.new foo
75
+ case2.conditions = [When.new(bar, one)]
76
+ case2.default = Else.new zero
77
+
78
+ array = [case1, case2]
79
+
80
+ assert_equal 2, array.uniq.size
81
+ end
82
+ end
83
+
84
+ describe "#as" do
85
+ it "allows aliasing" do
86
+ node = Case.new "foo"
87
+ as = node.as("bar")
88
+
89
+ assert_equal node, as.left
90
+ assert_kind_of Arel::Nodes::SqlLiteral, as.right
91
+ end
92
+ end
93
+ end
94
+ end
95
+ end
96
+ end
@@ -0,0 +1,18 @@
1
+ # frozen_string_literal: true
2
+
3
+ require_relative "../helper"
4
+
5
+ module Arel
6
+ module Nodes
7
+ describe Casted do
8
+ describe "#hash" do
9
+ it "is equal when eql? returns true" do
10
+ one = Casted.new 1, 2
11
+ also_one = Casted.new 1, 2
12
+
13
+ assert_equal one.hash, also_one.hash
14
+ end
15
+ end
16
+ end
17
+ end
18
+ end
@@ -0,0 +1,22 @@
1
+ # frozen_string_literal: true
2
+
3
+ require_relative "../helper"
4
+ require "yaml"
5
+
6
+ module Arel
7
+ module Nodes
8
+ class CommentTest < Arel::Spec
9
+ describe "equality" do
10
+ it "is equal with equal contents" do
11
+ array = [Comment.new(["foo"]), Comment.new(["foo"])]
12
+ assert_equal 1, array.uniq.size
13
+ end
14
+
15
+ it "is not equal with different contents" do
16
+ array = [Comment.new(["foo"]), Comment.new(["bar"])]
17
+ assert_equal 2, array.uniq.size
18
+ end
19
+ end
20
+ end
21
+ end
22
+ end
@@ -0,0 +1,35 @@
1
+ # frozen_string_literal: true
2
+
3
+ require_relative "../helper"
4
+
5
+ class Arel::Nodes::CountTest < Arel::Spec
6
+ describe "as" do
7
+ it "should alias the count" do
8
+ table = Arel::Table.new :users
9
+ _(table[:id].count.as("foo").to_sql).must_be_like %{
10
+ COUNT("users"."id") AS foo
11
+ }
12
+ end
13
+ end
14
+
15
+ describe "eq" do
16
+ it "should compare the count" do
17
+ table = Arel::Table.new :users
18
+ _(table[:id].count.eq(2).to_sql).must_be_like %{
19
+ COUNT("users"."id") = 2
20
+ }
21
+ end
22
+ end
23
+
24
+ describe "equality" do
25
+ it "is equal with equal ivars" do
26
+ array = [Arel::Nodes::Count.new("foo"), Arel::Nodes::Count.new("foo")]
27
+ assert_equal 1, array.uniq.size
28
+ end
29
+
30
+ it "is not equal with different ivars" do
31
+ array = [Arel::Nodes::Count.new("foo"), Arel::Nodes::Count.new("foo!")]
32
+ assert_equal 2, array.uniq.size
33
+ end
34
+ end
35
+ end
@@ -0,0 +1,36 @@
1
+ # frozen_string_literal: true
2
+
3
+ require_relative "../helper"
4
+
5
+ describe Arel::Nodes::DeleteStatement do
6
+ describe "#clone" do
7
+ it "clones wheres" do
8
+ statement = Arel::Nodes::DeleteStatement.new
9
+ statement.wheres = %w[a b c]
10
+
11
+ dolly = statement.clone
12
+ _(dolly.wheres).must_equal statement.wheres
13
+ _(dolly.wheres).wont_be_same_as statement.wheres
14
+ end
15
+ end
16
+
17
+ describe "equality" do
18
+ it "is equal with equal ivars" do
19
+ statement1 = Arel::Nodes::DeleteStatement.new
20
+ statement1.wheres = %w[a b c]
21
+ statement2 = Arel::Nodes::DeleteStatement.new
22
+ statement2.wheres = %w[a b c]
23
+ array = [statement1, statement2]
24
+ assert_equal 1, array.uniq.size
25
+ end
26
+
27
+ it "is not equal with different ivars" do
28
+ statement1 = Arel::Nodes::DeleteStatement.new
29
+ statement1.wheres = %w[a b c]
30
+ statement2 = Arel::Nodes::DeleteStatement.new
31
+ statement2.wheres = %w[1 2 3]
32
+ array = [statement1, statement2]
33
+ assert_equal 2, array.uniq.size
34
+ end
35
+ end
36
+ end
@@ -0,0 +1,46 @@
1
+ # frozen_string_literal: true
2
+
3
+ require_relative "../helper"
4
+
5
+ module Arel
6
+ module Nodes
7
+ class TestDescending < Arel::Test
8
+ def test_construct
9
+ descending = Descending.new "zomg"
10
+ assert_equal "zomg", descending.expr
11
+ end
12
+
13
+ def test_reverse
14
+ descending = Descending.new "zomg"
15
+ ascending = descending.reverse
16
+ assert_kind_of Ascending, ascending
17
+ assert_equal descending.expr, ascending.expr
18
+ end
19
+
20
+ def test_direction
21
+ descending = Descending.new "zomg"
22
+ assert_equal :desc, descending.direction
23
+ end
24
+
25
+ def test_ascending?
26
+ descending = Descending.new "zomg"
27
+ assert_not descending.ascending?
28
+ end
29
+
30
+ def test_descending?
31
+ descending = Descending.new "zomg"
32
+ assert descending.descending?
33
+ end
34
+
35
+ def test_equality_with_same_ivars
36
+ array = [Descending.new("zomg"), Descending.new("zomg")]
37
+ assert_equal 1, array.uniq.size
38
+ end
39
+
40
+ def test_inequality_with_different_ivars
41
+ array = [Descending.new("zomg"), Descending.new("zomg!")]
42
+ assert_equal 2, array.uniq.size
43
+ end
44
+ end
45
+ end
46
+ end