ibm_db 3.0.4-x86-mingw32 → 5.0.4-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 (593) hide show
  1. checksums.yaml +5 -5
  2. data/CHANGES +8 -1
  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 +269 -0
  8. data/ext/Makefile.nt32 +181 -181
  9. data/ext/Makefile.nt32.191 +212 -212
  10. data/ext/extconf.rb +322 -291
  11. data/ext/gil_release_version +3 -0
  12. data/ext/ibm_db-i386-mingw32.def +2 -0
  13. data/ext/ibm_db.c +11879 -11884
  14. data/ext/ibm_db.o +0 -0
  15. data/ext/ibm_db.so +0 -0
  16. data/ext/mkmf.log +110 -0
  17. data/ext/ruby_ibm_db.h +241 -241
  18. data/ext/ruby_ibm_db_cli.c +866 -866
  19. data/ext/ruby_ibm_db_cli.h +500 -500
  20. data/ext/ruby_ibm_db_cli.o +0 -0
  21. data/ext/unicode_support_version +3 -0
  22. data/init.rb +41 -41
  23. data/lib/IBM_DB.rb +27 -27
  24. data/lib/active_record/connection_adapters/ibm_db_adapter.rb +3561 -3177
  25. data/lib/active_record/connection_adapters/ibmdb_adapter.rb +5 -2
  26. data/lib/active_record/vendor/db2-i5-zOS.yaml +328 -328
  27. data/lib/mswin32/ibm_db.rb +91 -123
  28. data/lib/mswin32/rb2x/i386/ibm_db.so +0 -0
  29. data/test/active_record/connection_adapters/fake_adapter.rb +49 -46
  30. data/test/assets/example.log +1 -1
  31. data/test/assets/test.txt +1 -1
  32. data/test/cases/adapter_test.rb +351 -261
  33. data/test/cases/adapters/mysql2/active_schema_test.rb +193 -0
  34. data/test/cases/adapters/mysql2/bind_parameter_test.rb +50 -0
  35. data/test/cases/adapters/mysql2/boolean_test.rb +100 -0
  36. data/test/cases/adapters/mysql2/case_sensitivity_test.rb +63 -0
  37. data/test/cases/adapters/mysql2/charset_collation_test.rb +54 -0
  38. data/test/cases/adapters/mysql2/connection_test.rb +210 -0
  39. data/test/cases/adapters/mysql2/datetime_precision_quoting_test.rb +45 -0
  40. data/test/cases/adapters/mysql2/enum_test.rb +26 -0
  41. data/test/cases/adapters/mysql2/explain_test.rb +21 -0
  42. data/test/cases/adapters/mysql2/json_test.rb +195 -0
  43. data/test/cases/adapters/mysql2/mysql2_adapter_test.rb +83 -0
  44. data/test/cases/adapters/mysql2/reserved_word_test.rb +152 -0
  45. data/test/cases/adapters/mysql2/schema_migrations_test.rb +59 -0
  46. data/test/cases/adapters/mysql2/schema_test.rb +126 -0
  47. data/test/cases/adapters/mysql2/sp_test.rb +36 -0
  48. data/test/cases/adapters/mysql2/sql_types_test.rb +14 -0
  49. data/test/cases/adapters/mysql2/table_options_test.rb +42 -0
  50. data/test/cases/adapters/mysql2/unsigned_type_test.rb +66 -0
  51. data/test/cases/adapters/postgresql/active_schema_test.rb +98 -0
  52. data/test/cases/adapters/postgresql/array_test.rb +339 -0
  53. data/test/cases/adapters/postgresql/bit_string_test.rb +82 -0
  54. data/test/cases/adapters/postgresql/bytea_test.rb +134 -0
  55. data/test/cases/adapters/postgresql/case_insensitive_test.rb +26 -0
  56. data/test/cases/adapters/postgresql/change_schema_test.rb +38 -0
  57. data/test/cases/adapters/postgresql/cidr_test.rb +25 -0
  58. data/test/cases/adapters/postgresql/citext_test.rb +78 -0
  59. data/test/cases/adapters/postgresql/collation_test.rb +53 -0
  60. data/test/cases/adapters/postgresql/composite_test.rb +132 -0
  61. data/test/cases/adapters/postgresql/connection_test.rb +257 -0
  62. data/test/cases/adapters/postgresql/datatype_test.rb +92 -0
  63. data/test/cases/adapters/postgresql/domain_test.rb +47 -0
  64. data/test/cases/adapters/postgresql/enum_test.rb +91 -0
  65. data/test/cases/adapters/postgresql/explain_test.rb +20 -0
  66. data/test/cases/adapters/postgresql/extension_migration_test.rb +63 -0
  67. data/test/cases/adapters/postgresql/full_text_test.rb +44 -0
  68. data/test/cases/adapters/postgresql/geometric_test.rb +378 -0
  69. data/test/cases/adapters/postgresql/hstore_test.rb +382 -0
  70. data/test/cases/adapters/postgresql/infinity_test.rb +69 -0
  71. data/test/cases/adapters/postgresql/integer_test.rb +25 -0
  72. data/test/cases/adapters/postgresql/json_test.rb +237 -0
  73. data/test/cases/adapters/postgresql/ltree_test.rb +53 -0
  74. data/test/cases/adapters/postgresql/money_test.rb +96 -0
  75. data/test/cases/adapters/postgresql/network_test.rb +94 -0
  76. data/test/cases/adapters/postgresql/numbers_test.rb +49 -0
  77. data/test/cases/adapters/postgresql/postgresql_adapter_test.rb +405 -0
  78. data/test/cases/adapters/postgresql/prepared_statements_test.rb +22 -0
  79. data/test/cases/adapters/postgresql/quoting_test.rb +44 -0
  80. data/test/cases/adapters/postgresql/range_test.rb +343 -0
  81. data/test/cases/adapters/postgresql/referential_integrity_test.rb +111 -0
  82. data/test/cases/adapters/postgresql/rename_table_test.rb +34 -0
  83. data/test/cases/adapters/postgresql/schema_authorization_test.rb +119 -0
  84. data/test/cases/adapters/postgresql/schema_test.rb +597 -0
  85. data/test/cases/adapters/postgresql/serial_test.rb +154 -0
  86. data/test/cases/adapters/postgresql/statement_pool_test.rb +41 -0
  87. data/test/cases/adapters/postgresql/timestamp_test.rb +90 -0
  88. data/test/cases/adapters/postgresql/type_lookup_test.rb +33 -0
  89. data/test/cases/adapters/postgresql/utils_test.rb +62 -0
  90. data/test/cases/adapters/postgresql/uuid_test.rb +294 -0
  91. data/test/cases/adapters/postgresql/xml_test.rb +54 -0
  92. data/test/cases/adapters/sqlite3/collation_test.rb +53 -0
  93. data/test/cases/adapters/sqlite3/copy_table_test.rb +98 -0
  94. data/test/cases/adapters/sqlite3/explain_test.rb +21 -0
  95. data/test/cases/adapters/sqlite3/quoting_test.rb +101 -0
  96. data/test/cases/adapters/sqlite3/sqlite3_adapter_test.rb +441 -0
  97. data/test/cases/adapters/sqlite3/sqlite3_create_folder_test.rb +24 -0
  98. data/test/cases/adapters/sqlite3/statement_pool_test.rb +20 -0
  99. data/test/cases/aggregations_test.rb +168 -158
  100. data/test/cases/ar_schema_test.rb +146 -161
  101. data/test/cases/associations/association_scope_test.rb +16 -21
  102. data/test/cases/associations/belongs_to_associations_test.rb +1141 -1029
  103. data/test/cases/associations/bidirectional_destroy_dependencies_test.rb +41 -0
  104. data/test/cases/associations/callbacks_test.rb +190 -192
  105. data/test/cases/associations/cascaded_eager_loading_test.rb +188 -188
  106. data/test/cases/associations/eager_load_includes_full_sti_class_test.rb +36 -36
  107. data/test/cases/associations/eager_load_nested_include_test.rb +126 -128
  108. data/test/cases/associations/eager_singularization_test.rb +148 -148
  109. data/test/cases/associations/eager_test.rb +1514 -1411
  110. data/test/cases/associations/extension_test.rb +87 -82
  111. data/test/cases/associations/has_and_belongs_to_many_associations_test.rb +1004 -932
  112. data/test/cases/associations/has_many_associations_test.rb +2501 -2162
  113. data/test/cases/associations/has_many_through_associations_test.rb +1271 -1204
  114. data/test/cases/associations/has_one_associations_test.rb +707 -610
  115. data/test/cases/associations/has_one_through_associations_test.rb +383 -380
  116. data/test/cases/associations/inner_join_association_test.rb +139 -139
  117. data/test/cases/associations/inverse_associations_test.rb +733 -693
  118. data/test/cases/associations/join_model_test.rb +777 -754
  119. data/test/cases/associations/left_outer_join_association_test.rb +88 -0
  120. data/test/cases/associations/nested_through_associations_test.rb +579 -579
  121. data/test/cases/associations/required_test.rb +102 -82
  122. data/test/cases/associations_test.rb +385 -380
  123. data/test/cases/attribute_decorators_test.rb +126 -125
  124. data/test/cases/attribute_methods/read_test.rb +60 -60
  125. data/test/cases/attribute_methods_test.rb +1009 -952
  126. data/test/cases/attribute_set_test.rb +270 -200
  127. data/test/cases/attribute_test.rb +246 -180
  128. data/test/cases/attributes_test.rb +253 -136
  129. data/test/cases/autosave_association_test.rb +1708 -1595
  130. data/test/cases/base_test.rb +1713 -1638
  131. data/test/cases/batches_test.rb +489 -212
  132. data/test/cases/binary_test.rb +44 -52
  133. data/test/cases/bind_parameter_test.rb +110 -100
  134. data/test/cases/cache_key_test.rb +26 -0
  135. data/test/cases/calculations_test.rb +798 -646
  136. data/test/cases/callbacks_test.rb +636 -543
  137. data/test/cases/clone_test.rb +40 -40
  138. data/test/cases/coders/json_test.rb +15 -0
  139. data/test/cases/coders/yaml_column_test.rb +63 -63
  140. data/test/cases/collection_cache_key_test.rb +115 -0
  141. data/test/cases/column_alias_test.rb +17 -17
  142. data/test/cases/column_definition_test.rb +92 -123
  143. data/test/cases/comment_test.rb +145 -0
  144. data/test/cases/connection_adapters/adapter_leasing_test.rb +56 -54
  145. data/test/cases/connection_adapters/connection_handler_test.rb +160 -53
  146. data/test/cases/connection_adapters/connection_specification_test.rb +12 -12
  147. data/test/cases/connection_adapters/merge_and_resolve_default_url_config_test.rb +255 -293
  148. data/test/cases/connection_adapters/mysql_type_lookup_test.rb +69 -65
  149. data/test/cases/connection_adapters/quoting_test.rb +13 -13
  150. data/test/cases/connection_adapters/schema_cache_test.rb +61 -56
  151. data/test/cases/connection_adapters/type_lookup_test.rb +118 -110
  152. data/test/cases/connection_management_test.rb +112 -122
  153. data/test/cases/connection_pool_test.rb +521 -346
  154. data/test/cases/connection_specification/resolver_test.rb +131 -116
  155. data/test/cases/core_test.rb +112 -112
  156. data/test/cases/counter_cache_test.rb +214 -209
  157. data/test/cases/custom_locking_test.rb +17 -17
  158. data/test/cases/database_statements_test.rb +34 -19
  159. data/test/cases/{invalid_date_test.rb → date_test.rb} +44 -32
  160. data/test/cases/date_time_precision_test.rb +107 -0
  161. data/test/cases/date_time_test.rb +61 -61
  162. data/test/cases/defaults_test.rb +219 -223
  163. data/test/cases/dirty_test.rb +763 -775
  164. data/test/cases/disconnected_test.rb +30 -28
  165. data/test/cases/dup_test.rb +157 -157
  166. data/test/cases/enum_test.rb +444 -290
  167. data/test/cases/errors_test.rb +16 -0
  168. data/test/cases/explain_subscriber_test.rb +64 -64
  169. data/test/cases/explain_test.rb +87 -76
  170. data/test/cases/finder_respond_to_test.rb +60 -60
  171. data/test/cases/finder_test.rb +1294 -1166
  172. data/test/cases/fixture_set/file_test.rb +156 -138
  173. data/test/cases/fixtures_test.rb +988 -897
  174. data/test/cases/forbidden_attributes_protection_test.rb +165 -99
  175. data/test/cases/habtm_destroy_order_test.rb +61 -61
  176. data/test/cases/helper.rb +204 -210
  177. data/test/cases/hot_compatibility_test.rb +142 -54
  178. data/test/cases/i18n_test.rb +45 -45
  179. data/test/cases/inheritance_test.rb +606 -375
  180. data/test/cases/integration_test.rb +155 -139
  181. data/test/cases/invalid_connection_test.rb +24 -22
  182. data/test/cases/invertible_migration_test.rb +387 -295
  183. data/test/cases/json_serialization_test.rb +311 -302
  184. data/test/cases/locking_test.rb +493 -477
  185. data/test/cases/log_subscriber_test.rb +225 -136
  186. data/test/cases/migration/change_schema_test.rb +458 -472
  187. data/test/cases/migration/change_table_test.rb +256 -224
  188. data/test/cases/migration/column_attributes_test.rb +176 -192
  189. data/test/cases/migration/column_positioning_test.rb +56 -56
  190. data/test/cases/migration/columns_test.rb +310 -304
  191. data/test/cases/migration/command_recorder_test.rb +350 -305
  192. data/test/cases/migration/compatibility_test.rb +118 -0
  193. data/test/cases/migration/create_join_table_test.rb +157 -148
  194. data/test/cases/migration/foreign_key_test.rb +362 -360
  195. data/test/cases/migration/helper.rb +39 -39
  196. data/test/cases/migration/index_test.rb +218 -216
  197. data/test/cases/migration/logger_test.rb +36 -36
  198. data/test/cases/migration/pending_migrations_test.rb +52 -53
  199. data/test/cases/migration/references_foreign_key_test.rb +221 -214
  200. data/test/cases/migration/references_index_test.rb +101 -101
  201. data/test/cases/migration/references_statements_test.rb +136 -116
  202. data/test/cases/migration/rename_table_test.rb +93 -93
  203. data/test/cases/migration_test.rb +1157 -959
  204. data/test/cases/migrator_test.rb +471 -388
  205. data/test/cases/mixin_test.rb +68 -70
  206. data/test/cases/modules_test.rb +172 -173
  207. data/test/cases/multiparameter_attributes_test.rb +372 -350
  208. data/test/cases/multiple_db_test.rb +122 -115
  209. data/test/cases/nested_attributes_test.rb +1098 -1057
  210. data/test/cases/nested_attributes_with_callbacks_test.rb +144 -144
  211. data/test/cases/persistence_test.rb +1001 -909
  212. data/test/cases/pooled_connections_test.rb +81 -81
  213. data/test/cases/primary_keys_test.rb +376 -237
  214. data/test/cases/query_cache_test.rb +446 -326
  215. data/test/cases/quoting_test.rb +202 -156
  216. data/test/cases/readonly_test.rb +119 -118
  217. data/test/cases/reaper_test.rb +85 -85
  218. data/test/cases/reflection_test.rb +509 -454
  219. data/test/cases/relation/delegation_test.rb +63 -68
  220. data/test/cases/relation/merging_test.rb +157 -161
  221. data/test/cases/relation/mutation_test.rb +183 -165
  222. data/test/cases/relation/or_test.rb +92 -0
  223. data/test/cases/relation/predicate_builder_test.rb +16 -14
  224. data/test/cases/relation/record_fetch_warning_test.rb +40 -0
  225. data/test/cases/relation/where_chain_test.rb +105 -181
  226. data/test/cases/relation/where_clause_test.rb +182 -0
  227. data/test/cases/relation/where_test.rb +322 -300
  228. data/test/cases/relation_test.rb +328 -297
  229. data/test/cases/relations_test.rb +2026 -1815
  230. data/test/cases/reload_models_test.rb +22 -22
  231. data/test/cases/result_test.rb +90 -80
  232. data/test/cases/sanitize_test.rb +176 -83
  233. data/test/cases/schema_dumper_test.rb +457 -463
  234. data/test/cases/schema_loading_test.rb +52 -0
  235. data/test/cases/scoping/default_scoping_test.rb +528 -454
  236. data/test/cases/scoping/named_scoping_test.rb +561 -524
  237. data/test/cases/scoping/relation_scoping_test.rb +400 -357
  238. data/test/cases/secure_token_test.rb +32 -0
  239. data/test/cases/serialization_test.rb +104 -104
  240. data/test/cases/serialized_attribute_test.rb +364 -277
  241. data/test/cases/statement_cache_test.rb +136 -98
  242. data/test/cases/store_test.rb +195 -194
  243. data/test/cases/suppressor_test.rb +63 -0
  244. data/test/cases/tasks/database_tasks_test.rb +462 -396
  245. data/test/cases/tasks/mysql_rake_test.rb +345 -311
  246. data/test/cases/tasks/postgresql_rake_test.rb +304 -245
  247. data/test/cases/tasks/sqlite_rake_test.rb +220 -193
  248. data/test/cases/test_case.rb +131 -123
  249. data/test/cases/test_fixtures_test.rb +36 -0
  250. data/test/cases/time_precision_test.rb +103 -0
  251. data/test/cases/timestamp_test.rb +501 -468
  252. data/test/cases/touch_later_test.rb +121 -0
  253. data/test/cases/transaction_callbacks_test.rb +518 -452
  254. data/test/cases/transaction_isolation_test.rb +106 -106
  255. data/test/cases/transactions_test.rb +835 -817
  256. data/test/cases/type/adapter_specific_registry_test.rb +133 -0
  257. data/test/cases/type/date_time_test.rb +14 -0
  258. data/test/cases/type/integer_test.rb +27 -121
  259. data/test/cases/type/string_test.rb +22 -36
  260. data/test/cases/type/type_map_test.rb +177 -177
  261. data/test/cases/type_test.rb +39 -0
  262. data/test/cases/types_test.rb +24 -141
  263. data/test/cases/unconnected_test.rb +33 -33
  264. data/test/cases/validations/absence_validation_test.rb +73 -0
  265. data/test/cases/validations/association_validation_test.rb +97 -86
  266. data/test/cases/validations/i18n_generate_message_validation_test.rb +84 -84
  267. data/test/cases/validations/i18n_validation_test.rb +86 -90
  268. data/test/cases/validations/length_validation_test.rb +79 -47
  269. data/test/cases/validations/presence_validation_test.rb +103 -68
  270. data/test/cases/validations/uniqueness_validation_test.rb +548 -434
  271. data/test/cases/validations_repair_helper.rb +19 -23
  272. data/test/cases/validations_test.rb +194 -165
  273. data/test/cases/view_test.rb +216 -113
  274. data/test/cases/yaml_serialization_test.rb +121 -86
  275. data/test/config.example.yml +97 -0
  276. data/test/config.rb +5 -5
  277. data/test/config.yml +154 -154
  278. data/test/connections/native_ibm_db/connection.rb +43 -43
  279. data/test/fixtures/accounts.yml +29 -29
  280. data/test/fixtures/admin/accounts.yml +2 -2
  281. data/test/fixtures/admin/randomly_named_a9.yml +7 -7
  282. data/test/fixtures/admin/randomly_named_b0.yml +7 -7
  283. data/test/fixtures/admin/users.yml +10 -10
  284. data/test/fixtures/author_addresses.yml +17 -17
  285. data/test/fixtures/author_favorites.yml +3 -3
  286. data/test/fixtures/authors.yml +23 -23
  287. data/test/fixtures/bad_posts.yml +9 -0
  288. data/test/fixtures/binaries.yml +133 -133
  289. data/test/fixtures/books.yml +31 -11
  290. data/test/fixtures/bulbs.yml +5 -5
  291. data/test/fixtures/cars.yml +9 -9
  292. data/test/fixtures/categories.yml +19 -19
  293. data/test/fixtures/categories/special_categories.yml +9 -9
  294. data/test/fixtures/categories/subsubdir/arbitrary_filename.yml +4 -4
  295. data/test/fixtures/categories_ordered.yml +7 -7
  296. data/test/fixtures/categories_posts.yml +31 -31
  297. data/test/fixtures/categorizations.yml +23 -23
  298. data/test/fixtures/clubs.yml +8 -8
  299. data/test/fixtures/collections.yml +3 -3
  300. data/test/fixtures/colleges.yml +3 -3
  301. data/test/fixtures/comments.yml +65 -65
  302. data/test/fixtures/companies.yml +67 -67
  303. data/test/fixtures/computers.yml +10 -10
  304. data/test/fixtures/content.yml +3 -0
  305. data/test/fixtures/content_positions.yml +3 -0
  306. data/test/fixtures/courses.yml +8 -8
  307. data/test/fixtures/customers.yml +25 -25
  308. data/test/fixtures/dashboards.yml +6 -6
  309. data/test/fixtures/dead_parrots.yml +5 -0
  310. data/test/fixtures/developers.yml +21 -21
  311. data/test/fixtures/developers_projects.yml +16 -16
  312. data/test/fixtures/dog_lovers.yml +7 -7
  313. data/test/fixtures/dogs.yml +4 -4
  314. data/test/fixtures/doubloons.yml +3 -3
  315. data/test/fixtures/edges.yml +5 -5
  316. data/test/fixtures/entrants.yml +14 -14
  317. data/test/fixtures/essays.yml +6 -6
  318. data/test/fixtures/faces.yml +11 -11
  319. data/test/fixtures/fk_test_has_fk.yml +3 -3
  320. data/test/fixtures/fk_test_has_pk.yml +1 -1
  321. data/test/fixtures/friendships.yml +4 -4
  322. data/test/fixtures/funny_jokes.yml +10 -10
  323. data/test/fixtures/interests.yml +33 -33
  324. data/test/fixtures/items.yml +3 -3
  325. data/test/fixtures/jobs.yml +7 -7
  326. data/test/fixtures/legacy_things.yml +3 -3
  327. data/test/fixtures/live_parrots.yml +4 -0
  328. data/test/fixtures/mateys.yml +4 -4
  329. data/test/fixtures/member_details.yml +8 -8
  330. data/test/fixtures/member_types.yml +6 -6
  331. data/test/fixtures/members.yml +11 -11
  332. data/test/fixtures/memberships.yml +34 -34
  333. data/test/fixtures/men.yml +5 -5
  334. data/test/fixtures/minimalistics.yml +2 -2
  335. data/test/fixtures/minivans.yml +5 -5
  336. data/test/fixtures/mixed_case_monkeys.yml +6 -6
  337. data/test/fixtures/mixins.yml +29 -29
  338. data/test/fixtures/movies.yml +7 -7
  339. data/test/fixtures/naked/yml/accounts.yml +1 -1
  340. data/test/fixtures/naked/yml/companies.yml +1 -1
  341. data/test/fixtures/naked/yml/courses.yml +1 -1
  342. data/test/fixtures/naked/yml/parrots.yml +2 -0
  343. data/test/fixtures/naked/yml/trees.yml +3 -0
  344. data/test/fixtures/nodes.yml +29 -0
  345. data/test/fixtures/organizations.yml +5 -5
  346. data/test/fixtures/other_comments.yml +6 -0
  347. data/test/fixtures/other_dogs.yml +2 -0
  348. data/test/fixtures/other_posts.yml +7 -0
  349. data/test/fixtures/other_topics.yml +42 -42
  350. data/test/fixtures/owners.yml +9 -9
  351. data/test/fixtures/parrots.yml +27 -27
  352. data/test/fixtures/parrots_pirates.yml +7 -7
  353. data/test/fixtures/people.yml +24 -24
  354. data/test/fixtures/peoples_treasures.yml +3 -3
  355. data/test/fixtures/pets.yml +19 -19
  356. data/test/fixtures/pirates.yml +12 -12
  357. data/test/fixtures/posts.yml +80 -80
  358. data/test/fixtures/price_estimates.yml +16 -7
  359. data/test/fixtures/products.yml +4 -4
  360. data/test/fixtures/projects.yml +7 -7
  361. data/test/fixtures/randomly_named_a9.yml +7 -7
  362. data/test/fixtures/ratings.yml +14 -14
  363. data/test/fixtures/readers.yml +11 -11
  364. data/test/fixtures/references.yml +17 -17
  365. data/test/fixtures/reserved_words/distinct.yml +5 -5
  366. data/test/fixtures/reserved_words/distinct_select.yml +11 -11
  367. data/test/fixtures/reserved_words/group.yml +14 -14
  368. data/test/fixtures/reserved_words/select.yml +8 -8
  369. data/test/fixtures/reserved_words/values.yml +7 -7
  370. data/test/fixtures/ships.yml +6 -6
  371. data/test/fixtures/speedometers.yml +8 -8
  372. data/test/fixtures/sponsors.yml +12 -12
  373. data/test/fixtures/string_key_objects.yml +7 -7
  374. data/test/fixtures/subscribers.yml +10 -10
  375. data/test/fixtures/subscriptions.yml +12 -12
  376. data/test/fixtures/taggings.yml +78 -78
  377. data/test/fixtures/tags.yml +11 -11
  378. data/test/fixtures/tasks.yml +7 -7
  379. data/test/fixtures/teapots.yml +3 -3
  380. data/test/fixtures/to_be_linked/accounts.yml +2 -2
  381. data/test/fixtures/to_be_linked/users.yml +10 -10
  382. data/test/fixtures/topics.yml +49 -49
  383. data/test/fixtures/toys.yml +14 -14
  384. data/test/fixtures/traffic_lights.yml +9 -9
  385. data/test/fixtures/treasures.yml +10 -10
  386. data/test/fixtures/trees.yml +3 -0
  387. data/test/fixtures/uuid_children.yml +3 -3
  388. data/test/fixtures/uuid_parents.yml +2 -2
  389. data/test/fixtures/variants.yml +4 -4
  390. data/test/fixtures/vegetables.yml +19 -19
  391. data/test/fixtures/vertices.yml +3 -3
  392. data/test/fixtures/warehouse_things.yml +2 -2
  393. data/test/fixtures/zines.yml +5 -5
  394. data/test/ibm_db_test.rb +24 -24
  395. data/test/migrations/10_urban/9_add_expressions.rb +11 -11
  396. data/test/migrations/decimal/1_give_me_big_numbers.rb +15 -15
  397. data/test/migrations/magic/1_currencies_have_symbols.rb +12 -12
  398. data/test/migrations/missing/1000_people_have_middle_names.rb +9 -9
  399. data/test/migrations/missing/1_people_have_last_names.rb +9 -9
  400. data/test/migrations/missing/3_we_need_reminders.rb +12 -12
  401. data/test/migrations/missing/4_innocent_jointable.rb +12 -12
  402. data/test/migrations/rename/1_we_need_things.rb +11 -11
  403. data/test/migrations/rename/2_rename_things.rb +9 -9
  404. data/test/migrations/to_copy/1_people_have_hobbies.rb +9 -9
  405. data/test/migrations/to_copy/2_people_have_descriptions.rb +9 -9
  406. data/test/migrations/to_copy2/1_create_articles.rb +7 -7
  407. data/test/migrations/to_copy2/2_create_comments.rb +7 -7
  408. data/test/migrations/to_copy_with_name_collision/1_people_have_hobbies.rb +9 -9
  409. data/test/migrations/to_copy_with_timestamps/20090101010101_people_have_hobbies.rb +9 -9
  410. data/test/migrations/to_copy_with_timestamps/20090101010202_people_have_descriptions.rb +9 -9
  411. data/test/migrations/to_copy_with_timestamps2/20090101010101_create_articles.rb +7 -7
  412. data/test/migrations/to_copy_with_timestamps2/20090101010202_create_comments.rb +7 -7
  413. data/test/migrations/valid/1_valid_people_have_last_names.rb +9 -9
  414. data/test/migrations/valid/2_we_need_reminders.rb +12 -12
  415. data/test/migrations/valid/3_innocent_jointable.rb +12 -12
  416. data/test/migrations/valid_with_subdirectories/1_valid_people_have_last_names.rb +9 -9
  417. data/test/migrations/valid_with_subdirectories/sub/2_we_need_reminders.rb +12 -12
  418. data/test/migrations/valid_with_subdirectories/sub1/3_innocent_jointable.rb +12 -12
  419. data/test/migrations/valid_with_timestamps/20100101010101_valid_with_timestamps_people_have_last_names.rb +9 -9
  420. data/test/migrations/valid_with_timestamps/20100201010101_valid_with_timestamps_we_need_reminders.rb +12 -12
  421. data/test/migrations/valid_with_timestamps/20100301010101_valid_with_timestamps_innocent_jointable.rb +12 -12
  422. data/test/migrations/version_check/20131219224947_migration_version_check.rb +8 -8
  423. data/test/models/admin.rb +4 -4
  424. data/test/models/admin/account.rb +2 -2
  425. data/test/models/admin/randomly_named_c1.rb +7 -3
  426. data/test/models/admin/user.rb +40 -40
  427. data/test/models/aircraft.rb +5 -4
  428. data/test/models/arunit2_model.rb +3 -3
  429. data/test/models/author.rb +209 -212
  430. data/test/models/auto_id.rb +4 -4
  431. data/test/models/autoloadable/extra_firm.rb +2 -2
  432. data/test/models/binary.rb +1 -1
  433. data/test/models/bird.rb +12 -12
  434. data/test/models/book.rb +23 -18
  435. data/test/models/boolean.rb +2 -2
  436. data/test/models/bulb.rb +52 -51
  437. data/test/models/cake_designer.rb +3 -3
  438. data/test/models/car.rb +29 -26
  439. data/test/models/carrier.rb +2 -2
  440. data/test/models/cat.rb +10 -0
  441. data/test/models/categorization.rb +19 -19
  442. data/test/models/category.rb +35 -35
  443. data/test/models/chef.rb +8 -3
  444. data/test/models/citation.rb +3 -3
  445. data/test/models/club.rb +25 -23
  446. data/test/models/college.rb +10 -10
  447. data/test/models/column.rb +3 -3
  448. data/test/models/column_name.rb +3 -3
  449. data/test/models/comment.rb +76 -64
  450. data/test/models/company.rb +230 -225
  451. data/test/models/company_in_module.rb +98 -98
  452. data/test/models/computer.rb +3 -3
  453. data/test/models/contact.rb +41 -41
  454. data/test/models/content.rb +40 -0
  455. data/test/models/contract.rb +20 -20
  456. data/test/models/country.rb +7 -7
  457. data/test/models/course.rb +6 -6
  458. data/test/models/customer.rb +83 -77
  459. data/test/models/customer_carrier.rb +14 -14
  460. data/test/models/dashboard.rb +3 -3
  461. data/test/models/default.rb +2 -2
  462. data/test/models/department.rb +4 -4
  463. data/test/models/developer.rb +274 -252
  464. data/test/models/dog.rb +5 -5
  465. data/test/models/dog_lover.rb +5 -5
  466. data/test/models/doubloon.rb +12 -12
  467. data/test/models/drink_designer.rb +3 -3
  468. data/test/models/edge.rb +5 -5
  469. data/test/models/electron.rb +5 -5
  470. data/test/models/engine.rb +4 -4
  471. data/test/models/entrant.rb +3 -3
  472. data/test/models/essay.rb +5 -5
  473. data/test/models/event.rb +2 -2
  474. data/test/models/eye.rb +37 -37
  475. data/test/models/face.rb +9 -9
  476. data/test/models/friendship.rb +6 -6
  477. data/test/models/guid.rb +1 -1
  478. data/test/models/guitar.rb +4 -0
  479. data/test/models/hotel.rb +11 -6
  480. data/test/models/image.rb +3 -3
  481. data/test/models/interest.rb +5 -5
  482. data/test/models/invoice.rb +4 -4
  483. data/test/models/item.rb +7 -7
  484. data/test/models/job.rb +7 -7
  485. data/test/models/joke.rb +7 -7
  486. data/test/models/keyboard.rb +3 -3
  487. data/test/models/legacy_thing.rb +3 -3
  488. data/test/models/lesson.rb +11 -11
  489. data/test/models/line_item.rb +3 -3
  490. data/test/models/liquid.rb +4 -4
  491. data/test/models/man.rb +11 -11
  492. data/test/models/matey.rb +4 -4
  493. data/test/models/member.rb +42 -41
  494. data/test/models/member_detail.rb +8 -7
  495. data/test/models/member_type.rb +3 -3
  496. data/test/models/membership.rb +35 -35
  497. data/test/models/mentor.rb +3 -0
  498. data/test/models/minimalistic.rb +2 -2
  499. data/test/models/minivan.rb +9 -9
  500. data/test/models/mixed_case_monkey.rb +3 -3
  501. data/test/models/mocktail_designer.rb +2 -0
  502. data/test/models/molecule.rb +6 -6
  503. data/test/models/movie.rb +5 -5
  504. data/test/models/node.rb +5 -0
  505. data/test/models/non_primary_key.rb +2 -0
  506. data/test/models/notification.rb +3 -0
  507. data/test/models/order.rb +4 -4
  508. data/test/models/organization.rb +14 -14
  509. data/test/models/other_dog.rb +5 -0
  510. data/test/models/owner.rb +37 -34
  511. data/test/models/parrot.rb +28 -29
  512. data/test/models/person.rb +142 -143
  513. data/test/models/personal_legacy_thing.rb +4 -4
  514. data/test/models/pet.rb +18 -15
  515. data/test/models/pet_treasure.rb +6 -0
  516. data/test/models/pirate.rb +92 -92
  517. data/test/models/possession.rb +3 -3
  518. data/test/models/post.rb +273 -264
  519. data/test/models/price_estimate.rb +4 -4
  520. data/test/models/professor.rb +5 -5
  521. data/test/models/project.rb +40 -29
  522. data/test/models/publisher.rb +2 -2
  523. data/test/models/publisher/article.rb +4 -4
  524. data/test/models/publisher/magazine.rb +3 -3
  525. data/test/models/randomly_named_c1.rb +3 -3
  526. data/test/models/rating.rb +4 -4
  527. data/test/models/reader.rb +23 -23
  528. data/test/models/recipe.rb +3 -0
  529. data/test/models/record.rb +2 -2
  530. data/test/models/reference.rb +22 -22
  531. data/test/models/reply.rb +61 -61
  532. data/test/models/ship.rb +39 -33
  533. data/test/models/ship_part.rb +7 -7
  534. data/test/models/shop.rb +17 -17
  535. data/test/models/shop_account.rb +6 -6
  536. data/test/models/speedometer.rb +6 -6
  537. data/test/models/sponsor.rb +7 -7
  538. data/test/models/string_key_object.rb +3 -3
  539. data/test/models/student.rb +4 -4
  540. data/test/models/subject.rb +16 -16
  541. data/test/models/subscriber.rb +8 -8
  542. data/test/models/subscription.rb +4 -4
  543. data/test/models/tag.rb +13 -7
  544. data/test/models/tagging.rb +13 -13
  545. data/test/models/task.rb +5 -5
  546. data/test/models/topic.rb +118 -124
  547. data/test/models/toy.rb +6 -6
  548. data/test/models/traffic_light.rb +4 -4
  549. data/test/models/treasure.rb +14 -14
  550. data/test/models/treaty.rb +7 -7
  551. data/test/models/tree.rb +3 -0
  552. data/test/models/tuning_peg.rb +4 -0
  553. data/test/models/tyre.rb +11 -11
  554. data/test/models/user.rb +14 -0
  555. data/test/models/uuid_child.rb +3 -3
  556. data/test/models/uuid_item.rb +6 -0
  557. data/test/models/uuid_parent.rb +3 -3
  558. data/test/models/vegetables.rb +24 -24
  559. data/test/models/vehicle.rb +6 -6
  560. data/test/models/vertex.rb +9 -9
  561. data/test/models/warehouse_thing.rb +5 -5
  562. data/test/models/wheel.rb +3 -3
  563. data/test/models/without_table.rb +3 -3
  564. data/test/models/zine.rb +3 -3
  565. data/test/schema/mysql2_specific_schema.rb +68 -58
  566. data/test/schema/oracle_specific_schema.rb +40 -43
  567. data/test/schema/postgresql_specific_schema.rb +114 -202
  568. data/test/schema/schema.rb +1057 -938
  569. data/test/schema/schema.rb.original +1057 -0
  570. data/test/schema/sqlite_specific_schema.rb +18 -22
  571. data/test/support/config.rb +43 -43
  572. data/test/support/connection.rb +23 -22
  573. data/test/support/connection_helper.rb +14 -14
  574. data/test/support/ddl_helper.rb +8 -8
  575. data/test/support/schema_dumping_helper.rb +20 -20
  576. data/test/support/yaml_compatibility_fixtures/rails_4_1.yml +22 -0
  577. data/test/support/yaml_compatibility_fixtures/rails_4_2_0.yml +182 -0
  578. metadata +146 -30
  579. data/lib/mswin32/rb19x/ibm_db.so +0 -0
  580. data/lib/mswin32/rb21x/i386/ibm_db.so +0 -0
  581. data/lib/mswin32/rb22x/i386/ibm_db.so +0 -0
  582. data/lib/mswin32/rb23x/i386/ibm_db.so +0 -0
  583. data/test/cases/associations/deprecated_counter_cache_on_has_many_through_test.rb +0 -26
  584. data/test/cases/attribute_methods/serialization_test.rb +0 -29
  585. data/test/cases/migration/change_schema_test - Copy.rb +0 -448
  586. data/test/cases/migration/foreign_key_test - Changed.rb +0 -325
  587. data/test/cases/migration/table_and_index_test.rb +0 -24
  588. data/test/cases/relation/where_test2.rb +0 -36
  589. data/test/cases/type/decimal_test.rb +0 -51
  590. data/test/cases/type/unsigned_integer_test.rb +0 -18
  591. data/test/cases/xml_serialization_test.rb +0 -457
  592. data/test/fixtures/naked/csv/accounts.csv +0 -1
  593. data/test/schema/mysql_specific_schema.rb +0 -70
@@ -1,380 +1,383 @@
1
- require "cases/helper"
2
- require 'models/club'
3
- require 'models/member_type'
4
- require 'models/member'
5
- require 'models/membership'
6
- require 'models/sponsor'
7
- require 'models/organization'
8
- require 'models/member_detail'
9
- require 'models/minivan'
10
- require 'models/dashboard'
11
- require 'models/speedometer'
12
- require 'models/category'
13
- require 'models/author'
14
- require 'models/essay'
15
- require 'models/owner'
16
- require 'models/post'
17
- require 'models/comment'
18
- require 'models/customer'
19
- require 'models/carrier'
20
- require 'models/shop_account'
21
- require 'models/customer_carrier'
22
-
23
- class HasOneThroughAssociationsTest < ActiveRecord::TestCase
24
- fixtures :member_types, :members, :clubs, :memberships, :sponsors, :organizations, :minivans,
25
- :dashboards, :speedometers, :authors, :posts, :comments, :categories, :essays, :owners, :author_addresses
26
-
27
- def setup
28
- @member = members(:groucho)
29
- end
30
-
31
- def test_has_one_through_with_has_one
32
- assert_equal clubs(:boring_club), @member.club
33
- end
34
-
35
- def test_creating_association_creates_through_record
36
- new_member = Member.create(:name => "Chris")
37
- new_member.club = Club.create(:name => "LRUG")
38
- assert_not_nil new_member.current_membership
39
- assert_not_nil new_member.club
40
- end
41
-
42
- def test_creating_association_builds_through_record_for_new
43
- new_member = Member.new(:name => "Jane")
44
- new_member.club = clubs(:moustache_club)
45
- assert new_member.current_membership
46
- assert_equal clubs(:moustache_club), new_member.current_membership.club
47
- assert_equal clubs(:moustache_club), new_member.club
48
- assert new_member.save
49
- assert_equal clubs(:moustache_club), new_member.club
50
- end
51
-
52
- def test_creating_association_sets_both_parent_ids_for_new
53
- member = Member.new(name: 'Sean Griffin')
54
- club = Club.new(name: 'Da Club')
55
-
56
- member.club = club
57
-
58
- member.save!
59
-
60
- assert member.id
61
- assert club.id
62
- assert_equal member.id, member.current_membership.member_id
63
- assert_equal club.id, member.current_membership.club_id
64
- end
65
-
66
- def test_replace_target_record
67
- new_club = Club.create(:name => "Marx Bros")
68
- @member.club = new_club
69
- @member.reload
70
- assert_equal new_club, @member.club
71
- end
72
-
73
- def test_replacing_target_record_deletes_old_association
74
- assert_no_difference "Membership.count" do
75
- new_club = Club.create(:name => "Bananarama")
76
- @member.club = new_club
77
- @member.reload
78
- end
79
- end
80
-
81
- def test_set_record_to_nil_should_delete_association
82
- @member.club = nil
83
- @member.reload
84
- assert_equal nil, @member.current_membership
85
- assert_nil @member.club
86
- end
87
-
88
- def test_has_one_through_polymorphic
89
- assert_equal clubs(:moustache_club), @member.sponsor_club
90
- end
91
-
92
- def test_has_one_through_eager_loading
93
- members = assert_queries(3) do #base table, through table, clubs table
94
- Member.all.merge!(:includes => :club, :where => ["name = ?", "Groucho Marx"]).to_a
95
- end
96
- assert_equal 1, members.size
97
- assert_not_nil assert_no_queries {members[0].club}
98
- end
99
-
100
- def test_has_one_through_eager_loading_through_polymorphic
101
- members = assert_queries(3) do #base table, through table, clubs table
102
- Member.all.merge!(:includes => :sponsor_club, :where => ["name = ?", "Groucho Marx"]).to_a
103
- end
104
- assert_equal 1, members.size
105
- assert_not_nil assert_no_queries {members[0].sponsor_club}
106
- end
107
-
108
- def test_has_one_through_with_conditions_eager_loading
109
- # conditions on the through table
110
- assert_equal clubs(:moustache_club), Member.all.merge!(:includes => :favourite_club).find(@member.id).favourite_club
111
- memberships(:membership_of_favourite_club).update_columns(favourite: false)
112
- assert_equal nil, Member.all.merge!(:includes => :favourite_club).find(@member.id).reload.favourite_club
113
-
114
- # conditions on the source table
115
- assert_equal clubs(:moustache_club), Member.all.merge!(:includes => :hairy_club).find(@member.id).hairy_club
116
- clubs(:moustache_club).update_columns(name: "Association of Clean-Shaven Persons")
117
- assert_equal nil, Member.all.merge!(:includes => :hairy_club).find(@member.id).reload.hairy_club
118
- end
119
-
120
- def test_has_one_through_polymorphic_with_source_type
121
- assert_equal members(:groucho), clubs(:moustache_club).sponsored_member
122
- end
123
-
124
- def test_eager_has_one_through_polymorphic_with_source_type
125
- clubs = Club.all.merge!(:includes => :sponsored_member, :where => ["name = ?","Moustache and Eyebrow Fancier Club"]).to_a
126
- # Only the eyebrow fanciers club has a sponsored_member
127
- assert_not_nil assert_no_queries {clubs[0].sponsored_member}
128
- end
129
-
130
- def test_has_one_through_nonpreload_eagerloading
131
- members = assert_queries(1) do
132
- Member.all.merge!(:includes => :club, :where => ["members.name = ?", "Groucho Marx"], :order => 'clubs.name').to_a #force fallback
133
- end
134
- assert_equal 1, members.size
135
- assert_not_nil assert_no_queries {members[0].club}
136
- end
137
-
138
- def test_has_one_through_nonpreload_eager_loading_through_polymorphic
139
- members = assert_queries(1) do
140
- Member.all.merge!(:includes => :sponsor_club, :where => ["members.name = ?", "Groucho Marx"], :order => 'clubs.name').to_a #force fallback
141
- end
142
- assert_equal 1, members.size
143
- assert_not_nil assert_no_queries {members[0].sponsor_club}
144
- end
145
-
146
- def test_has_one_through_nonpreload_eager_loading_through_polymorphic_with_more_than_one_through_record
147
- Sponsor.new(:sponsor_club => clubs(:crazy_club), :sponsorable => members(:groucho)).save!
148
- members = assert_queries(1) do
149
- Member.all.merge!(:includes => :sponsor_club, :where => ["members.name = ?", "Groucho Marx"], :order => 'clubs.name DESC').to_a #force fallback
150
- end
151
- assert_equal 1, members.size
152
- assert_not_nil assert_no_queries { members[0].sponsor_club }
153
- assert_equal clubs(:crazy_club), members[0].sponsor_club
154
- end
155
-
156
- def test_uninitialized_has_one_through_should_return_nil_for_unsaved_record
157
- assert_nil Member.new.club
158
- end
159
-
160
- def test_assigning_association_correctly_assigns_target
161
- new_member = Member.create(:name => "Chris")
162
- new_member.club = new_club = Club.create(:name => "LRUG")
163
- assert_equal new_club, new_member.association(:club).target
164
- end
165
-
166
- def test_has_one_through_proxy_should_not_respond_to_private_methods
167
- assert_raise(NoMethodError) { clubs(:moustache_club).private_method }
168
- assert_raise(NoMethodError) { @member.club.private_method }
169
- end
170
-
171
- def test_has_one_through_proxy_should_respond_to_private_methods_via_send
172
- clubs(:moustache_club).send(:private_method)
173
- @member.club.send(:private_method)
174
- end
175
-
176
- def test_assigning_to_has_one_through_preserves_decorated_join_record
177
- @organization = organizations(:nsa)
178
- assert_difference 'MemberDetail.count', 1 do
179
- @member_detail = MemberDetail.new(:extra_data => 'Extra')
180
- @member.member_detail = @member_detail
181
- @member.organization = @organization
182
- end
183
- assert_equal @organization, @member.organization
184
- assert @organization.members.include?(@member)
185
- assert_equal 'Extra', @member.member_detail.extra_data
186
- end
187
-
188
- def test_reassigning_has_one_through
189
- @organization = organizations(:nsa)
190
- @new_organization = organizations(:discordians)
191
-
192
- assert_difference 'MemberDetail.count', 1 do
193
- @member_detail = MemberDetail.new(:extra_data => 'Extra')
194
- @member.member_detail = @member_detail
195
- @member.organization = @organization
196
- end
197
- assert_equal @organization, @member.organization
198
- assert_equal 'Extra', @member.member_detail.extra_data
199
- assert @organization.members.include?(@member)
200
- assert !@new_organization.members.include?(@member)
201
-
202
- assert_no_difference 'MemberDetail.count' do
203
- @member.organization = @new_organization
204
- end
205
- assert_equal @new_organization, @member.organization
206
- assert_equal 'Extra', @member.member_detail.extra_data
207
- assert !@organization.members.include?(@member)
208
- assert @new_organization.members.include?(@member)
209
- end
210
-
211
- def test_preloading_has_one_through_on_belongs_to
212
- MemberDetail.delete_all
213
- assert_not_nil @member.member_type
214
- @organization = organizations(:nsa)
215
- @member_detail = MemberDetail.new
216
- @member.member_detail = @member_detail
217
- @member.organization = @organization
218
- @member_details = assert_queries(3) do
219
- MemberDetail.all.merge!(:includes => :member_type).to_a
220
- end
221
- @new_detail = @member_details[0]
222
- assert @new_detail.send(:association, :member_type).loaded?
223
- assert_no_queries { @new_detail.member_type }
224
- end
225
-
226
- def test_save_of_record_with_loaded_has_one_through
227
- @club = @member.club
228
- assert_not_nil @club.sponsored_member
229
-
230
- assert_nothing_raised do
231
- Club.find(@club.id).save!
232
- Club.all.merge!(:includes => :sponsored_member).find(@club.id).save!
233
- end
234
-
235
- @club.sponsor.destroy
236
-
237
- assert_nothing_raised do
238
- Club.find(@club.id).save!
239
- Club.all.merge!(:includes => :sponsored_member).find(@club.id).save!
240
- end
241
- end
242
-
243
- def test_through_belongs_to_after_destroy
244
- @member_detail = MemberDetail.new(:extra_data => 'Extra')
245
- @member.member_detail = @member_detail
246
- @member.save!
247
-
248
- assert_not_nil @member_detail.member_type
249
- @member_detail.destroy
250
- assert_queries(1) do
251
- assert_not_nil @member_detail.member_type(true)
252
- end
253
-
254
- @member_detail.member.destroy
255
- assert_queries(1) do
256
- assert_nil @member_detail.member_type(true)
257
- end
258
- end
259
-
260
- def test_value_is_properly_quoted
261
- minivan = Minivan.find('m1')
262
- assert_nothing_raised do
263
- minivan.dashboard
264
- end
265
- end
266
-
267
- def test_has_one_through_polymorphic_with_primary_key_option
268
- assert_equal categories(:general), authors(:david).essay_category
269
-
270
- authors = Author.joins(:essay_category).where('categories.id' => categories(:general).id)
271
- assert_equal authors(:david), authors.first
272
-
273
- assert_equal owners(:blackbeard), authors(:david).essay_owner
274
-
275
- authors = Author.joins(:essay_owner).where("owners.name = 'blackbeard'")
276
- assert_equal authors(:david), authors.first
277
- end
278
-
279
- def test_has_one_through_with_primary_key_option
280
- assert_equal categories(:general), authors(:david).essay_category_2
281
-
282
- authors = Author.joins(:essay_category_2).where('categories.id' => categories(:general).id)
283
- assert_equal authors(:david), authors.first
284
- end
285
-
286
- def test_has_one_through_with_default_scope_on_join_model
287
- assert_equal posts(:welcome).comments.order('id').first, authors(:david).comment_on_first_post
288
- end
289
-
290
- def test_has_one_through_many_raises_exception
291
- assert_raise(ActiveRecord::HasOneThroughCantAssociateThroughCollection) do
292
- members(:groucho).club_through_many
293
- end
294
- end
295
-
296
- def test_has_one_through_polymorphic_association
297
- assert_raise(ActiveRecord::HasOneAssociationPolymorphicThroughError) do
298
- @member.premium_club
299
- end
300
- end
301
-
302
- def test_has_one_through_belongs_to_should_update_when_the_through_foreign_key_changes
303
- minivan = minivans(:cool_first)
304
-
305
- minivan.dashboard
306
- proxy = minivan.send(:association_instance_get, :dashboard)
307
-
308
- assert !proxy.stale_target?
309
- assert_equal dashboards(:cool_first), minivan.dashboard
310
-
311
- minivan.speedometer_id = speedometers(:second).id
312
-
313
- assert proxy.stale_target?
314
- assert_equal dashboards(:second), minivan.dashboard
315
- end
316
-
317
- def test_has_one_through_belongs_to_setting_belongs_to_foreign_key_after_nil_target_loaded
318
- minivan = Minivan.new
319
-
320
- minivan.dashboard
321
- proxy = minivan.send(:association_instance_get, :dashboard)
322
-
323
- minivan.speedometer_id = speedometers(:second).id
324
-
325
- assert proxy.stale_target?
326
- assert_equal dashboards(:second), minivan.dashboard
327
- end
328
-
329
- def test_assigning_has_one_through_belongs_to_with_new_record_owner
330
- minivan = Minivan.new
331
- dashboard = dashboards(:cool_first)
332
-
333
- minivan.dashboard = dashboard
334
-
335
- assert_equal dashboard, minivan.dashboard
336
- assert_equal dashboard, minivan.speedometer.dashboard
337
- end
338
-
339
- def test_has_one_through_with_custom_select_on_join_model_default_scope
340
- assert_equal clubs(:boring_club), members(:groucho).selected_club
341
- end
342
-
343
- def test_has_one_through_relationship_cannot_have_a_counter_cache
344
- assert_raise(ArgumentError) do
345
- Class.new(ActiveRecord::Base) do
346
- has_one :thing, through: :other_thing, counter_cache: true
347
- end
348
- end
349
- end
350
-
351
- def test_has_one_through_do_not_cache_association_reader_if_the_though_method_has_default_scopes
352
- customer = Customer.create!
353
- carrier = Carrier.create!
354
- customer_carrier = CustomerCarrier.create!(
355
- customer: customer,
356
- carrier: carrier,
357
- )
358
- account = ShopAccount.create!(customer_carrier: customer_carrier)
359
-
360
- CustomerCarrier.current_customer = customer
361
-
362
- account_carrier = account.carrier
363
- assert_equal carrier, account_carrier
364
-
365
- CustomerCarrier.current_customer = nil
366
-
367
- other_carrier = Carrier.create!
368
- other_customer = Customer.create!
369
- other_customer_carrier = CustomerCarrier.create!(
370
- customer: other_customer,
371
- carrier: other_carrier,
372
- )
373
- other_account = ShopAccount.create!(customer_carrier: other_customer_carrier)
374
-
375
- account_carrier = other_account.carrier
376
- assert_equal other_carrier, account_carrier
377
- ensure
378
- CustomerCarrier.current_customer = nil
379
- end
380
- end
1
+ require "cases/helper"
2
+ require 'models/club'
3
+ require 'models/member_type'
4
+ require 'models/member'
5
+ require 'models/membership'
6
+ require 'models/sponsor'
7
+ require 'models/organization'
8
+ require 'models/member_detail'
9
+ require 'models/minivan'
10
+ require 'models/dashboard'
11
+ require 'models/speedometer'
12
+ require 'models/category'
13
+ require 'models/author'
14
+ require 'models/essay'
15
+ require 'models/owner'
16
+ require 'models/post'
17
+ require 'models/comment'
18
+ require 'models/categorization'
19
+ require 'models/customer'
20
+ require 'models/carrier'
21
+ require 'models/shop_account'
22
+ require 'models/customer_carrier'
23
+
24
+ class HasOneThroughAssociationsTest < ActiveRecord::TestCase
25
+ fixtures :member_types, :members, :clubs, :memberships, :sponsors, :organizations, :minivans,
26
+ :dashboards, :speedometers, :authors, :posts, :comments, :categories, :essays, :owners
27
+
28
+ def setup
29
+ @member = members(:groucho)
30
+ end
31
+
32
+ def test_has_one_through_with_has_one
33
+ assert_equal clubs(:boring_club), @member.club
34
+ end
35
+
36
+ def test_creating_association_creates_through_record
37
+ new_member = Member.create(:name => "Chris")
38
+ new_member.club = Club.create(:name => "LRUG")
39
+ assert_not_nil new_member.current_membership
40
+ assert_not_nil new_member.club
41
+ end
42
+
43
+ def test_creating_association_builds_through_record_for_new
44
+ new_member = Member.new(:name => "Jane")
45
+ new_member.club = clubs(:moustache_club)
46
+ assert new_member.current_membership
47
+ assert_equal clubs(:moustache_club), new_member.current_membership.club
48
+ assert_equal clubs(:moustache_club), new_member.club
49
+ assert new_member.save
50
+ assert_equal clubs(:moustache_club), new_member.club
51
+ end
52
+
53
+ def test_creating_association_sets_both_parent_ids_for_new
54
+ member = Member.new(name: 'Sean Griffin')
55
+ club = Club.new(name: 'Da Club')
56
+
57
+ member.club = club
58
+
59
+ member.save!
60
+
61
+ assert member.id
62
+ assert club.id
63
+ assert_equal member.id, member.current_membership.member_id
64
+ assert_equal club.id, member.current_membership.club_id
65
+ end
66
+
67
+ def test_replace_target_record
68
+ new_club = Club.create(:name => "Marx Bros")
69
+ @member.club = new_club
70
+ @member.reload
71
+ assert_equal new_club, @member.club
72
+ end
73
+
74
+ def test_replacing_target_record_deletes_old_association
75
+ assert_no_difference "Membership.count" do
76
+ new_club = Club.create(:name => "Bananarama")
77
+ @member.club = new_club
78
+ @member.reload
79
+ end
80
+ end
81
+
82
+ def test_set_record_to_nil_should_delete_association
83
+ @member.club = nil
84
+ @member.reload
85
+ assert_equal nil, @member.current_membership
86
+ assert_nil @member.club
87
+ end
88
+
89
+ def test_has_one_through_polymorphic
90
+ assert_equal clubs(:moustache_club), @member.sponsor_club
91
+ end
92
+
93
+ def test_has_one_through_eager_loading
94
+ members = assert_queries(3) do #base table, through table, clubs table
95
+ Member.all.merge!(:includes => :club, :where => ["name = ?", "Groucho Marx"]).to_a
96
+ end
97
+ assert_equal 1, members.size
98
+ assert_not_nil assert_no_queries {members[0].club}
99
+ end
100
+
101
+ def test_has_one_through_eager_loading_through_polymorphic
102
+ members = assert_queries(3) do #base table, through table, clubs table
103
+ Member.all.merge!(:includes => :sponsor_club, :where => ["name = ?", "Groucho Marx"]).to_a
104
+ end
105
+ assert_equal 1, members.size
106
+ assert_not_nil assert_no_queries {members[0].sponsor_club}
107
+ end
108
+
109
+ def test_has_one_through_with_conditions_eager_loading
110
+ # conditions on the through table
111
+ assert_equal clubs(:moustache_club), Member.all.merge!(:includes => :favourite_club).find(@member.id).favourite_club
112
+ memberships(:membership_of_favourite_club).update_columns(favourite: false)
113
+ assert_equal nil, Member.all.merge!(:includes => :favourite_club).find(@member.id).reload.favourite_club
114
+
115
+ # conditions on the source table
116
+ assert_equal clubs(:moustache_club), Member.all.merge!(:includes => :hairy_club).find(@member.id).hairy_club
117
+ clubs(:moustache_club).update_columns(name: "Association of Clean-Shaven Persons")
118
+ assert_equal nil, Member.all.merge!(:includes => :hairy_club).find(@member.id).reload.hairy_club
119
+ end
120
+
121
+ def test_has_one_through_polymorphic_with_source_type
122
+ assert_equal members(:groucho), clubs(:moustache_club).sponsored_member
123
+ end
124
+
125
+ def test_eager_has_one_through_polymorphic_with_source_type
126
+ clubs = Club.all.merge!(:includes => :sponsored_member, :where => ["name = ?","Moustache and Eyebrow Fancier Club"]).to_a
127
+ # Only the eyebrow fanciers club has a sponsored_member
128
+ assert_not_nil assert_no_queries {clubs[0].sponsored_member}
129
+ end
130
+
131
+ def test_has_one_through_nonpreload_eagerloading
132
+ members = assert_queries(1) do
133
+ Member.all.merge!(:includes => :club, :where => ["members.name = ?", "Groucho Marx"], :order => 'clubs.name').to_a #force fallback
134
+ end
135
+ assert_equal 1, members.size
136
+ assert_not_nil assert_no_queries {members[0].club}
137
+ end
138
+
139
+ def test_has_one_through_nonpreload_eager_loading_through_polymorphic
140
+ members = assert_queries(1) do
141
+ Member.all.merge!(:includes => :sponsor_club, :where => ["members.name = ?", "Groucho Marx"], :order => 'clubs.name').to_a #force fallback
142
+ end
143
+ assert_equal 1, members.size
144
+ assert_not_nil assert_no_queries {members[0].sponsor_club}
145
+ end
146
+
147
+ def test_has_one_through_nonpreload_eager_loading_through_polymorphic_with_more_than_one_through_record
148
+ Sponsor.new(:sponsor_club => clubs(:crazy_club), :sponsorable => members(:groucho)).save!
149
+ members = assert_queries(1) do
150
+ Member.all.merge!(:includes => :sponsor_club, :where => ["members.name = ?", "Groucho Marx"], :order => 'clubs.name DESC').to_a #force fallback
151
+ end
152
+ assert_equal 1, members.size
153
+ assert_not_nil assert_no_queries { members[0].sponsor_club }
154
+ assert_equal clubs(:crazy_club), members[0].sponsor_club
155
+ end
156
+
157
+ def test_uninitialized_has_one_through_should_return_nil_for_unsaved_record
158
+ assert_nil Member.new.club
159
+ end
160
+
161
+ def test_assigning_association_correctly_assigns_target
162
+ new_member = Member.create(:name => "Chris")
163
+ new_member.club = new_club = Club.create(:name => "LRUG")
164
+ assert_equal new_club, new_member.association(:club).target
165
+ end
166
+
167
+ def test_has_one_through_proxy_should_not_respond_to_private_methods
168
+ assert_raise(NoMethodError) { clubs(:moustache_club).private_method }
169
+ assert_raise(NoMethodError) { @member.club.private_method }
170
+ end
171
+
172
+ def test_has_one_through_proxy_should_respond_to_private_methods_via_send
173
+ clubs(:moustache_club).send(:private_method)
174
+ @member.club.send(:private_method)
175
+ end
176
+
177
+ def test_assigning_to_has_one_through_preserves_decorated_join_record
178
+ @organization = organizations(:nsa)
179
+ assert_difference 'MemberDetail.count', 1 do
180
+ @member_detail = MemberDetail.new(:extra_data => 'Extra')
181
+ @member.member_detail = @member_detail
182
+ @member.organization = @organization
183
+ end
184
+ assert_equal @organization, @member.organization
185
+ assert @organization.members.include?(@member)
186
+ assert_equal 'Extra', @member.member_detail.extra_data
187
+ end
188
+
189
+ def test_reassigning_has_one_through
190
+ @organization = organizations(:nsa)
191
+ @new_organization = organizations(:discordians)
192
+
193
+ assert_difference 'MemberDetail.count', 1 do
194
+ @member_detail = MemberDetail.new(:extra_data => 'Extra')
195
+ @member.member_detail = @member_detail
196
+ @member.organization = @organization
197
+ end
198
+ assert_equal @organization, @member.organization
199
+ assert_equal 'Extra', @member.member_detail.extra_data
200
+ assert @organization.members.include?(@member)
201
+ assert !@new_organization.members.include?(@member)
202
+
203
+ assert_no_difference 'MemberDetail.count' do
204
+ @member.organization = @new_organization
205
+ end
206
+ assert_equal @new_organization, @member.organization
207
+ assert_equal 'Extra', @member.member_detail.extra_data
208
+ assert !@organization.members.include?(@member)
209
+ assert @new_organization.members.include?(@member)
210
+ end
211
+
212
+ def test_preloading_has_one_through_on_belongs_to
213
+ MemberDetail.delete_all
214
+ assert_not_nil @member.member_type
215
+ @organization = organizations(:nsa)
216
+ @member_detail = MemberDetail.new
217
+ @member.member_detail = @member_detail
218
+ @member.organization = @organization
219
+ @member_details = assert_queries(3) do
220
+ MemberDetail.all.merge!(:includes => :member_type).to_a
221
+ end
222
+ @new_detail = @member_details[0]
223
+ assert @new_detail.send(:association, :member_type).loaded?
224
+ assert_no_queries { @new_detail.member_type }
225
+ end
226
+
227
+ def test_save_of_record_with_loaded_has_one_through
228
+ @club = @member.club
229
+ assert_not_nil @club.sponsored_member
230
+
231
+ assert_nothing_raised do
232
+ Club.find(@club.id).save!
233
+ Club.all.merge!(:includes => :sponsored_member).find(@club.id).save!
234
+ end
235
+
236
+ @club.sponsor.destroy
237
+
238
+ assert_nothing_raised do
239
+ Club.find(@club.id).save!
240
+ Club.all.merge!(:includes => :sponsored_member).find(@club.id).save!
241
+ end
242
+ end
243
+
244
+ def test_through_belongs_to_after_destroy
245
+ @member_detail = MemberDetail.new(:extra_data => 'Extra')
246
+ @member.member_detail = @member_detail
247
+ @member.save!
248
+
249
+ assert_not_nil @member_detail.member_type
250
+ @member_detail.destroy
251
+ assert_queries(1) do
252
+ @member_detail.association(:member_type).reload
253
+ assert_not_nil @member_detail.member_type
254
+ end
255
+
256
+ @member_detail.member.destroy
257
+ assert_queries(1) do
258
+ @member_detail.association(:member_type).reload
259
+ assert_nil @member_detail.member_type
260
+ end
261
+ end
262
+
263
+ def test_value_is_properly_quoted
264
+ minivan = Minivan.find('m1')
265
+ assert_nothing_raised do
266
+ minivan.dashboard
267
+ end
268
+ end
269
+
270
+ def test_has_one_through_polymorphic_with_primary_key_option
271
+ assert_equal categories(:general), authors(:david).essay_category
272
+
273
+ authors = Author.joins(:essay_category).where('categories.id' => categories(:general).id)
274
+ assert_equal authors(:david), authors.first
275
+
276
+ assert_equal owners(:blackbeard), authors(:david).essay_owner
277
+
278
+ authors = Author.joins(:essay_owner).where("owners.name = 'blackbeard'")
279
+ assert_equal authors(:david), authors.first
280
+ end
281
+
282
+ def test_has_one_through_with_primary_key_option
283
+ assert_equal categories(:general), authors(:david).essay_category_2
284
+
285
+ authors = Author.joins(:essay_category_2).where('categories.id' => categories(:general).id)
286
+ assert_equal authors(:david), authors.first
287
+ end
288
+
289
+ def test_has_one_through_with_default_scope_on_join_model
290
+ assert_equal posts(:welcome).comments.order('id').first, authors(:david).comment_on_first_post
291
+ end
292
+
293
+ def test_has_one_through_many_raises_exception
294
+ assert_raise(ActiveRecord::HasOneThroughCantAssociateThroughCollection) do
295
+ members(:groucho).club_through_many
296
+ end
297
+ end
298
+
299
+ def test_has_one_through_polymorphic_association
300
+ assert_raise(ActiveRecord::HasOneAssociationPolymorphicThroughError) do
301
+ @member.premium_club
302
+ end
303
+ end
304
+
305
+ def test_has_one_through_belongs_to_should_update_when_the_through_foreign_key_changes
306
+ minivan = minivans(:cool_first)
307
+
308
+ minivan.dashboard
309
+ proxy = minivan.send(:association_instance_get, :dashboard)
310
+
311
+ assert !proxy.stale_target?
312
+ assert_equal dashboards(:cool_first), minivan.dashboard
313
+
314
+ minivan.speedometer_id = speedometers(:second).id
315
+
316
+ assert proxy.stale_target?
317
+ assert_equal dashboards(:second), minivan.dashboard
318
+ end
319
+
320
+ def test_has_one_through_belongs_to_setting_belongs_to_foreign_key_after_nil_target_loaded
321
+ minivan = Minivan.new
322
+
323
+ minivan.dashboard
324
+ proxy = minivan.send(:association_instance_get, :dashboard)
325
+
326
+ minivan.speedometer_id = speedometers(:second).id
327
+
328
+ assert proxy.stale_target?
329
+ assert_equal dashboards(:second), minivan.dashboard
330
+ end
331
+
332
+ def test_assigning_has_one_through_belongs_to_with_new_record_owner
333
+ minivan = Minivan.new
334
+ dashboard = dashboards(:cool_first)
335
+
336
+ minivan.dashboard = dashboard
337
+
338
+ assert_equal dashboard, minivan.dashboard
339
+ assert_equal dashboard, minivan.speedometer.dashboard
340
+ end
341
+
342
+ def test_has_one_through_with_custom_select_on_join_model_default_scope
343
+ assert_equal clubs(:boring_club), members(:groucho).selected_club
344
+ end
345
+
346
+ def test_has_one_through_relationship_cannot_have_a_counter_cache
347
+ assert_raise(ArgumentError) do
348
+ Class.new(ActiveRecord::Base) do
349
+ has_one :thing, through: :other_thing, counter_cache: true
350
+ end
351
+ end
352
+ end
353
+
354
+ def test_has_one_through_do_not_cache_association_reader_if_the_though_method_has_default_scopes
355
+ customer = Customer.create!
356
+ carrier = Carrier.create!
357
+ customer_carrier = CustomerCarrier.create!(
358
+ customer: customer,
359
+ carrier: carrier,
360
+ )
361
+ account = ShopAccount.create!(customer_carrier: customer_carrier)
362
+
363
+ CustomerCarrier.current_customer = customer
364
+
365
+ account_carrier = account.carrier
366
+ assert_equal carrier, account_carrier
367
+
368
+ CustomerCarrier.current_customer = nil
369
+
370
+ other_carrier = Carrier.create!
371
+ other_customer = Customer.create!
372
+ other_customer_carrier = CustomerCarrier.create!(
373
+ customer: other_customer,
374
+ carrier: other_carrier,
375
+ )
376
+ other_account = ShopAccount.create!(customer_carrier: other_customer_carrier)
377
+
378
+ account_carrier = other_account.carrier
379
+ assert_equal other_carrier, account_carrier
380
+ ensure
381
+ CustomerCarrier.current_customer = nil
382
+ end
383
+ end