ibm_db 3.0.5-x86-mingw32 → 4.0.0-x86-mingw32

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 (586) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGES +4 -0
  3. data/LICENSE +1 -1
  4. data/MANIFEST +14 -14
  5. data/ParameterizedQueries README +6 -6
  6. data/README +208 -225
  7. data/ext/Makefile.nt32 +181 -181
  8. data/ext/Makefile.nt32.191 +212 -212
  9. data/ext/extconf.rb +291 -291
  10. data/ext/ibm_db.c +11887 -11887
  11. data/ext/ruby_ibm_db.h +241 -241
  12. data/ext/ruby_ibm_db_cli.c +866 -866
  13. data/ext/ruby_ibm_db_cli.h +500 -500
  14. data/init.rb +41 -41
  15. data/lib/IBM_DB.rb +27 -27
  16. data/lib/active_record/connection_adapters/ibm_db_adapter.rb +3452 -3177
  17. data/lib/active_record/connection_adapters/ibmdb_adapter.rb +5 -2
  18. data/lib/active_record/vendor/db2-i5-zOS.yaml +328 -328
  19. data/lib/mswin32/ibm_db.rb +91 -123
  20. data/lib/mswin32/rb2x/i386/ibm_db.so +0 -0
  21. data/test/active_record/connection_adapters/fake_adapter.rb +49 -46
  22. data/test/assets/example.log +1 -1
  23. data/test/assets/test.txt +1 -1
  24. data/test/cases/adapter_test.rb +351 -276
  25. data/test/cases/adapters/mysql2/active_schema_test.rb +193 -0
  26. data/test/cases/adapters/mysql2/bind_parameter_test.rb +50 -0
  27. data/test/cases/adapters/mysql2/boolean_test.rb +100 -0
  28. data/test/cases/adapters/mysql2/case_sensitivity_test.rb +63 -0
  29. data/test/cases/adapters/mysql2/charset_collation_test.rb +54 -0
  30. data/test/cases/adapters/mysql2/connection_test.rb +210 -0
  31. data/test/cases/adapters/mysql2/datetime_precision_quoting_test.rb +45 -0
  32. data/test/cases/adapters/mysql2/enum_test.rb +26 -0
  33. data/test/cases/adapters/mysql2/explain_test.rb +21 -0
  34. data/test/cases/adapters/mysql2/json_test.rb +195 -0
  35. data/test/cases/adapters/mysql2/mysql2_adapter_test.rb +83 -0
  36. data/test/cases/adapters/mysql2/reserved_word_test.rb +152 -0
  37. data/test/cases/adapters/mysql2/schema_migrations_test.rb +59 -0
  38. data/test/cases/adapters/mysql2/schema_test.rb +126 -0
  39. data/test/cases/adapters/mysql2/sp_test.rb +36 -0
  40. data/test/cases/adapters/mysql2/sql_types_test.rb +14 -0
  41. data/test/cases/adapters/mysql2/table_options_test.rb +42 -0
  42. data/test/cases/adapters/mysql2/unsigned_type_test.rb +66 -0
  43. data/test/cases/adapters/postgresql/active_schema_test.rb +98 -0
  44. data/test/cases/adapters/postgresql/array_test.rb +339 -0
  45. data/test/cases/adapters/postgresql/bit_string_test.rb +82 -0
  46. data/test/cases/adapters/postgresql/bytea_test.rb +134 -0
  47. data/test/cases/adapters/postgresql/case_insensitive_test.rb +26 -0
  48. data/test/cases/adapters/postgresql/change_schema_test.rb +38 -0
  49. data/test/cases/adapters/postgresql/cidr_test.rb +25 -0
  50. data/test/cases/adapters/postgresql/citext_test.rb +78 -0
  51. data/test/cases/adapters/postgresql/collation_test.rb +53 -0
  52. data/test/cases/adapters/postgresql/composite_test.rb +132 -0
  53. data/test/cases/adapters/postgresql/connection_test.rb +257 -0
  54. data/test/cases/adapters/postgresql/datatype_test.rb +92 -0
  55. data/test/cases/adapters/postgresql/domain_test.rb +47 -0
  56. data/test/cases/adapters/postgresql/enum_test.rb +91 -0
  57. data/test/cases/adapters/postgresql/explain_test.rb +20 -0
  58. data/test/cases/adapters/postgresql/extension_migration_test.rb +63 -0
  59. data/test/cases/adapters/postgresql/full_text_test.rb +44 -0
  60. data/test/cases/adapters/postgresql/geometric_test.rb +378 -0
  61. data/test/cases/adapters/postgresql/hstore_test.rb +382 -0
  62. data/test/cases/adapters/postgresql/infinity_test.rb +69 -0
  63. data/test/cases/adapters/postgresql/integer_test.rb +25 -0
  64. data/test/cases/adapters/postgresql/json_test.rb +237 -0
  65. data/test/cases/adapters/postgresql/ltree_test.rb +53 -0
  66. data/test/cases/adapters/postgresql/money_test.rb +96 -0
  67. data/test/cases/adapters/postgresql/network_test.rb +94 -0
  68. data/test/cases/adapters/postgresql/numbers_test.rb +49 -0
  69. data/test/cases/adapters/postgresql/postgresql_adapter_test.rb +405 -0
  70. data/test/cases/adapters/postgresql/prepared_statements_test.rb +22 -0
  71. data/test/cases/adapters/postgresql/quoting_test.rb +44 -0
  72. data/test/cases/adapters/postgresql/range_test.rb +343 -0
  73. data/test/cases/adapters/postgresql/referential_integrity_test.rb +111 -0
  74. data/test/cases/adapters/postgresql/rename_table_test.rb +34 -0
  75. data/test/cases/adapters/postgresql/schema_authorization_test.rb +119 -0
  76. data/test/cases/adapters/postgresql/schema_test.rb +597 -0
  77. data/test/cases/adapters/postgresql/serial_test.rb +154 -0
  78. data/test/cases/adapters/postgresql/statement_pool_test.rb +41 -0
  79. data/test/cases/adapters/postgresql/timestamp_test.rb +90 -0
  80. data/test/cases/adapters/postgresql/type_lookup_test.rb +33 -0
  81. data/test/cases/adapters/postgresql/utils_test.rb +62 -0
  82. data/test/cases/adapters/postgresql/uuid_test.rb +294 -0
  83. data/test/cases/adapters/postgresql/xml_test.rb +54 -0
  84. data/test/cases/adapters/sqlite3/collation_test.rb +53 -0
  85. data/test/cases/adapters/sqlite3/copy_table_test.rb +98 -0
  86. data/test/cases/adapters/sqlite3/explain_test.rb +21 -0
  87. data/test/cases/adapters/sqlite3/quoting_test.rb +101 -0
  88. data/test/cases/adapters/sqlite3/sqlite3_adapter_test.rb +441 -0
  89. data/test/cases/adapters/sqlite3/sqlite3_create_folder_test.rb +24 -0
  90. data/test/cases/adapters/sqlite3/statement_pool_test.rb +20 -0
  91. data/test/cases/aggregations_test.rb +168 -158
  92. data/test/cases/ar_schema_test.rb +146 -161
  93. data/test/cases/associations/association_scope_test.rb +16 -21
  94. data/test/cases/associations/belongs_to_associations_test.rb +1141 -1029
  95. data/test/cases/associations/bidirectional_destroy_dependencies_test.rb +41 -0
  96. data/test/cases/associations/callbacks_test.rb +190 -192
  97. data/test/cases/associations/cascaded_eager_loading_test.rb +188 -188
  98. data/test/cases/associations/eager_load_includes_full_sti_class_test.rb +36 -36
  99. data/test/cases/associations/eager_load_nested_include_test.rb +126 -128
  100. data/test/cases/associations/eager_singularization_test.rb +148 -148
  101. data/test/cases/associations/eager_test.rb +1514 -1429
  102. data/test/cases/associations/extension_test.rb +87 -82
  103. data/test/cases/associations/has_and_belongs_to_many_associations_test.rb +1004 -972
  104. data/test/cases/associations/has_many_associations_test.rb +2501 -2182
  105. data/test/cases/associations/has_many_through_associations_test.rb +1271 -1204
  106. data/test/cases/associations/has_one_associations_test.rb +707 -610
  107. data/test/cases/associations/has_one_through_associations_test.rb +383 -380
  108. data/test/cases/associations/inner_join_association_test.rb +139 -139
  109. data/test/cases/associations/inverse_associations_test.rb +733 -706
  110. data/test/cases/associations/join_model_test.rb +777 -754
  111. data/test/cases/associations/left_outer_join_association_test.rb +88 -0
  112. data/test/cases/associations/nested_through_associations_test.rb +579 -579
  113. data/test/cases/associations/required_test.rb +102 -82
  114. data/test/cases/associations_test.rb +385 -380
  115. data/test/cases/attribute_decorators_test.rb +125 -125
  116. data/test/cases/attribute_methods/read_test.rb +60 -60
  117. data/test/cases/attribute_methods_test.rb +1009 -952
  118. data/test/cases/attribute_set_test.rb +270 -210
  119. data/test/cases/attribute_test.rb +246 -180
  120. data/test/cases/attributes_test.rb +253 -136
  121. data/test/cases/autosave_association_test.rb +1708 -1595
  122. data/test/cases/base_test.rb +1713 -1664
  123. data/test/cases/batches_test.rb +489 -212
  124. data/test/cases/binary_test.rb +44 -52
  125. data/test/cases/bind_parameter_test.rb +110 -100
  126. data/test/cases/cache_key_test.rb +25 -0
  127. data/test/cases/calculations_test.rb +798 -646
  128. data/test/cases/callbacks_test.rb +636 -543
  129. data/test/cases/clone_test.rb +40 -40
  130. data/test/cases/coders/json_test.rb +15 -0
  131. data/test/cases/coders/yaml_column_test.rb +63 -63
  132. data/test/cases/collection_cache_key_test.rb +115 -0
  133. data/test/cases/column_alias_test.rb +17 -17
  134. data/test/cases/column_definition_test.rb +92 -123
  135. data/test/cases/comment_test.rb +143 -0
  136. data/test/cases/connection_adapters/adapter_leasing_test.rb +56 -54
  137. data/test/cases/connection_adapters/connection_handler_test.rb +160 -53
  138. data/test/cases/connection_adapters/connection_specification_test.rb +12 -12
  139. data/test/cases/connection_adapters/merge_and_resolve_default_url_config_test.rb +255 -293
  140. data/test/cases/connection_adapters/mysql_type_lookup_test.rb +69 -65
  141. data/test/cases/connection_adapters/quoting_test.rb +13 -13
  142. data/test/cases/connection_adapters/schema_cache_test.rb +61 -56
  143. data/test/cases/connection_adapters/type_lookup_test.rb +118 -110
  144. data/test/cases/connection_management_test.rb +112 -122
  145. data/test/cases/connection_pool_test.rb +521 -346
  146. data/test/cases/connection_specification/resolver_test.rb +131 -116
  147. data/test/cases/core_test.rb +112 -112
  148. data/test/cases/counter_cache_test.rb +214 -209
  149. data/test/cases/custom_locking_test.rb +17 -17
  150. data/test/cases/database_statements_test.rb +34 -19
  151. data/test/cases/{invalid_date_test.rb → date_test.rb} +44 -32
  152. data/test/cases/date_time_precision_test.rb +106 -0
  153. data/test/cases/date_time_test.rb +61 -61
  154. data/test/cases/defaults_test.rb +218 -223
  155. data/test/cases/dirty_test.rb +763 -785
  156. data/test/cases/disconnected_test.rb +30 -28
  157. data/test/cases/dup_test.rb +157 -157
  158. data/test/cases/enum_test.rb +444 -290
  159. data/test/cases/errors_test.rb +16 -0
  160. data/test/cases/explain_subscriber_test.rb +64 -64
  161. data/test/cases/explain_test.rb +87 -76
  162. data/test/cases/finder_respond_to_test.rb +60 -60
  163. data/test/cases/finder_test.rb +1294 -1169
  164. data/test/cases/fixture_set/file_test.rb +156 -138
  165. data/test/cases/fixtures_test.rb +988 -908
  166. data/test/cases/forbidden_attributes_protection_test.rb +165 -99
  167. data/test/cases/habtm_destroy_order_test.rb +61 -61
  168. data/test/cases/helper.rb +204 -210
  169. data/test/cases/hot_compatibility_test.rb +142 -54
  170. data/test/cases/i18n_test.rb +45 -45
  171. data/test/cases/inheritance_test.rb +606 -375
  172. data/test/cases/integration_test.rb +155 -139
  173. data/test/cases/invalid_connection_test.rb +24 -22
  174. data/test/cases/invertible_migration_test.rb +387 -295
  175. data/test/cases/json_serialization_test.rb +311 -302
  176. data/test/cases/locking_test.rb +493 -477
  177. data/test/cases/log_subscriber_test.rb +225 -136
  178. data/test/cases/migration/change_schema_test.rb +458 -512
  179. data/test/cases/migration/change_table_test.rb +256 -224
  180. data/test/cases/migration/column_attributes_test.rb +176 -192
  181. data/test/cases/migration/column_positioning_test.rb +56 -56
  182. data/test/cases/migration/columns_test.rb +310 -304
  183. data/test/cases/migration/command_recorder_test.rb +350 -305
  184. data/test/cases/migration/compatibility_test.rb +118 -0
  185. data/test/cases/migration/create_join_table_test.rb +157 -148
  186. data/test/cases/migration/foreign_key_test.rb +360 -328
  187. data/test/cases/migration/helper.rb +39 -39
  188. data/test/cases/migration/index_test.rb +218 -216
  189. data/test/cases/migration/logger_test.rb +36 -36
  190. data/test/cases/migration/pending_migrations_test.rb +52 -53
  191. data/test/cases/migration/references_foreign_key_test.rb +216 -169
  192. data/test/cases/migration/references_index_test.rb +101 -101
  193. data/test/cases/migration/references_statements_test.rb +136 -116
  194. data/test/cases/migration/rename_table_test.rb +93 -93
  195. data/test/cases/migration_test.rb +1157 -959
  196. data/test/cases/migrator_test.rb +470 -388
  197. data/test/cases/mixin_test.rb +68 -70
  198. data/test/cases/modules_test.rb +172 -173
  199. data/test/cases/multiparameter_attributes_test.rb +372 -350
  200. data/test/cases/multiple_db_test.rb +122 -115
  201. data/test/cases/nested_attributes_test.rb +1098 -1070
  202. data/test/cases/nested_attributes_with_callbacks_test.rb +144 -144
  203. data/test/cases/persistence_test.rb +1001 -909
  204. data/test/cases/pooled_connections_test.rb +81 -81
  205. data/test/cases/primary_keys_test.rb +376 -237
  206. data/test/cases/query_cache_test.rb +446 -326
  207. data/test/cases/quoting_test.rb +202 -156
  208. data/test/cases/readonly_test.rb +119 -118
  209. data/test/cases/reaper_test.rb +85 -85
  210. data/test/cases/reflection_test.rb +509 -463
  211. data/test/cases/relation/delegation_test.rb +63 -68
  212. data/test/cases/relation/merging_test.rb +157 -161
  213. data/test/cases/relation/mutation_test.rb +183 -165
  214. data/test/cases/relation/or_test.rb +92 -0
  215. data/test/cases/relation/predicate_builder_test.rb +16 -14
  216. data/test/cases/relation/record_fetch_warning_test.rb +40 -0
  217. data/test/cases/relation/where_chain_test.rb +105 -181
  218. data/test/cases/relation/where_clause_test.rb +182 -0
  219. data/test/cases/relation/where_test.rb +322 -300
  220. data/test/cases/relation_test.rb +328 -319
  221. data/test/cases/relations_test.rb +2026 -1815
  222. data/test/cases/reload_models_test.rb +22 -22
  223. data/test/cases/result_test.rb +90 -80
  224. data/test/cases/sanitize_test.rb +176 -83
  225. data/test/cases/schema_dumper_test.rb +457 -463
  226. data/test/cases/schema_loading_test.rb +52 -0
  227. data/test/cases/scoping/default_scoping_test.rb +528 -454
  228. data/test/cases/scoping/named_scoping_test.rb +561 -524
  229. data/test/cases/scoping/relation_scoping_test.rb +400 -357
  230. data/test/cases/secure_token_test.rb +32 -0
  231. data/test/cases/serialization_test.rb +104 -104
  232. data/test/cases/serialized_attribute_test.rb +364 -277
  233. data/test/cases/statement_cache_test.rb +136 -98
  234. data/test/cases/store_test.rb +195 -194
  235. data/test/cases/suppressor_test.rb +63 -0
  236. data/test/cases/tasks/database_tasks_test.rb +462 -398
  237. data/test/cases/tasks/mysql_rake_test.rb +345 -324
  238. data/test/cases/tasks/postgresql_rake_test.rb +304 -250
  239. data/test/cases/tasks/sqlite_rake_test.rb +220 -193
  240. data/test/cases/test_case.rb +131 -123
  241. data/test/cases/test_fixtures_test.rb +36 -0
  242. data/test/cases/time_precision_test.rb +102 -0
  243. data/test/cases/timestamp_test.rb +501 -467
  244. data/test/cases/touch_later_test.rb +121 -0
  245. data/test/cases/transaction_callbacks_test.rb +518 -452
  246. data/test/cases/transaction_isolation_test.rb +106 -106
  247. data/test/cases/transactions_test.rb +834 -817
  248. data/test/cases/type/adapter_specific_registry_test.rb +133 -0
  249. data/test/cases/type/date_time_test.rb +14 -0
  250. data/test/cases/type/integer_test.rb +27 -121
  251. data/test/cases/type/string_test.rb +22 -36
  252. data/test/cases/type/type_map_test.rb +177 -177
  253. data/test/cases/type_test.rb +39 -0
  254. data/test/cases/types_test.rb +24 -141
  255. data/test/cases/unconnected_test.rb +33 -33
  256. data/test/cases/validations/absence_validation_test.rb +73 -0
  257. data/test/cases/validations/association_validation_test.rb +97 -86
  258. data/test/cases/validations/i18n_generate_message_validation_test.rb +84 -84
  259. data/test/cases/validations/i18n_validation_test.rb +86 -90
  260. data/test/cases/validations/length_validation_test.rb +79 -47
  261. data/test/cases/validations/presence_validation_test.rb +103 -68
  262. data/test/cases/validations/uniqueness_validation_test.rb +548 -457
  263. data/test/cases/validations_repair_helper.rb +19 -23
  264. data/test/cases/validations_test.rb +194 -165
  265. data/test/cases/view_test.rb +216 -119
  266. data/test/cases/yaml_serialization_test.rb +121 -126
  267. data/test/config.example.yml +97 -0
  268. data/test/config.rb +5 -5
  269. data/test/fixtures/accounts.yml +29 -29
  270. data/test/fixtures/admin/accounts.yml +2 -2
  271. data/test/fixtures/admin/users.yml +10 -10
  272. data/test/fixtures/author_addresses.original +11 -0
  273. data/test/fixtures/author_addresses.yml +17 -17
  274. data/test/fixtures/author_favorites.yml +3 -3
  275. data/test/fixtures/authors.original +17 -0
  276. data/test/fixtures/authors.yml +23 -23
  277. data/test/fixtures/bad_posts.yml +9 -0
  278. data/test/fixtures/binaries.yml +133 -133
  279. data/test/fixtures/books.yml +31 -11
  280. data/test/fixtures/bulbs.yml +5 -5
  281. data/test/fixtures/cars.yml +9 -9
  282. data/test/fixtures/categories.yml +19 -19
  283. data/test/fixtures/categories/special_categories.yml +9 -9
  284. data/test/fixtures/categories/subsubdir/arbitrary_filename.yml +4 -4
  285. data/test/fixtures/categories_ordered.yml +7 -7
  286. data/test/fixtures/categories_posts.yml +31 -31
  287. data/test/fixtures/categorizations.yml +23 -23
  288. data/test/fixtures/clubs.yml +8 -8
  289. data/test/fixtures/collections.yml +3 -3
  290. data/test/fixtures/colleges.yml +3 -3
  291. data/test/fixtures/comments.yml +65 -65
  292. data/test/fixtures/companies.yml +67 -67
  293. data/test/fixtures/computers.yml +10 -10
  294. data/test/fixtures/content.yml +3 -0
  295. data/test/fixtures/content_positions.yml +3 -0
  296. data/test/fixtures/courses.yml +8 -8
  297. data/test/fixtures/customers.yml +25 -25
  298. data/test/fixtures/dashboards.yml +6 -6
  299. data/test/fixtures/dead_parrots.yml +5 -0
  300. data/test/fixtures/developers.yml +22 -22
  301. data/test/fixtures/developers_projects.yml +16 -16
  302. data/test/fixtures/dog_lovers.yml +7 -7
  303. data/test/fixtures/dogs.yml +4 -4
  304. data/test/fixtures/doubloons.yml +3 -3
  305. data/test/fixtures/edges.yml +5 -5
  306. data/test/fixtures/entrants.yml +14 -14
  307. data/test/fixtures/essays.yml +6 -6
  308. data/test/fixtures/faces.yml +11 -11
  309. data/test/fixtures/fk_test_has_fk.yml +3 -3
  310. data/test/fixtures/fk_test_has_pk.yml +1 -1
  311. data/test/fixtures/friendships.yml +4 -4
  312. data/test/fixtures/funny_jokes.yml +10 -10
  313. data/test/fixtures/interests.yml +33 -33
  314. data/test/fixtures/items.yml +3 -3
  315. data/test/fixtures/jobs.yml +7 -7
  316. data/test/fixtures/legacy_things.yml +3 -3
  317. data/test/fixtures/live_parrots.yml +4 -0
  318. data/test/fixtures/mateys.yml +4 -4
  319. data/test/fixtures/member_details.yml +8 -8
  320. data/test/fixtures/member_types.yml +6 -6
  321. data/test/fixtures/members.yml +11 -11
  322. data/test/fixtures/memberships.yml +34 -34
  323. data/test/fixtures/men.yml +5 -5
  324. data/test/fixtures/minimalistics.yml +2 -2
  325. data/test/fixtures/minivans.yml +5 -5
  326. data/test/fixtures/mixed_case_monkeys.yml +6 -6
  327. data/test/fixtures/mixins.yml +29 -29
  328. data/test/fixtures/movies.yml +7 -7
  329. data/test/fixtures/naked/yml/accounts.yml +1 -1
  330. data/test/fixtures/naked/yml/companies.yml +1 -1
  331. data/test/fixtures/naked/yml/courses.yml +1 -1
  332. data/test/fixtures/naked/yml/parrots.yml +2 -0
  333. data/test/fixtures/naked/yml/trees.yml +3 -0
  334. data/test/fixtures/nodes.yml +29 -0
  335. data/test/fixtures/organizations.yml +5 -5
  336. data/test/fixtures/other_comments.yml +6 -0
  337. data/test/fixtures/other_dogs.yml +2 -0
  338. data/test/fixtures/other_posts.yml +7 -0
  339. data/test/fixtures/other_topics.yml +42 -42
  340. data/test/fixtures/owners.yml +9 -9
  341. data/test/fixtures/parrots.yml +27 -27
  342. data/test/fixtures/parrots_pirates.yml +7 -7
  343. data/test/fixtures/people.yml +24 -24
  344. data/test/fixtures/peoples_treasures.yml +3 -3
  345. data/test/fixtures/pets.yml +19 -19
  346. data/test/fixtures/pirates.yml +15 -12
  347. data/test/fixtures/posts.yml +80 -80
  348. data/test/fixtures/price_estimates.yml +16 -7
  349. data/test/fixtures/products.yml +4 -4
  350. data/test/fixtures/projects.yml +7 -7
  351. data/test/fixtures/ratings.yml +14 -14
  352. data/test/fixtures/readers.yml +11 -11
  353. data/test/fixtures/references.yml +17 -17
  354. data/test/fixtures/reserved_words/distinct.yml +5 -5
  355. data/test/fixtures/reserved_words/distinct_select.yml +11 -11
  356. data/test/fixtures/reserved_words/group.yml +14 -14
  357. data/test/fixtures/reserved_words/select.yml +8 -8
  358. data/test/fixtures/reserved_words/values.yml +7 -7
  359. data/test/fixtures/ships.yml +6 -6
  360. data/test/fixtures/speedometers.yml +8 -8
  361. data/test/fixtures/sponsors.yml +12 -12
  362. data/test/fixtures/string_key_objects.yml +7 -7
  363. data/test/fixtures/subscribers.yml +10 -10
  364. data/test/fixtures/subscriptions.yml +12 -12
  365. data/test/fixtures/taggings.yml +78 -78
  366. data/test/fixtures/tags.yml +11 -11
  367. data/test/fixtures/tasks.yml +7 -7
  368. data/test/fixtures/teapots.yml +3 -3
  369. data/test/fixtures/to_be_linked/accounts.yml +2 -2
  370. data/test/fixtures/to_be_linked/users.yml +10 -10
  371. data/test/fixtures/topics.yml +49 -49
  372. data/test/fixtures/toys.yml +14 -14
  373. data/test/fixtures/traffic_lights.yml +9 -9
  374. data/test/fixtures/treasures.yml +10 -10
  375. data/test/fixtures/trees.yml +3 -0
  376. data/test/fixtures/uuid_children.yml +3 -3
  377. data/test/fixtures/uuid_parents.yml +2 -2
  378. data/test/fixtures/variants.yml +4 -4
  379. data/test/fixtures/vegetables.yml +19 -19
  380. data/test/fixtures/vertices.yml +3 -3
  381. data/test/fixtures/warehouse_things.yml +2 -2
  382. data/test/fixtures/zines.yml +5 -5
  383. data/test/migrations/10_urban/9_add_expressions.rb +11 -11
  384. data/test/migrations/decimal/1_give_me_big_numbers.rb +15 -15
  385. data/test/migrations/magic/1_currencies_have_symbols.rb +12 -12
  386. data/test/migrations/missing/1000_people_have_middle_names.rb +9 -9
  387. data/test/migrations/missing/1_people_have_last_names.rb +9 -9
  388. data/test/migrations/missing/3_we_need_reminders.rb +12 -12
  389. data/test/migrations/missing/4_innocent_jointable.rb +12 -12
  390. data/test/migrations/rename/1_we_need_things.rb +11 -11
  391. data/test/migrations/rename/2_rename_things.rb +9 -9
  392. data/test/migrations/to_copy/1_people_have_hobbies.rb +9 -9
  393. data/test/migrations/to_copy/2_people_have_descriptions.rb +9 -9
  394. data/test/migrations/to_copy2/1_create_articles.rb +7 -7
  395. data/test/migrations/to_copy2/2_create_comments.rb +7 -7
  396. data/test/migrations/to_copy_with_name_collision/1_people_have_hobbies.rb +9 -9
  397. data/test/migrations/to_copy_with_timestamps/20090101010101_people_have_hobbies.rb +9 -9
  398. data/test/migrations/to_copy_with_timestamps/20090101010202_people_have_descriptions.rb +9 -9
  399. data/test/migrations/to_copy_with_timestamps2/20090101010101_create_articles.rb +7 -7
  400. data/test/migrations/to_copy_with_timestamps2/20090101010202_create_comments.rb +7 -7
  401. data/test/migrations/valid/1_valid_people_have_last_names.rb +9 -9
  402. data/test/migrations/valid/2_we_need_reminders.rb +12 -12
  403. data/test/migrations/valid/3_innocent_jointable.rb +12 -12
  404. data/test/migrations/valid_with_subdirectories/1_valid_people_have_last_names.rb +9 -9
  405. data/test/migrations/valid_with_subdirectories/sub/2_we_need_reminders.rb +12 -12
  406. data/test/migrations/valid_with_subdirectories/sub1/3_innocent_jointable.rb +12 -12
  407. data/test/migrations/valid_with_timestamps/20100101010101_valid_with_timestamps_people_have_last_names.rb +9 -9
  408. data/test/migrations/valid_with_timestamps/20100201010101_valid_with_timestamps_we_need_reminders.rb +12 -12
  409. data/test/migrations/valid_with_timestamps/20100301010101_valid_with_timestamps_innocent_jointable.rb +12 -12
  410. data/test/migrations/version_check/20131219224947_migration_version_check.rb +8 -8
  411. data/test/models/admin.rb +5 -5
  412. data/test/models/admin/account.rb +3 -3
  413. data/test/models/admin/randomly_named_c1.rb +6 -2
  414. data/test/models/admin/user.rb +40 -40
  415. data/test/models/aircraft.rb +5 -4
  416. data/test/models/arunit2_model.rb +3 -3
  417. data/test/models/author.rb +209 -212
  418. data/test/models/auto_id.rb +4 -4
  419. data/test/models/autoloadable/extra_firm.rb +2 -2
  420. data/test/models/binary.rb +2 -2
  421. data/test/models/bird.rb +12 -12
  422. data/test/models/book.rb +23 -18
  423. data/test/models/boolean.rb +2 -2
  424. data/test/models/bulb.rb +52 -51
  425. data/test/models/cake_designer.rb +3 -3
  426. data/test/models/car.rb +29 -26
  427. data/test/models/carrier.rb +2 -2
  428. data/test/models/cat.rb +10 -0
  429. data/test/models/categorization.rb +19 -19
  430. data/test/models/category.rb +35 -35
  431. data/test/models/chef.rb +8 -7
  432. data/test/models/citation.rb +3 -3
  433. data/test/models/club.rb +25 -23
  434. data/test/models/college.rb +10 -10
  435. data/test/models/column.rb +3 -3
  436. data/test/models/column_name.rb +3 -3
  437. data/test/models/comment.rb +76 -64
  438. data/test/models/company.rb +230 -228
  439. data/test/models/company_in_module.rb +98 -98
  440. data/test/models/computer.rb +3 -3
  441. data/test/models/contact.rb +41 -41
  442. data/test/models/content.rb +40 -0
  443. data/test/models/contract.rb +20 -20
  444. data/test/models/country.rb +7 -7
  445. data/test/models/course.rb +6 -6
  446. data/test/models/customer.rb +83 -77
  447. data/test/models/customer_carrier.rb +14 -14
  448. data/test/models/dashboard.rb +3 -3
  449. data/test/models/default.rb +2 -2
  450. data/test/models/department.rb +4 -4
  451. data/test/models/developer.rb +274 -255
  452. data/test/models/dog.rb +5 -5
  453. data/test/models/dog_lover.rb +5 -5
  454. data/test/models/doubloon.rb +12 -12
  455. data/test/models/drink_designer.rb +3 -3
  456. data/test/models/edge.rb +5 -5
  457. data/test/models/electron.rb +5 -5
  458. data/test/models/engine.rb +4 -4
  459. data/test/models/entrant.rb +3 -3
  460. data/test/models/essay.rb +5 -5
  461. data/test/models/event.rb +3 -3
  462. data/test/models/eye.rb +37 -37
  463. data/test/models/face.rb +9 -9
  464. data/test/models/friendship.rb +6 -6
  465. data/test/models/guid.rb +2 -2
  466. data/test/models/guitar.rb +4 -0
  467. data/test/models/hotel.rb +11 -9
  468. data/test/models/image.rb +3 -3
  469. data/test/models/interest.rb +5 -5
  470. data/test/models/invoice.rb +4 -4
  471. data/test/models/item.rb +7 -7
  472. data/test/models/job.rb +7 -7
  473. data/test/models/joke.rb +7 -7
  474. data/test/models/keyboard.rb +3 -3
  475. data/test/models/legacy_thing.rb +3 -3
  476. data/test/models/lesson.rb +11 -11
  477. data/test/models/line_item.rb +3 -3
  478. data/test/models/liquid.rb +4 -4
  479. data/test/models/man.rb +11 -11
  480. data/test/models/matey.rb +4 -4
  481. data/test/models/member.rb +42 -41
  482. data/test/models/member_detail.rb +8 -7
  483. data/test/models/member_type.rb +3 -3
  484. data/test/models/membership.rb +35 -35
  485. data/test/models/mentor.rb +3 -0
  486. data/test/models/minimalistic.rb +2 -2
  487. data/test/models/minivan.rb +9 -9
  488. data/test/models/mixed_case_monkey.rb +3 -3
  489. data/test/models/mocktail_designer.rb +2 -0
  490. data/test/models/molecule.rb +6 -6
  491. data/test/models/movie.rb +5 -5
  492. data/test/models/node.rb +5 -0
  493. data/test/models/non_primary_key.rb +2 -0
  494. data/test/models/notification.rb +3 -0
  495. data/test/models/order.rb +4 -4
  496. data/test/models/organization.rb +14 -14
  497. data/test/models/other_dog.rb +5 -0
  498. data/test/models/owner.rb +37 -34
  499. data/test/models/parrot.rb +28 -29
  500. data/test/models/person.rb +142 -143
  501. data/test/models/personal_legacy_thing.rb +4 -4
  502. data/test/models/pet.rb +18 -15
  503. data/test/models/pet_treasure.rb +6 -0
  504. data/test/models/pirate.rb +92 -92
  505. data/test/models/possession.rb +3 -3
  506. data/test/models/post.rb +273 -264
  507. data/test/models/price_estimate.rb +4 -4
  508. data/test/models/professor.rb +5 -5
  509. data/test/models/project.rb +40 -31
  510. data/test/models/publisher.rb +2 -2
  511. data/test/models/publisher/article.rb +4 -4
  512. data/test/models/publisher/magazine.rb +3 -3
  513. data/test/models/randomly_named_c1.rb +1 -1
  514. data/test/models/rating.rb +4 -4
  515. data/test/models/reader.rb +23 -23
  516. data/test/models/recipe.rb +3 -0
  517. data/test/models/record.rb +2 -2
  518. data/test/models/reference.rb +22 -22
  519. data/test/models/reply.rb +61 -61
  520. data/test/models/ship.rb +39 -33
  521. data/test/models/ship_part.rb +8 -8
  522. data/test/models/shop.rb +17 -17
  523. data/test/models/shop_account.rb +6 -6
  524. data/test/models/speedometer.rb +6 -6
  525. data/test/models/sponsor.rb +7 -7
  526. data/test/models/string_key_object.rb +3 -3
  527. data/test/models/student.rb +4 -4
  528. data/test/models/subject.rb +16 -16
  529. data/test/models/subscriber.rb +8 -8
  530. data/test/models/subscription.rb +4 -4
  531. data/test/models/tag.rb +13 -7
  532. data/test/models/tagging.rb +13 -13
  533. data/test/models/task.rb +5 -5
  534. data/test/models/topic.rb +118 -124
  535. data/test/models/toy.rb +6 -6
  536. data/test/models/traffic_light.rb +4 -4
  537. data/test/models/treasure.rb +14 -14
  538. data/test/models/treaty.rb +7 -7
  539. data/test/models/tree.rb +3 -0
  540. data/test/models/tuning_peg.rb +4 -0
  541. data/test/models/tyre.rb +11 -11
  542. data/test/models/user.rb +14 -0
  543. data/test/models/uuid_child.rb +3 -3
  544. data/test/models/uuid_item.rb +6 -0
  545. data/test/models/uuid_parent.rb +3 -3
  546. data/test/models/vegetables.rb +24 -24
  547. data/test/models/vehicle.rb +6 -6
  548. data/test/models/vertex.rb +9 -9
  549. data/test/models/warehouse_thing.rb +5 -5
  550. data/test/models/wheel.rb +3 -3
  551. data/test/models/without_table.rb +3 -3
  552. data/test/models/zine.rb +3 -3
  553. data/test/schema/mysql2_specific_schema.rb +68 -58
  554. data/test/schema/oracle_specific_schema.rb +40 -43
  555. data/test/schema/postgresql_specific_schema.rb +114 -202
  556. data/test/schema/schema.rb +1057 -952
  557. data/test/schema/schema.rb.original +1057 -0
  558. data/test/schema/sqlite_specific_schema.rb +18 -22
  559. data/test/support/config.rb +43 -43
  560. data/test/support/connection.rb +23 -22
  561. data/test/support/connection_helper.rb +14 -14
  562. data/test/support/ddl_helper.rb +8 -8
  563. data/test/support/schema_dumping_helper.rb +20 -20
  564. data/test/support/yaml_compatibility_fixtures/rails_4_1.yml +22 -0
  565. data/test/support/yaml_compatibility_fixtures/rails_4_2_0.yml +182 -0
  566. metadata +129 -28
  567. data/lib/mswin32/rb19x/ibm_db.so +0 -0
  568. data/lib/mswin32/rb21x/i386/ibm_db.so +0 -0
  569. data/lib/mswin32/rb22x/i386/ibm_db.so +0 -0
  570. data/lib/mswin32/rb23x/i386/ibm_db.so +0 -0
  571. data/test/cases/associations/deprecated_counter_cache_on_has_many_through_test.rb +0 -26
  572. data/test/cases/attribute_methods/serialization_test.rb +0 -29
  573. data/test/cases/migration/change_schema_test - Copy.rb +0 -448
  574. data/test/cases/migration/foreign_key_test - Changed.rb +0 -325
  575. data/test/cases/migration/table_and_index_test.rb +0 -24
  576. data/test/cases/relation/where_test2.rb +0 -36
  577. data/test/cases/type/decimal_test.rb +0 -56
  578. data/test/cases/type/unsigned_integer_test.rb +0 -18
  579. data/test/cases/xml_serialization_test.rb +0 -457
  580. data/test/connections/native_ibm_db/connection.rb +0 -44
  581. data/test/fixtures/naked/csv/accounts.csv +0 -1
  582. data/test/schema/i5/ibm_db_specific_schema.rb +0 -137
  583. data/test/schema/ids/ibm_db_specific_schema.rb +0 -140
  584. data/test/schema/luw/ibm_db_specific_schema.rb +0 -137
  585. data/test/schema/mysql_specific_schema.rb +0 -70
  586. data/test/schema/zOS/ibm_db_specific_schema.rb +0 -208
@@ -1,81 +1,81 @@
1
- require "cases/helper"
2
- require "models/project"
3
- require "timeout"
4
-
5
- class PooledConnectionsTest < ActiveRecord::TestCase
6
- self.use_transactional_fixtures = false
7
-
8
- def setup
9
- @per_test_teardown = []
10
- @connection = ActiveRecord::Base.remove_connection
11
- end
12
-
13
- teardown do
14
- ActiveRecord::Base.clear_all_connections!
15
- ActiveRecord::Base.establish_connection(@connection)
16
- @per_test_teardown.each {|td| td.call }
17
- end
18
-
19
- # Will deadlock due to lack of Monitor timeouts in 1.9
20
- def checkout_checkin_connections(pool_size, threads)
21
- ActiveRecord::Base.establish_connection(@connection.merge({:pool => pool_size, :checkout_timeout => 0.5}))
22
- @connection_count = 0
23
- @timed_out = 0
24
- threads.times do
25
- Thread.new do
26
- begin
27
- conn = ActiveRecord::Base.connection_pool.checkout
28
- sleep 0.1
29
- ActiveRecord::Base.connection_pool.checkin conn
30
- @connection_count += 1
31
- rescue ActiveRecord::ConnectionTimeoutError
32
- @timed_out += 1
33
- end
34
- end.join
35
- end
36
- end
37
-
38
- def checkout_checkin_connections_loop(pool_size, loops)
39
- ActiveRecord::Base.establish_connection(@connection.merge({:pool => pool_size, :checkout_timeout => 0.5}))
40
- @connection_count = 0
41
- @timed_out = 0
42
- loops.times do
43
- begin
44
- conn = ActiveRecord::Base.connection_pool.checkout
45
- ActiveRecord::Base.connection_pool.checkin conn
46
- @connection_count += 1
47
- ActiveRecord::Base.connection.tables
48
- rescue ActiveRecord::ConnectionTimeoutError
49
- @timed_out += 1
50
- end
51
- end
52
- end
53
-
54
- def test_pooled_connection_checkin_one
55
- checkout_checkin_connections 1, 2
56
- assert_equal 2, @connection_count
57
- assert_equal 0, @timed_out
58
- assert_equal 1, ActiveRecord::Base.connection_pool.connections.size
59
- end
60
-
61
- def test_pooled_connection_checkin_two
62
- checkout_checkin_connections_loop 2, 3
63
- assert_equal 3, @connection_count
64
- assert_equal 0, @timed_out
65
- assert_equal 2, ActiveRecord::Base.connection_pool.connections.size
66
- end
67
-
68
- def test_pooled_connection_remove
69
- ActiveRecord::Base.establish_connection(@connection.merge({:pool => 2, :checkout_timeout => 0.5}))
70
- old_connection = ActiveRecord::Base.connection
71
- extra_connection = ActiveRecord::Base.connection_pool.checkout
72
- ActiveRecord::Base.connection_pool.remove(extra_connection)
73
- assert_equal ActiveRecord::Base.connection, old_connection
74
- end
75
-
76
- private
77
-
78
- def add_record(name)
79
- ActiveRecord::Base.connection_pool.with_connection { Project.create! :name => name }
80
- end
81
- end unless in_memory_db?
1
+ require "cases/helper"
2
+ require "models/project"
3
+ require "timeout"
4
+
5
+ class PooledConnectionsTest < ActiveRecord::TestCase
6
+ self.use_transactional_tests = false
7
+
8
+ def setup
9
+ @per_test_teardown = []
10
+ @connection = ActiveRecord::Base.remove_connection
11
+ end
12
+
13
+ teardown do
14
+ ActiveRecord::Base.clear_all_connections!
15
+ ActiveRecord::Base.establish_connection(@connection)
16
+ @per_test_teardown.each(&:call)
17
+ end
18
+
19
+ # Will deadlock due to lack of Monitor timeouts in 1.9
20
+ def checkout_checkin_connections(pool_size, threads)
21
+ ActiveRecord::Base.establish_connection(@connection.merge({:pool => pool_size, :checkout_timeout => 0.5}))
22
+ @connection_count = 0
23
+ @timed_out = 0
24
+ threads.times do
25
+ Thread.new do
26
+ begin
27
+ conn = ActiveRecord::Base.connection_pool.checkout
28
+ sleep 0.1
29
+ ActiveRecord::Base.connection_pool.checkin conn
30
+ @connection_count += 1
31
+ rescue ActiveRecord::ConnectionTimeoutError
32
+ @timed_out += 1
33
+ end
34
+ end.join
35
+ end
36
+ end
37
+
38
+ def checkout_checkin_connections_loop(pool_size, loops)
39
+ ActiveRecord::Base.establish_connection(@connection.merge({:pool => pool_size, :checkout_timeout => 0.5}))
40
+ @connection_count = 0
41
+ @timed_out = 0
42
+ loops.times do
43
+ begin
44
+ conn = ActiveRecord::Base.connection_pool.checkout
45
+ ActiveRecord::Base.connection_pool.checkin conn
46
+ @connection_count += 1
47
+ ActiveRecord::Base.connection.data_sources
48
+ rescue ActiveRecord::ConnectionTimeoutError
49
+ @timed_out += 1
50
+ end
51
+ end
52
+ end
53
+
54
+ def test_pooled_connection_checkin_one
55
+ checkout_checkin_connections 1, 2
56
+ assert_equal 2, @connection_count
57
+ assert_equal 0, @timed_out
58
+ assert_equal 1, ActiveRecord::Base.connection_pool.connections.size
59
+ end
60
+
61
+ def test_pooled_connection_checkin_two
62
+ checkout_checkin_connections_loop 2, 3
63
+ assert_equal 3, @connection_count
64
+ assert_equal 0, @timed_out
65
+ assert_equal 2, ActiveRecord::Base.connection_pool.connections.size
66
+ end
67
+
68
+ def test_pooled_connection_remove
69
+ ActiveRecord::Base.establish_connection(@connection.merge({:pool => 2, :checkout_timeout => 0.5}))
70
+ old_connection = ActiveRecord::Base.connection
71
+ extra_connection = ActiveRecord::Base.connection_pool.checkout
72
+ ActiveRecord::Base.connection_pool.remove(extra_connection)
73
+ assert_equal ActiveRecord::Base.connection, old_connection
74
+ end
75
+
76
+ private
77
+
78
+ def add_record(name)
79
+ ActiveRecord::Base.connection_pool.with_connection { Project.create! :name => name }
80
+ end
81
+ end unless in_memory_db?
@@ -1,237 +1,376 @@
1
- require "cases/helper"
2
- require 'models/topic'
3
- require 'models/reply'
4
- require 'models/subscriber'
5
- require 'models/movie'
6
- require 'models/keyboard'
7
- require 'models/mixed_case_monkey'
8
- require 'models/dashboard'
9
-
10
- class PrimaryKeysTest < ActiveRecord::TestCase
11
- fixtures :topics, :subscribers, :movies, :mixed_case_monkeys
12
-
13
- def test_to_key_with_default_primary_key
14
- topic = Topic.new
15
- assert_nil topic.to_key
16
- topic = Topic.find(1)
17
- assert_equal [1], topic.to_key
18
- end
19
-
20
- def test_to_key_with_customized_primary_key
21
- keyboard = Keyboard.new
22
- assert_nil keyboard.to_key
23
- keyboard.save
24
- assert_equal keyboard.to_key, [keyboard.id]
25
- end
26
-
27
- def test_read_attribute_with_custom_primary_key
28
- keyboard = Keyboard.create!
29
- assert_equal keyboard.key_number, keyboard.read_attribute(:id)
30
- end
31
-
32
- def test_to_key_with_primary_key_after_destroy
33
- topic = Topic.find(1)
34
- topic.destroy
35
- assert_equal [1], topic.to_key
36
- end
37
-
38
- def test_integer_key
39
- topic = Topic.find(1)
40
- assert_equal(topics(:first).author_name, topic.author_name)
41
- topic = Topic.find(2)
42
- assert_equal(topics(:second).author_name, topic.author_name)
43
-
44
- topic = Topic.new
45
- topic.title = "New Topic"
46
- assert_nil topic.id
47
- assert_nothing_raised { topic.save! }
48
- id = topic.id
49
-
50
- topicReloaded = Topic.find(id)
51
- assert_equal("New Topic", topicReloaded.title)
52
- end
53
-
54
- def test_customized_primary_key_auto_assigns_on_save
55
- Keyboard.delete_all
56
- keyboard = Keyboard.new(:name => 'HHKB')
57
- assert_nothing_raised { keyboard.save! }
58
- assert_equal keyboard.id, Keyboard.find_by_name('HHKB').id
59
- end
60
-
61
- def test_customized_primary_key_can_be_get_before_saving
62
- keyboard = Keyboard.new
63
- assert_nil keyboard.id
64
- assert_nothing_raised { assert_nil keyboard.key_number }
65
- end
66
-
67
- def test_customized_string_primary_key_settable_before_save
68
- subscriber = Subscriber.new
69
- assert_nothing_raised { subscriber.id = 'webster123' }
70
- assert_equal 'webster123', subscriber.id
71
- assert_equal 'webster123', subscriber.nick
72
- end
73
-
74
- def test_string_key
75
- subscriber = Subscriber.find(subscribers(:first).nick)
76
- assert_equal(subscribers(:first).name, subscriber.name)
77
- subscriber = Subscriber.find(subscribers(:second).nick)
78
- assert_equal(subscribers(:second).name, subscriber.name)
79
-
80
- subscriber = Subscriber.new
81
- subscriber.id = "jdoe"
82
- assert_equal("jdoe", subscriber.id)
83
- subscriber.name = "John Doe"
84
- assert_nothing_raised { subscriber.save! }
85
- assert_equal("jdoe", subscriber.id)
86
-
87
- subscriberReloaded = Subscriber.find("jdoe")
88
- assert_equal("John Doe", subscriberReloaded.name)
89
- end
90
-
91
- def test_find_with_more_than_one_string_key
92
- assert_equal 2, Subscriber.find(subscribers(:first).nick, subscribers(:second).nick).length
93
- end
94
-
95
- def test_primary_key_prefix
96
- old_primary_key_prefix_type = ActiveRecord::Base.primary_key_prefix_type
97
- ActiveRecord::Base.primary_key_prefix_type = :table_name
98
- Topic.reset_primary_key
99
- assert_equal "topicid", Topic.primary_key
100
-
101
- ActiveRecord::Base.primary_key_prefix_type = :table_name_with_underscore
102
- Topic.reset_primary_key
103
- assert_equal "topic_id", Topic.primary_key
104
-
105
- ActiveRecord::Base.primary_key_prefix_type = nil
106
- Topic.reset_primary_key
107
- assert_equal "id", Topic.primary_key
108
- ensure
109
- ActiveRecord::Base.primary_key_prefix_type = old_primary_key_prefix_type
110
- end
111
-
112
- def test_delete_should_quote_pkey
113
- assert_nothing_raised { MixedCaseMonkey.delete(1) }
114
- end
115
- def test_update_counters_should_quote_pkey_and_quote_counter_columns
116
- assert_nothing_raised { MixedCaseMonkey.update_counters(1, :fleacount => 99) }
117
- end
118
- def test_find_with_one_id_should_quote_pkey
119
- assert_nothing_raised { MixedCaseMonkey.find(1) }
120
- end
121
- def test_find_with_multiple_ids_should_quote_pkey
122
- assert_nothing_raised { MixedCaseMonkey.find([1,2]) }
123
- end
124
- def test_instance_update_should_quote_pkey
125
- assert_nothing_raised { MixedCaseMonkey.find(1).save }
126
- end
127
- def test_instance_destroy_should_quote_pkey
128
- assert_nothing_raised { MixedCaseMonkey.find(1).destroy }
129
- end
130
-
131
- def test_supports_primary_key
132
- assert_nothing_raised NoMethodError do
133
- ActiveRecord::Base.connection.supports_primary_key?
134
- end
135
- end
136
-
137
- def test_primary_key_returns_value_if_it_exists
138
- klass = Class.new(ActiveRecord::Base) do
139
- self.table_name = 'developers'
140
- end
141
-
142
- if ActiveRecord::Base.connection.supports_primary_key?
143
- assert_equal 'id', klass.primary_key
144
- end
145
- end
146
-
147
- def test_primary_key_returns_nil_if_it_does_not_exist
148
- klass = Class.new(ActiveRecord::Base) do
149
- self.table_name = 'developers_projects'
150
- end
151
-
152
- if ActiveRecord::Base.connection.supports_primary_key?
153
- assert_nil klass.primary_key
154
- end
155
- end
156
-
157
- def test_quoted_primary_key_after_set_primary_key
158
- k = Class.new( ActiveRecord::Base )
159
- assert_equal k.connection.quote_column_name("id"), k.quoted_primary_key
160
- k.primary_key = "foo"
161
- assert_equal k.connection.quote_column_name("foo"), k.quoted_primary_key
162
- end
163
-
164
- def test_auto_detect_primary_key_from_schema
165
- MixedCaseMonkey.reset_primary_key
166
- #assert_equal "monkeyID", MixedCaseMonkey.primary_key
167
- assert_equal "monkeyid", MixedCaseMonkey.primary_key
168
- end
169
-
170
- def test_primary_key_update_with_custom_key_name
171
- dashboard = Dashboard.create!(dashboard_id: '1')
172
- dashboard.id = '2'
173
- dashboard.save!
174
-
175
- dashboard = Dashboard.first
176
- assert_equal '2', dashboard.id
177
- end
178
- end
179
-
180
- class PrimaryKeyWithNoConnectionTest < ActiveRecord::TestCase
181
- self.use_transactional_fixtures = false
182
-
183
- unless in_memory_db?
184
- def test_set_primary_key_with_no_connection
185
- connection = ActiveRecord::Base.remove_connection
186
-
187
- model = Class.new(ActiveRecord::Base)
188
- model.primary_key = 'foo'
189
-
190
- assert_equal 'foo', model.primary_key
191
-
192
- ActiveRecord::Base.establish_connection(connection)
193
-
194
- assert_equal 'foo', model.primary_key
195
- end
196
- end
197
- end
198
-
199
- if current_adapter?(:MysqlAdapter, :Mysql2Adapter)
200
- class PrimaryKeyWithAnsiQuotesTest < ActiveRecord::TestCase
201
- self.use_transactional_fixtures = false
202
-
203
- def test_primary_key_method_with_ansi_quotes
204
- con = ActiveRecord::Base.connection
205
- con.execute("SET SESSION sql_mode='ANSI_QUOTES'")
206
- assert_equal "id", con.primary_key("topics")
207
- ensure
208
- con.reconnect!
209
- end
210
- end
211
- end
212
-
213
- if current_adapter?(:PostgreSQLAdapter)
214
- class PrimaryKeyBigSerialTest < ActiveRecord::TestCase
215
- self.use_transactional_fixtures = false
216
-
217
- class Widget < ActiveRecord::Base
218
- end
219
-
220
- setup do
221
- @connection = ActiveRecord::Base.connection
222
- @connection.create_table(:widgets, id: :bigserial) { |t| }
223
- end
224
-
225
- teardown do
226
- @connection.drop_table :widgets
227
- end
228
-
229
- def test_bigserial_primary_key
230
- assert_equal "id", Widget.primary_key
231
- assert_equal :integer, Widget.columns_hash[Widget.primary_key].type
232
-
233
- widget = Widget.create!
234
- assert_not_nil widget.id
235
- end
236
- end
237
- end
1
+ require "cases/helper"
2
+ require 'support/schema_dumping_helper'
3
+ require 'models/topic'
4
+ require 'models/reply'
5
+ require 'models/subscriber'
6
+ require 'models/movie'
7
+ require 'models/keyboard'
8
+ require 'models/mixed_case_monkey'
9
+ require 'models/dashboard'
10
+ require 'models/non_primary_key'
11
+
12
+ class PrimaryKeysTest < ActiveRecord::TestCase
13
+ fixtures :topics, :subscribers, :movies, :mixed_case_monkeys
14
+
15
+ def test_to_key_with_default_primary_key
16
+ topic = Topic.new
17
+ assert_nil topic.to_key
18
+ topic = Topic.find(1)
19
+ assert_equal [1], topic.to_key
20
+ end
21
+
22
+ def test_to_key_with_customized_primary_key
23
+ keyboard = Keyboard.new
24
+ assert_nil keyboard.to_key
25
+ keyboard.save
26
+ assert_equal keyboard.to_key, [keyboard.id]
27
+ end
28
+
29
+ def test_read_attribute_with_custom_primary_key
30
+ keyboard = Keyboard.create!
31
+ assert_equal keyboard.key_number, keyboard.read_attribute(:id)
32
+ end
33
+
34
+ def test_to_key_with_primary_key_after_destroy
35
+ topic = Topic.find(1)
36
+ topic.destroy
37
+ assert_equal [1], topic.to_key
38
+ end
39
+
40
+ def test_integer_key
41
+ topic = Topic.find(1)
42
+ assert_equal(topics(:first).author_name, topic.author_name)
43
+ topic = Topic.find(2)
44
+ assert_equal(topics(:second).author_name, topic.author_name)
45
+
46
+ topic = Topic.new
47
+ topic.title = "New Topic"
48
+ assert_nil topic.id
49
+ assert_nothing_raised { topic.save! }
50
+ id = topic.id
51
+
52
+ topicReloaded = Topic.find(id)
53
+ assert_equal("New Topic", topicReloaded.title)
54
+ end
55
+
56
+ def test_customized_primary_key_auto_assigns_on_save
57
+ Keyboard.delete_all
58
+ keyboard = Keyboard.new(:name => 'HHKB')
59
+ assert_nothing_raised { keyboard.save! }
60
+ assert_equal keyboard.id, Keyboard.find_by_name('HHKB').id
61
+ end
62
+
63
+ def test_customized_primary_key_can_be_get_before_saving
64
+ keyboard = Keyboard.new
65
+ assert_nil keyboard.id
66
+ assert_nothing_raised { assert_nil keyboard.key_number }
67
+ end
68
+
69
+ def test_customized_string_primary_key_settable_before_save
70
+ subscriber = Subscriber.new
71
+ assert_nothing_raised { subscriber.id = 'webster123' }
72
+ assert_equal 'webster123', subscriber.id
73
+ assert_equal 'webster123', subscriber.nick
74
+ end
75
+
76
+ def test_string_key
77
+ subscriber = Subscriber.find(subscribers(:first).nick)
78
+ assert_equal(subscribers(:first).name, subscriber.name)
79
+ subscriber = Subscriber.find(subscribers(:second).nick)
80
+ assert_equal(subscribers(:second).name, subscriber.name)
81
+
82
+ subscriber = Subscriber.new
83
+ subscriber.id = "jdoe"
84
+ assert_equal("jdoe", subscriber.id)
85
+ subscriber.name = "John Doe"
86
+ assert_nothing_raised { subscriber.save! }
87
+ assert_equal("jdoe", subscriber.id)
88
+
89
+ subscriberReloaded = Subscriber.find("jdoe")
90
+ assert_equal("John Doe", subscriberReloaded.name)
91
+ end
92
+
93
+ def test_id_column_that_is_not_primary_key
94
+ NonPrimaryKey.create!(id: 100)
95
+ actual = NonPrimaryKey.find_by(id: 100)
96
+ assert_match %r{<NonPrimaryKey id: 100}, actual.inspect
97
+ end
98
+
99
+ def test_find_with_more_than_one_string_key
100
+ assert_equal 2, Subscriber.find(subscribers(:first).nick, subscribers(:second).nick).length
101
+ end
102
+
103
+ def test_primary_key_prefix
104
+ old_primary_key_prefix_type = ActiveRecord::Base.primary_key_prefix_type
105
+ ActiveRecord::Base.primary_key_prefix_type = :table_name
106
+ Topic.reset_primary_key
107
+ assert_equal "topicid", Topic.primary_key
108
+
109
+ ActiveRecord::Base.primary_key_prefix_type = :table_name_with_underscore
110
+ Topic.reset_primary_key
111
+ assert_equal "topic_id", Topic.primary_key
112
+
113
+ ActiveRecord::Base.primary_key_prefix_type = nil
114
+ Topic.reset_primary_key
115
+ assert_equal "id", Topic.primary_key
116
+ ensure
117
+ ActiveRecord::Base.primary_key_prefix_type = old_primary_key_prefix_type
118
+ end
119
+
120
+ def test_delete_should_quote_pkey
121
+ assert_nothing_raised { MixedCaseMonkey.delete(1) }
122
+ end
123
+ def test_update_counters_should_quote_pkey_and_quote_counter_columns
124
+ assert_nothing_raised { MixedCaseMonkey.update_counters(1, :fleaCount => 99) }
125
+ end
126
+ def test_find_with_one_id_should_quote_pkey
127
+ assert_nothing_raised { MixedCaseMonkey.find(1) }
128
+ end
129
+ def test_find_with_multiple_ids_should_quote_pkey
130
+ assert_nothing_raised { MixedCaseMonkey.find([1,2]) }
131
+ end
132
+ def test_instance_update_should_quote_pkey
133
+ assert_nothing_raised { MixedCaseMonkey.find(1).save }
134
+ end
135
+ def test_instance_destroy_should_quote_pkey
136
+ assert_nothing_raised { MixedCaseMonkey.find(1).destroy }
137
+ end
138
+
139
+ def test_supports_primary_key
140
+ assert_nothing_raised do
141
+ ActiveRecord::Base.connection.supports_primary_key?
142
+ end
143
+ end
144
+
145
+ if ActiveRecord::Base.connection.supports_primary_key?
146
+ def test_primary_key_returns_value_if_it_exists
147
+ klass = Class.new(ActiveRecord::Base) do
148
+ self.table_name = 'developers'
149
+ end
150
+
151
+ assert_equal 'id', klass.primary_key
152
+ end
153
+
154
+ def test_primary_key_returns_nil_if_it_does_not_exist
155
+ klass = Class.new(ActiveRecord::Base) do
156
+ self.table_name = 'developers_projects'
157
+ end
158
+
159
+ assert_nil klass.primary_key
160
+ end
161
+ end
162
+
163
+ def test_quoted_primary_key_after_set_primary_key
164
+ k = Class.new( ActiveRecord::Base )
165
+ assert_equal k.connection.quote_column_name("id"), k.quoted_primary_key
166
+ k.primary_key = "foo"
167
+ assert_equal k.connection.quote_column_name("foo"), k.quoted_primary_key
168
+ end
169
+
170
+ def test_auto_detect_primary_key_from_schema
171
+ MixedCaseMonkey.reset_primary_key
172
+ assert_equal "monkeyID", MixedCaseMonkey.primary_key
173
+ end
174
+
175
+ def test_primary_key_update_with_custom_key_name
176
+ dashboard = Dashboard.create!(dashboard_id: '1')
177
+ dashboard.id = '2'
178
+ dashboard.save!
179
+
180
+ dashboard = Dashboard.first
181
+ assert_equal '2', dashboard.id
182
+ end
183
+
184
+ if current_adapter?(:PostgreSQLAdapter)
185
+ def test_serial_with_quoted_sequence_name
186
+ column = MixedCaseMonkey.columns_hash[MixedCaseMonkey.primary_key]
187
+ assert_equal "nextval('\"mixed_case_monkeys_monkeyID_seq\"'::regclass)", column.default_function
188
+ assert column.serial?
189
+ end
190
+
191
+ def test_serial_with_unquoted_sequence_name
192
+ column = Topic.columns_hash[Topic.primary_key]
193
+ assert_equal "nextval('topics_id_seq'::regclass)", column.default_function
194
+ assert column.serial?
195
+ end
196
+ end
197
+ end
198
+
199
+ class PrimaryKeyWithNoConnectionTest < ActiveRecord::TestCase
200
+ self.use_transactional_tests = false
201
+
202
+ unless in_memory_db?
203
+ def test_set_primary_key_with_no_connection
204
+ connection = ActiveRecord::Base.remove_connection
205
+
206
+ model = Class.new(ActiveRecord::Base)
207
+ model.primary_key = 'foo'
208
+
209
+ assert_equal 'foo', model.primary_key
210
+
211
+ ActiveRecord::Base.establish_connection(connection)
212
+
213
+ assert_equal 'foo', model.primary_key
214
+ end
215
+ end
216
+ end
217
+
218
+ class PrimaryKeyAnyTypeTest < ActiveRecord::TestCase
219
+ include SchemaDumpingHelper
220
+
221
+ self.use_transactional_tests = false
222
+
223
+ class Barcode < ActiveRecord::Base
224
+ end
225
+
226
+ setup do
227
+ @connection = ActiveRecord::Base.connection
228
+ @connection.create_table(:barcodes, primary_key: "code", id: :string, limit: 42, force: true)
229
+ end
230
+
231
+ teardown do
232
+ @connection.drop_table(:barcodes)
233
+ #, if_exists: true)
234
+ end
235
+
236
+ def test_any_type_primary_key
237
+ assert_equal "code", Barcode.primary_key
238
+
239
+ column = Barcode.column_for_attribute(Barcode.primary_key)
240
+ assert_not column.null
241
+ assert_equal :string, column.type
242
+ assert_equal 42, column.limit
243
+ end
244
+
245
+ test "schema dump primary key includes type and options" do
246
+ schema = dump_table_schema "barcodes"
247
+ assert_match %r{create_table "barcodes", primary_key: "code", id: :string, limit: 42}, schema
248
+ end
249
+ end
250
+
251
+ class CompositePrimaryKeyTest < ActiveRecord::TestCase
252
+ include SchemaDumpingHelper
253
+
254
+ self.use_transactional_tests = false
255
+
256
+ def setup
257
+ @connection = ActiveRecord::Base.connection
258
+ @connection.schema_cache.clear!
259
+ @connection.create_table(:barcodes, primary_key: ["region", "code"], force: true) do |t|
260
+ t.string :region, null: false
261
+ t.integer :code, null: false
262
+ end
263
+ end
264
+
265
+ def teardown
266
+ @connection.drop_table(:barcodes)
267
+ #, if_exists: true)
268
+ end
269
+
270
+ def test_composite_primary_key
271
+ assert_equal ["region", "code"], @connection.primary_keys("barcodes")
272
+ end
273
+
274
+ def test_primary_key_issues_warning
275
+ model = Class.new(ActiveRecord::Base) do
276
+ def self.table_name
277
+ "barcodes"
278
+ end
279
+ end
280
+ warning = capture(:stderr) do
281
+ assert_nil model.primary_key
282
+ end
283
+ assert_match(/WARNING: Active Record does not support composite primary key\./, warning)
284
+ end
285
+
286
+ def test_collectly_dump_composite_primary_key
287
+ schema = dump_table_schema "barcodes"
288
+ assert_match %r{create_table "barcodes", primary_key: \["region", "code"\]}, schema
289
+ end
290
+ end
291
+
292
+ if current_adapter?(:Mysql2Adapter)
293
+ class PrimaryKeyBigintNilDefaultTest < ActiveRecord::TestCase
294
+ include SchemaDumpingHelper
295
+
296
+ self.use_transactional_tests = false
297
+
298
+ def setup
299
+ @connection = ActiveRecord::Base.connection
300
+ @connection.create_table(:bigint_defaults, id: :bigint, default: nil, force: true)
301
+ end
302
+
303
+ def teardown
304
+ @connection.drop_table :bigint_defaults
305
+ #, if_exists: true
306
+ end
307
+
308
+ test "primary key with bigint allows default override via nil" do
309
+ column = @connection.columns(:bigint_defaults).find { |c| c.name == 'id' }
310
+ assert column.bigint?
311
+ assert_not column.auto_increment?
312
+ end
313
+
314
+ test "schema dump primary key with bigint default nil" do
315
+ schema = dump_table_schema "bigint_defaults"
316
+ assert_match %r{create_table "bigint_defaults", id: :bigint, default: nil}, schema
317
+ end
318
+ end
319
+ end
320
+
321
+ if current_adapter?(:PostgreSQLAdapter, :Mysql2Adapter)
322
+ class PrimaryKeyBigSerialTest < ActiveRecord::TestCase
323
+ include SchemaDumpingHelper
324
+
325
+ self.use_transactional_tests = false
326
+
327
+ class Widget < ActiveRecord::Base
328
+ end
329
+
330
+ setup do
331
+ @connection = ActiveRecord::Base.connection
332
+ if current_adapter?(:PostgreSQLAdapter)
333
+ @connection.create_table(:widgets, id: :bigserial, force: true)
334
+ else
335
+ @connection.create_table(:widgets, id: :bigint, force: true)
336
+ end
337
+ end
338
+
339
+ teardown do
340
+ @connection.drop_table :widgets
341
+ #, if_exists: true
342
+ Widget.reset_column_information
343
+ end
344
+
345
+ test "primary key column type with bigserial" do
346
+ column_type = Widget.type_for_attribute(Widget.primary_key)
347
+ assert_equal :integer, column_type.type
348
+ assert_equal 8, column_type.limit
349
+ end
350
+
351
+ test "primary key with bigserial are automatically numbered" do
352
+ widget = Widget.create!
353
+ assert_not_nil widget.id
354
+ end
355
+
356
+ test "schema dump primary key with bigserial" do
357
+ schema = dump_table_schema "widgets"
358
+ if current_adapter?(:PostgreSQLAdapter)
359
+ assert_match %r{create_table "widgets", id: :bigserial, force: :cascade}, schema
360
+ else
361
+ assert_match %r{create_table "widgets", id: :bigint, force: :cascade}, schema
362
+ end
363
+ end
364
+
365
+ if current_adapter?(:Mysql2Adapter)
366
+ test "primary key column type with options" do
367
+ @connection.create_table(:widgets, id: :primary_key, limit: 8, unsigned: true, force: true)
368
+ column = @connection.columns(:widgets).find { |c| c.name == 'id' }
369
+ assert column.auto_increment?
370
+ assert_equal :integer, column.type
371
+ assert_equal 8, column.limit
372
+ assert column.unsigned?
373
+ end
374
+ end
375
+ end
376
+ end