ibm_db 4.0.0-x86-mingw32 → 5.1.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 (576) hide show
  1. checksums.yaml +5 -5
  2. data/MANIFEST +14 -14
  3. data/README +208 -208
  4. data/ext/Makefile +269 -0
  5. data/ext/Makefile.nt32 +181 -181
  6. data/ext/Makefile.nt32.191 +212 -212
  7. data/ext/extconf.rb +322 -291
  8. data/ext/gil_release_version.h +3 -0
  9. data/ext/ibm_db-i386-mingw32.def +2 -0
  10. data/ext/ibm_db.c +11879 -11887
  11. data/ext/ibm_db.o +0 -0
  12. data/ext/ibm_db.so +0 -0
  13. data/ext/mkmf.log +110 -0
  14. data/ext/ruby_ibm_db.h +241 -241
  15. data/ext/ruby_ibm_db_cli.c +866 -866
  16. data/ext/ruby_ibm_db_cli.h +500 -500
  17. data/ext/ruby_ibm_db_cli.o +0 -0
  18. data/ext/unicode_support_version.h +3 -0
  19. data/init.rb +41 -41
  20. data/lib/IBM_DB.rb +27 -27
  21. data/lib/active_record/connection_adapters/ibm_db_adapter.rb +3593 -3452
  22. data/lib/active_record/connection_adapters/ibmdb_adapter.rb +5 -5
  23. data/lib/active_record/vendor/db2-i5-zOS.yaml +328 -328
  24. data/lib/mswin32/ibm_db.rb +94 -90
  25. data/lib/mswin32/rb2x/i386/ruby26/ibm_db.so +0 -0
  26. data/lib/mswin32/rb2x/i386/ruby27/ibm_db.so +0 -0
  27. data/test/active_record/connection_adapters/fake_adapter.rb +49 -49
  28. data/test/assets/example.log +1 -1
  29. data/test/assets/test.txt +1 -1
  30. data/test/cases/adapter_test.rb +351 -351
  31. data/test/cases/adapters/mysql2/active_schema_test.rb +193 -193
  32. data/test/cases/adapters/mysql2/bind_parameter_test.rb +50 -50
  33. data/test/cases/adapters/mysql2/boolean_test.rb +100 -100
  34. data/test/cases/adapters/mysql2/case_sensitivity_test.rb +63 -63
  35. data/test/cases/adapters/mysql2/charset_collation_test.rb +54 -54
  36. data/test/cases/adapters/mysql2/connection_test.rb +210 -210
  37. data/test/cases/adapters/mysql2/datetime_precision_quoting_test.rb +45 -45
  38. data/test/cases/adapters/mysql2/enum_test.rb +26 -26
  39. data/test/cases/adapters/mysql2/explain_test.rb +21 -21
  40. data/test/cases/adapters/mysql2/json_test.rb +195 -195
  41. data/test/cases/adapters/mysql2/mysql2_adapter_test.rb +83 -83
  42. data/test/cases/adapters/mysql2/reserved_word_test.rb +152 -152
  43. data/test/cases/adapters/mysql2/schema_migrations_test.rb +59 -59
  44. data/test/cases/adapters/mysql2/schema_test.rb +126 -126
  45. data/test/cases/adapters/mysql2/sp_test.rb +36 -36
  46. data/test/cases/adapters/mysql2/sql_types_test.rb +14 -14
  47. data/test/cases/adapters/mysql2/table_options_test.rb +42 -42
  48. data/test/cases/adapters/mysql2/unsigned_type_test.rb +66 -66
  49. data/test/cases/adapters/postgresql/active_schema_test.rb +98 -98
  50. data/test/cases/adapters/postgresql/array_test.rb +339 -339
  51. data/test/cases/adapters/postgresql/bit_string_test.rb +82 -82
  52. data/test/cases/adapters/postgresql/bytea_test.rb +134 -134
  53. data/test/cases/adapters/postgresql/case_insensitive_test.rb +26 -26
  54. data/test/cases/adapters/postgresql/change_schema_test.rb +38 -38
  55. data/test/cases/adapters/postgresql/cidr_test.rb +25 -25
  56. data/test/cases/adapters/postgresql/citext_test.rb +78 -78
  57. data/test/cases/adapters/postgresql/collation_test.rb +53 -53
  58. data/test/cases/adapters/postgresql/composite_test.rb +132 -132
  59. data/test/cases/adapters/postgresql/connection_test.rb +257 -257
  60. data/test/cases/adapters/postgresql/datatype_test.rb +92 -92
  61. data/test/cases/adapters/postgresql/domain_test.rb +47 -47
  62. data/test/cases/adapters/postgresql/enum_test.rb +91 -91
  63. data/test/cases/adapters/postgresql/explain_test.rb +20 -20
  64. data/test/cases/adapters/postgresql/extension_migration_test.rb +63 -63
  65. data/test/cases/adapters/postgresql/full_text_test.rb +44 -44
  66. data/test/cases/adapters/postgresql/geometric_test.rb +378 -378
  67. data/test/cases/adapters/postgresql/hstore_test.rb +382 -382
  68. data/test/cases/adapters/postgresql/infinity_test.rb +69 -69
  69. data/test/cases/adapters/postgresql/integer_test.rb +25 -25
  70. data/test/cases/adapters/postgresql/json_test.rb +237 -237
  71. data/test/cases/adapters/postgresql/ltree_test.rb +53 -53
  72. data/test/cases/adapters/postgresql/money_test.rb +96 -96
  73. data/test/cases/adapters/postgresql/network_test.rb +94 -94
  74. data/test/cases/adapters/postgresql/numbers_test.rb +49 -49
  75. data/test/cases/adapters/postgresql/postgresql_adapter_test.rb +405 -405
  76. data/test/cases/adapters/postgresql/prepared_statements_test.rb +22 -22
  77. data/test/cases/adapters/postgresql/quoting_test.rb +44 -44
  78. data/test/cases/adapters/postgresql/range_test.rb +343 -343
  79. data/test/cases/adapters/postgresql/referential_integrity_test.rb +111 -111
  80. data/test/cases/adapters/postgresql/rename_table_test.rb +34 -34
  81. data/test/cases/adapters/postgresql/schema_authorization_test.rb +119 -119
  82. data/test/cases/adapters/postgresql/schema_test.rb +597 -597
  83. data/test/cases/adapters/postgresql/serial_test.rb +154 -154
  84. data/test/cases/adapters/postgresql/statement_pool_test.rb +41 -41
  85. data/test/cases/adapters/postgresql/timestamp_test.rb +90 -90
  86. data/test/cases/adapters/postgresql/type_lookup_test.rb +33 -33
  87. data/test/cases/adapters/postgresql/utils_test.rb +62 -62
  88. data/test/cases/adapters/postgresql/uuid_test.rb +294 -294
  89. data/test/cases/adapters/postgresql/xml_test.rb +54 -54
  90. data/test/cases/adapters/sqlite3/collation_test.rb +53 -53
  91. data/test/cases/adapters/sqlite3/copy_table_test.rb +98 -98
  92. data/test/cases/adapters/sqlite3/explain_test.rb +21 -21
  93. data/test/cases/adapters/sqlite3/quoting_test.rb +101 -101
  94. data/test/cases/adapters/sqlite3/sqlite3_adapter_test.rb +441 -441
  95. data/test/cases/adapters/sqlite3/sqlite3_create_folder_test.rb +24 -24
  96. data/test/cases/adapters/sqlite3/statement_pool_test.rb +20 -20
  97. data/test/cases/aggregations_test.rb +168 -168
  98. data/test/cases/ar_schema_test.rb +146 -146
  99. data/test/cases/associations/association_scope_test.rb +16 -16
  100. data/test/cases/associations/belongs_to_associations_test.rb +1141 -1141
  101. data/test/cases/associations/bidirectional_destroy_dependencies_test.rb +41 -41
  102. data/test/cases/associations/callbacks_test.rb +190 -190
  103. data/test/cases/associations/cascaded_eager_loading_test.rb +188 -188
  104. data/test/cases/associations/eager_load_includes_full_sti_class_test.rb +36 -36
  105. data/test/cases/associations/eager_load_nested_include_test.rb +126 -126
  106. data/test/cases/associations/eager_singularization_test.rb +148 -148
  107. data/test/cases/associations/eager_test.rb +1514 -1514
  108. data/test/cases/associations/extension_test.rb +87 -87
  109. data/test/cases/associations/has_and_belongs_to_many_associations_test.rb +1004 -1004
  110. data/test/cases/associations/has_many_associations_test.rb +2501 -2501
  111. data/test/cases/associations/has_many_through_associations_test.rb +1271 -1271
  112. data/test/cases/associations/has_one_associations_test.rb +707 -707
  113. data/test/cases/associations/has_one_through_associations_test.rb +383 -383
  114. data/test/cases/associations/inner_join_association_test.rb +139 -139
  115. data/test/cases/associations/inverse_associations_test.rb +733 -733
  116. data/test/cases/associations/join_model_test.rb +777 -777
  117. data/test/cases/associations/left_outer_join_association_test.rb +88 -88
  118. data/test/cases/associations/nested_through_associations_test.rb +579 -579
  119. data/test/cases/associations/required_test.rb +102 -102
  120. data/test/cases/associations_test.rb +385 -385
  121. data/test/cases/attribute_decorators_test.rb +126 -125
  122. data/test/cases/attribute_methods/read_test.rb +60 -60
  123. data/test/cases/attribute_methods_test.rb +1009 -1009
  124. data/test/cases/attribute_set_test.rb +270 -270
  125. data/test/cases/attribute_test.rb +246 -246
  126. data/test/cases/attributes_test.rb +253 -253
  127. data/test/cases/autosave_association_test.rb +1708 -1708
  128. data/test/cases/base_test.rb +1713 -1713
  129. data/test/cases/batches_test.rb +489 -489
  130. data/test/cases/binary_test.rb +44 -44
  131. data/test/cases/bind_parameter_test.rb +110 -110
  132. data/test/cases/cache_key_test.rb +26 -25
  133. data/test/cases/calculations_test.rb +798 -798
  134. data/test/cases/callbacks_test.rb +636 -636
  135. data/test/cases/clone_test.rb +40 -40
  136. data/test/cases/coders/json_test.rb +15 -15
  137. data/test/cases/coders/yaml_column_test.rb +63 -63
  138. data/test/cases/collection_cache_key_test.rb +115 -115
  139. data/test/cases/column_alias_test.rb +17 -17
  140. data/test/cases/column_definition_test.rb +92 -92
  141. data/test/cases/comment_test.rb +145 -143
  142. data/test/cases/connection_adapters/adapter_leasing_test.rb +56 -56
  143. data/test/cases/connection_adapters/connection_handler_test.rb +160 -160
  144. data/test/cases/connection_adapters/connection_specification_test.rb +12 -12
  145. data/test/cases/connection_adapters/merge_and_resolve_default_url_config_test.rb +255 -255
  146. data/test/cases/connection_adapters/mysql_type_lookup_test.rb +69 -69
  147. data/test/cases/connection_adapters/quoting_test.rb +13 -13
  148. data/test/cases/connection_adapters/schema_cache_test.rb +61 -61
  149. data/test/cases/connection_adapters/type_lookup_test.rb +118 -118
  150. data/test/cases/connection_management_test.rb +112 -112
  151. data/test/cases/connection_pool_test.rb +521 -521
  152. data/test/cases/connection_specification/resolver_test.rb +131 -131
  153. data/test/cases/core_test.rb +112 -112
  154. data/test/cases/counter_cache_test.rb +214 -214
  155. data/test/cases/custom_locking_test.rb +17 -17
  156. data/test/cases/database_statements_test.rb +34 -34
  157. data/test/cases/date_test.rb +44 -44
  158. data/test/cases/date_time_precision_test.rb +107 -106
  159. data/test/cases/date_time_test.rb +61 -61
  160. data/test/cases/defaults_test.rb +219 -218
  161. data/test/cases/dirty_test.rb +763 -763
  162. data/test/cases/disconnected_test.rb +30 -30
  163. data/test/cases/dup_test.rb +157 -157
  164. data/test/cases/enum_test.rb +444 -444
  165. data/test/cases/errors_test.rb +16 -16
  166. data/test/cases/explain_subscriber_test.rb +64 -64
  167. data/test/cases/explain_test.rb +87 -87
  168. data/test/cases/finder_respond_to_test.rb +60 -60
  169. data/test/cases/finder_test.rb +1294 -1294
  170. data/test/cases/fixture_set/file_test.rb +156 -156
  171. data/test/cases/fixtures_test.rb +988 -988
  172. data/test/cases/forbidden_attributes_protection_test.rb +165 -165
  173. data/test/cases/habtm_destroy_order_test.rb +61 -61
  174. data/test/cases/helper.rb +204 -204
  175. data/test/cases/hot_compatibility_test.rb +142 -142
  176. data/test/cases/i18n_test.rb +45 -45
  177. data/test/cases/inheritance_test.rb +606 -606
  178. data/test/cases/integration_test.rb +155 -155
  179. data/test/cases/invalid_connection_test.rb +24 -24
  180. data/test/cases/invertible_migration_test.rb +387 -387
  181. data/test/cases/json_serialization_test.rb +311 -311
  182. data/test/cases/locking_test.rb +493 -493
  183. data/test/cases/log_subscriber_test.rb +225 -225
  184. data/test/cases/migration/change_schema_test.rb +458 -458
  185. data/test/cases/migration/change_table_test.rb +256 -256
  186. data/test/cases/migration/column_attributes_test.rb +176 -176
  187. data/test/cases/migration/column_positioning_test.rb +56 -56
  188. data/test/cases/migration/columns_test.rb +310 -310
  189. data/test/cases/migration/command_recorder_test.rb +350 -350
  190. data/test/cases/migration/compatibility_test.rb +118 -118
  191. data/test/cases/migration/create_join_table_test.rb +157 -157
  192. data/test/cases/migration/foreign_key_test.rb +362 -360
  193. data/test/cases/migration/helper.rb +39 -39
  194. data/test/cases/migration/index_test.rb +218 -218
  195. data/test/cases/migration/logger_test.rb +36 -36
  196. data/test/cases/migration/pending_migrations_test.rb +52 -52
  197. data/test/cases/migration/references_foreign_key_test.rb +221 -216
  198. data/test/cases/migration/references_index_test.rb +101 -101
  199. data/test/cases/migration/references_statements_test.rb +136 -136
  200. data/test/cases/migration/rename_table_test.rb +93 -93
  201. data/test/cases/migration_test.rb +1157 -1157
  202. data/test/cases/migrator_test.rb +471 -470
  203. data/test/cases/mixin_test.rb +68 -68
  204. data/test/cases/modules_test.rb +172 -172
  205. data/test/cases/multiparameter_attributes_test.rb +372 -372
  206. data/test/cases/multiple_db_test.rb +122 -122
  207. data/test/cases/nested_attributes_test.rb +1098 -1098
  208. data/test/cases/nested_attributes_with_callbacks_test.rb +144 -144
  209. data/test/cases/persistence_test.rb +1001 -1001
  210. data/test/cases/pooled_connections_test.rb +81 -81
  211. data/test/cases/primary_keys_test.rb +376 -376
  212. data/test/cases/query_cache_test.rb +446 -446
  213. data/test/cases/quoting_test.rb +202 -202
  214. data/test/cases/readonly_test.rb +119 -119
  215. data/test/cases/reaper_test.rb +85 -85
  216. data/test/cases/reflection_test.rb +509 -509
  217. data/test/cases/relation/delegation_test.rb +63 -63
  218. data/test/cases/relation/merging_test.rb +157 -157
  219. data/test/cases/relation/mutation_test.rb +183 -183
  220. data/test/cases/relation/or_test.rb +92 -92
  221. data/test/cases/relation/predicate_builder_test.rb +16 -16
  222. data/test/cases/relation/record_fetch_warning_test.rb +40 -40
  223. data/test/cases/relation/where_chain_test.rb +105 -105
  224. data/test/cases/relation/where_clause_test.rb +182 -182
  225. data/test/cases/relation/where_test.rb +322 -322
  226. data/test/cases/relation_test.rb +328 -328
  227. data/test/cases/relations_test.rb +2026 -2026
  228. data/test/cases/reload_models_test.rb +22 -22
  229. data/test/cases/result_test.rb +90 -90
  230. data/test/cases/sanitize_test.rb +176 -176
  231. data/test/cases/schema_dumper_test.rb +457 -457
  232. data/test/cases/schema_loading_test.rb +52 -52
  233. data/test/cases/scoping/default_scoping_test.rb +528 -528
  234. data/test/cases/scoping/named_scoping_test.rb +561 -561
  235. data/test/cases/scoping/relation_scoping_test.rb +400 -400
  236. data/test/cases/secure_token_test.rb +32 -32
  237. data/test/cases/serialization_test.rb +104 -104
  238. data/test/cases/serialized_attribute_test.rb +364 -364
  239. data/test/cases/statement_cache_test.rb +136 -136
  240. data/test/cases/store_test.rb +195 -195
  241. data/test/cases/suppressor_test.rb +63 -63
  242. data/test/cases/tasks/database_tasks_test.rb +462 -462
  243. data/test/cases/tasks/mysql_rake_test.rb +345 -345
  244. data/test/cases/tasks/postgresql_rake_test.rb +304 -304
  245. data/test/cases/tasks/sqlite_rake_test.rb +220 -220
  246. data/test/cases/test_case.rb +131 -131
  247. data/test/cases/test_fixtures_test.rb +36 -36
  248. data/test/cases/time_precision_test.rb +103 -102
  249. data/test/cases/timestamp_test.rb +501 -501
  250. data/test/cases/touch_later_test.rb +121 -121
  251. data/test/cases/transaction_callbacks_test.rb +518 -518
  252. data/test/cases/transaction_isolation_test.rb +106 -106
  253. data/test/cases/transactions_test.rb +835 -834
  254. data/test/cases/type/adapter_specific_registry_test.rb +133 -133
  255. data/test/cases/type/date_time_test.rb +14 -14
  256. data/test/cases/type/integer_test.rb +27 -27
  257. data/test/cases/type/string_test.rb +22 -22
  258. data/test/cases/type/type_map_test.rb +177 -177
  259. data/test/cases/type_test.rb +39 -39
  260. data/test/cases/types_test.rb +24 -24
  261. data/test/cases/unconnected_test.rb +33 -33
  262. data/test/cases/validations/absence_validation_test.rb +73 -73
  263. data/test/cases/validations/association_validation_test.rb +97 -97
  264. data/test/cases/validations/i18n_generate_message_validation_test.rb +84 -84
  265. data/test/cases/validations/i18n_validation_test.rb +86 -86
  266. data/test/cases/validations/length_validation_test.rb +79 -79
  267. data/test/cases/validations/presence_validation_test.rb +103 -103
  268. data/test/cases/validations/uniqueness_validation_test.rb +548 -548
  269. data/test/cases/validations_repair_helper.rb +19 -19
  270. data/test/cases/validations_test.rb +194 -194
  271. data/test/cases/view_test.rb +216 -216
  272. data/test/cases/yaml_serialization_test.rb +121 -121
  273. data/test/config.example.yml +97 -97
  274. data/test/config.rb +5 -5
  275. data/test/connections/native_ibm_db/connection.rb +44 -0
  276. data/test/fixtures/accounts.yml +29 -29
  277. data/test/fixtures/admin/accounts.yml +2 -2
  278. data/test/fixtures/admin/users.yml +10 -10
  279. data/test/fixtures/author_addresses.yml +17 -17
  280. data/test/fixtures/author_favorites.yml +3 -3
  281. data/test/fixtures/authors.yml +23 -23
  282. data/test/fixtures/bad_posts.yml +9 -9
  283. data/test/fixtures/binaries.yml +133 -133
  284. data/test/fixtures/books.yml +31 -31
  285. data/test/fixtures/bulbs.yml +5 -5
  286. data/test/fixtures/cars.yml +9 -9
  287. data/test/fixtures/categories.yml +19 -19
  288. data/test/fixtures/categories/special_categories.yml +9 -9
  289. data/test/fixtures/categories/subsubdir/arbitrary_filename.yml +4 -4
  290. data/test/fixtures/categories_ordered.yml +7 -7
  291. data/test/fixtures/categories_posts.yml +31 -31
  292. data/test/fixtures/categorizations.yml +23 -23
  293. data/test/fixtures/clubs.yml +8 -8
  294. data/test/fixtures/collections.yml +3 -3
  295. data/test/fixtures/colleges.yml +3 -3
  296. data/test/fixtures/comments.yml +65 -65
  297. data/test/fixtures/companies.yml +67 -67
  298. data/test/fixtures/computers.yml +10 -10
  299. data/test/fixtures/content.yml +3 -3
  300. data/test/fixtures/content_positions.yml +3 -3
  301. data/test/fixtures/courses.yml +8 -8
  302. data/test/fixtures/customers.yml +25 -25
  303. data/test/fixtures/dashboards.yml +6 -6
  304. data/test/fixtures/dead_parrots.yml +5 -5
  305. data/test/fixtures/developers.yml +22 -22
  306. data/test/fixtures/developers_projects.yml +16 -16
  307. data/test/fixtures/dog_lovers.yml +7 -7
  308. data/test/fixtures/dogs.yml +4 -4
  309. data/test/fixtures/doubloons.yml +3 -3
  310. data/test/fixtures/edges.yml +5 -5
  311. data/test/fixtures/entrants.yml +14 -14
  312. data/test/fixtures/essays.yml +6 -6
  313. data/test/fixtures/faces.yml +11 -11
  314. data/test/fixtures/fk_test_has_fk.yml +3 -3
  315. data/test/fixtures/fk_test_has_pk.yml +1 -1
  316. data/test/fixtures/friendships.yml +4 -4
  317. data/test/fixtures/funny_jokes.yml +10 -10
  318. data/test/fixtures/interests.yml +33 -33
  319. data/test/fixtures/items.yml +3 -3
  320. data/test/fixtures/jobs.yml +7 -7
  321. data/test/fixtures/legacy_things.yml +3 -3
  322. data/test/fixtures/live_parrots.yml +4 -4
  323. data/test/fixtures/mateys.yml +4 -4
  324. data/test/fixtures/member_details.yml +8 -8
  325. data/test/fixtures/member_types.yml +6 -6
  326. data/test/fixtures/members.yml +11 -11
  327. data/test/fixtures/memberships.yml +34 -34
  328. data/test/fixtures/men.yml +5 -5
  329. data/test/fixtures/minimalistics.yml +2 -2
  330. data/test/fixtures/minivans.yml +5 -5
  331. data/test/fixtures/mixed_case_monkeys.yml +6 -6
  332. data/test/fixtures/mixins.yml +29 -29
  333. data/test/fixtures/movies.yml +7 -7
  334. data/test/fixtures/naked/yml/accounts.yml +1 -1
  335. data/test/fixtures/naked/yml/companies.yml +1 -1
  336. data/test/fixtures/naked/yml/courses.yml +1 -1
  337. data/test/fixtures/naked/yml/parrots.yml +2 -2
  338. data/test/fixtures/naked/yml/trees.yml +3 -3
  339. data/test/fixtures/nodes.yml +29 -29
  340. data/test/fixtures/organizations.yml +5 -5
  341. data/test/fixtures/other_comments.yml +6 -6
  342. data/test/fixtures/other_dogs.yml +2 -2
  343. data/test/fixtures/other_posts.yml +7 -7
  344. data/test/fixtures/other_topics.yml +42 -42
  345. data/test/fixtures/owners.yml +9 -9
  346. data/test/fixtures/parrots.yml +27 -27
  347. data/test/fixtures/parrots_pirates.yml +7 -7
  348. data/test/fixtures/people.yml +24 -24
  349. data/test/fixtures/peoples_treasures.yml +3 -3
  350. data/test/fixtures/pets.yml +19 -19
  351. data/test/fixtures/pirates.yml +12 -15
  352. data/test/fixtures/posts.yml +80 -80
  353. data/test/fixtures/price_estimates.yml +16 -16
  354. data/test/fixtures/products.yml +4 -4
  355. data/test/fixtures/projects.yml +7 -7
  356. data/test/fixtures/ratings.yml +14 -14
  357. data/test/fixtures/readers.yml +11 -11
  358. data/test/fixtures/references.yml +17 -17
  359. data/test/fixtures/reserved_words/distinct.yml +5 -5
  360. data/test/fixtures/reserved_words/distinct_select.yml +11 -11
  361. data/test/fixtures/reserved_words/group.yml +14 -14
  362. data/test/fixtures/reserved_words/select.yml +8 -8
  363. data/test/fixtures/reserved_words/values.yml +7 -7
  364. data/test/fixtures/ships.yml +6 -6
  365. data/test/fixtures/speedometers.yml +8 -8
  366. data/test/fixtures/sponsors.yml +12 -12
  367. data/test/fixtures/string_key_objects.yml +7 -7
  368. data/test/fixtures/subscribers.yml +10 -10
  369. data/test/fixtures/subscriptions.yml +12 -12
  370. data/test/fixtures/taggings.yml +78 -78
  371. data/test/fixtures/tags.yml +11 -11
  372. data/test/fixtures/tasks.yml +7 -7
  373. data/test/fixtures/teapots.yml +3 -3
  374. data/test/fixtures/to_be_linked/accounts.yml +2 -2
  375. data/test/fixtures/to_be_linked/users.yml +10 -10
  376. data/test/fixtures/topics.yml +49 -49
  377. data/test/fixtures/toys.yml +14 -14
  378. data/test/fixtures/traffic_lights.yml +9 -9
  379. data/test/fixtures/treasures.yml +10 -10
  380. data/test/fixtures/trees.yml +3 -3
  381. data/test/fixtures/uuid_children.yml +3 -3
  382. data/test/fixtures/uuid_parents.yml +2 -2
  383. data/test/fixtures/variants.yml +4 -4
  384. data/test/fixtures/vegetables.yml +19 -19
  385. data/test/fixtures/vertices.yml +3 -3
  386. data/test/fixtures/warehouse_things.yml +2 -2
  387. data/test/fixtures/zines.yml +5 -5
  388. data/test/migrations/10_urban/9_add_expressions.rb +11 -11
  389. data/test/migrations/decimal/1_give_me_big_numbers.rb +15 -15
  390. data/test/migrations/magic/1_currencies_have_symbols.rb +12 -12
  391. data/test/migrations/missing/1000_people_have_middle_names.rb +9 -9
  392. data/test/migrations/missing/1_people_have_last_names.rb +9 -9
  393. data/test/migrations/missing/3_we_need_reminders.rb +12 -12
  394. data/test/migrations/missing/4_innocent_jointable.rb +12 -12
  395. data/test/migrations/rename/1_we_need_things.rb +11 -11
  396. data/test/migrations/rename/2_rename_things.rb +9 -9
  397. data/test/migrations/to_copy/1_people_have_hobbies.rb +9 -9
  398. data/test/migrations/to_copy/2_people_have_descriptions.rb +9 -9
  399. data/test/migrations/to_copy2/1_create_articles.rb +7 -7
  400. data/test/migrations/to_copy2/2_create_comments.rb +7 -7
  401. data/test/migrations/to_copy_with_name_collision/1_people_have_hobbies.rb +9 -9
  402. data/test/migrations/to_copy_with_timestamps/20090101010101_people_have_hobbies.rb +9 -9
  403. data/test/migrations/to_copy_with_timestamps/20090101010202_people_have_descriptions.rb +9 -9
  404. data/test/migrations/to_copy_with_timestamps2/20090101010101_create_articles.rb +7 -7
  405. data/test/migrations/to_copy_with_timestamps2/20090101010202_create_comments.rb +7 -7
  406. data/test/migrations/valid/1_valid_people_have_last_names.rb +9 -9
  407. data/test/migrations/valid/2_we_need_reminders.rb +12 -12
  408. data/test/migrations/valid/3_innocent_jointable.rb +12 -12
  409. data/test/migrations/valid_with_subdirectories/1_valid_people_have_last_names.rb +9 -9
  410. data/test/migrations/valid_with_subdirectories/sub/2_we_need_reminders.rb +12 -12
  411. data/test/migrations/valid_with_subdirectories/sub1/3_innocent_jointable.rb +12 -12
  412. data/test/migrations/valid_with_timestamps/20100101010101_valid_with_timestamps_people_have_last_names.rb +9 -9
  413. data/test/migrations/valid_with_timestamps/20100201010101_valid_with_timestamps_we_need_reminders.rb +12 -12
  414. data/test/migrations/valid_with_timestamps/20100301010101_valid_with_timestamps_innocent_jointable.rb +12 -12
  415. data/test/migrations/version_check/20131219224947_migration_version_check.rb +8 -8
  416. data/test/models/admin.rb +5 -5
  417. data/test/models/admin/account.rb +3 -3
  418. data/test/models/admin/user.rb +40 -40
  419. data/test/models/aircraft.rb +5 -5
  420. data/test/models/arunit2_model.rb +3 -3
  421. data/test/models/author.rb +209 -209
  422. data/test/models/auto_id.rb +4 -4
  423. data/test/models/autoloadable/extra_firm.rb +2 -2
  424. data/test/models/binary.rb +2 -2
  425. data/test/models/bird.rb +12 -12
  426. data/test/models/book.rb +23 -23
  427. data/test/models/boolean.rb +2 -2
  428. data/test/models/bulb.rb +52 -52
  429. data/test/models/cake_designer.rb +3 -3
  430. data/test/models/car.rb +29 -29
  431. data/test/models/carrier.rb +2 -2
  432. data/test/models/cat.rb +10 -10
  433. data/test/models/categorization.rb +19 -19
  434. data/test/models/category.rb +35 -35
  435. data/test/models/chef.rb +8 -8
  436. data/test/models/citation.rb +3 -3
  437. data/test/models/club.rb +25 -25
  438. data/test/models/college.rb +10 -10
  439. data/test/models/column.rb +3 -3
  440. data/test/models/column_name.rb +3 -3
  441. data/test/models/comment.rb +76 -76
  442. data/test/models/company.rb +230 -230
  443. data/test/models/company_in_module.rb +98 -98
  444. data/test/models/computer.rb +3 -3
  445. data/test/models/contact.rb +41 -41
  446. data/test/models/content.rb +40 -40
  447. data/test/models/contract.rb +20 -20
  448. data/test/models/country.rb +7 -7
  449. data/test/models/course.rb +6 -6
  450. data/test/models/customer.rb +83 -83
  451. data/test/models/customer_carrier.rb +14 -14
  452. data/test/models/dashboard.rb +3 -3
  453. data/test/models/default.rb +2 -2
  454. data/test/models/department.rb +4 -4
  455. data/test/models/developer.rb +274 -274
  456. data/test/models/dog.rb +5 -5
  457. data/test/models/dog_lover.rb +5 -5
  458. data/test/models/doubloon.rb +12 -12
  459. data/test/models/drink_designer.rb +3 -3
  460. data/test/models/edge.rb +5 -5
  461. data/test/models/electron.rb +5 -5
  462. data/test/models/engine.rb +4 -4
  463. data/test/models/entrant.rb +3 -3
  464. data/test/models/essay.rb +5 -5
  465. data/test/models/event.rb +3 -3
  466. data/test/models/eye.rb +37 -37
  467. data/test/models/face.rb +9 -9
  468. data/test/models/friendship.rb +6 -6
  469. data/test/models/guid.rb +2 -2
  470. data/test/models/guitar.rb +4 -4
  471. data/test/models/hotel.rb +11 -11
  472. data/test/models/image.rb +3 -3
  473. data/test/models/interest.rb +5 -5
  474. data/test/models/invoice.rb +4 -4
  475. data/test/models/item.rb +7 -7
  476. data/test/models/job.rb +7 -7
  477. data/test/models/joke.rb +7 -7
  478. data/test/models/keyboard.rb +3 -3
  479. data/test/models/legacy_thing.rb +3 -3
  480. data/test/models/lesson.rb +11 -11
  481. data/test/models/line_item.rb +3 -3
  482. data/test/models/liquid.rb +4 -4
  483. data/test/models/man.rb +11 -11
  484. data/test/models/matey.rb +4 -4
  485. data/test/models/member.rb +42 -42
  486. data/test/models/member_detail.rb +8 -8
  487. data/test/models/member_type.rb +3 -3
  488. data/test/models/membership.rb +35 -35
  489. data/test/models/mentor.rb +2 -2
  490. data/test/models/minimalistic.rb +2 -2
  491. data/test/models/minivan.rb +9 -9
  492. data/test/models/mixed_case_monkey.rb +3 -3
  493. data/test/models/mocktail_designer.rb +2 -2
  494. data/test/models/molecule.rb +6 -6
  495. data/test/models/movie.rb +5 -5
  496. data/test/models/node.rb +5 -5
  497. data/test/models/non_primary_key.rb +2 -2
  498. data/test/models/notification.rb +3 -3
  499. data/test/models/order.rb +4 -4
  500. data/test/models/organization.rb +14 -14
  501. data/test/models/other_dog.rb +5 -5
  502. data/test/models/owner.rb +37 -37
  503. data/test/models/parrot.rb +28 -28
  504. data/test/models/person.rb +142 -142
  505. data/test/models/personal_legacy_thing.rb +4 -4
  506. data/test/models/pet.rb +18 -18
  507. data/test/models/pet_treasure.rb +6 -6
  508. data/test/models/pirate.rb +92 -92
  509. data/test/models/possession.rb +3 -3
  510. data/test/models/post.rb +273 -273
  511. data/test/models/price_estimate.rb +4 -4
  512. data/test/models/professor.rb +5 -5
  513. data/test/models/project.rb +40 -40
  514. data/test/models/publisher.rb +2 -2
  515. data/test/models/publisher/article.rb +4 -4
  516. data/test/models/publisher/magazine.rb +3 -3
  517. data/test/models/rating.rb +4 -4
  518. data/test/models/reader.rb +23 -23
  519. data/test/models/recipe.rb +3 -3
  520. data/test/models/record.rb +2 -2
  521. data/test/models/reference.rb +22 -22
  522. data/test/models/reply.rb +61 -61
  523. data/test/models/ship.rb +39 -39
  524. data/test/models/ship_part.rb +8 -8
  525. data/test/models/shop.rb +17 -17
  526. data/test/models/shop_account.rb +6 -6
  527. data/test/models/speedometer.rb +6 -6
  528. data/test/models/sponsor.rb +7 -7
  529. data/test/models/string_key_object.rb +3 -3
  530. data/test/models/student.rb +4 -4
  531. data/test/models/subject.rb +16 -16
  532. data/test/models/subscriber.rb +8 -8
  533. data/test/models/subscription.rb +4 -4
  534. data/test/models/tag.rb +13 -13
  535. data/test/models/tagging.rb +13 -13
  536. data/test/models/task.rb +5 -5
  537. data/test/models/topic.rb +118 -118
  538. data/test/models/toy.rb +6 -6
  539. data/test/models/traffic_light.rb +4 -4
  540. data/test/models/treasure.rb +14 -14
  541. data/test/models/treaty.rb +7 -7
  542. data/test/models/tree.rb +3 -3
  543. data/test/models/tuning_peg.rb +4 -4
  544. data/test/models/tyre.rb +11 -11
  545. data/test/models/user.rb +14 -14
  546. data/test/models/uuid_child.rb +3 -3
  547. data/test/models/uuid_item.rb +6 -6
  548. data/test/models/uuid_parent.rb +3 -3
  549. data/test/models/vegetables.rb +24 -24
  550. data/test/models/vehicle.rb +6 -6
  551. data/test/models/vertex.rb +9 -9
  552. data/test/models/warehouse_thing.rb +5 -5
  553. data/test/models/wheel.rb +3 -3
  554. data/test/models/without_table.rb +3 -3
  555. data/test/models/zine.rb +3 -3
  556. data/test/schema/i5/ibm_db_specific_schema.rb +137 -0
  557. data/test/schema/ids/ibm_db_specific_schema.rb +140 -0
  558. data/test/schema/luw/ibm_db_specific_schema.rb +137 -0
  559. data/test/schema/mysql2_specific_schema.rb +68 -68
  560. data/test/schema/oracle_specific_schema.rb +40 -40
  561. data/test/schema/postgresql_specific_schema.rb +114 -114
  562. data/test/schema/schema.rb +1057 -1057
  563. data/test/schema/schema.rb.original +1057 -1057
  564. data/test/schema/sqlite_specific_schema.rb +18 -18
  565. data/test/schema/zOS/ibm_db_specific_schema.rb +208 -0
  566. data/test/support/config.rb +43 -43
  567. data/test/support/connection.rb +23 -23
  568. data/test/support/connection_helper.rb +14 -14
  569. data/test/support/ddl_helper.rb +8 -8
  570. data/test/support/schema_dumping_helper.rb +20 -20
  571. data/test/support/yaml_compatibility_fixtures/rails_4_1.yml +22 -22
  572. data/test/support/yaml_compatibility_fixtures/rails_4_2_0.yml +182 -182
  573. metadata +30 -14
  574. data/lib/mswin32/rb2x/i386/ibm_db.so +0 -0
  575. data/test/fixtures/author_addresses.original +0 -11
  576. data/test/fixtures/authors.original +0 -17
@@ -1,85 +1,85 @@
1
- require "cases/helper"
2
-
3
- module ActiveRecord
4
- module ConnectionAdapters
5
- class ReaperTest < ActiveRecord::TestCase
6
- attr_reader :pool
7
-
8
- def setup
9
- super
10
- @pool = ConnectionPool.new ActiveRecord::Base.connection_pool.spec
11
- end
12
-
13
- teardown do
14
- @pool.connections.each(&:close)
15
- end
16
-
17
- class FakePool
18
- attr_reader :reaped
19
-
20
- def initialize
21
- @reaped = false
22
- end
23
-
24
- def reap
25
- @reaped = true
26
- end
27
- end
28
-
29
- # A reaper with nil time should never reap connections
30
- def test_nil_time
31
- fp = FakePool.new
32
- assert !fp.reaped
33
- reaper = ConnectionPool::Reaper.new(fp, nil)
34
- reaper.run
35
- assert !fp.reaped
36
- end
37
-
38
- def test_some_time
39
- fp = FakePool.new
40
- assert !fp.reaped
41
-
42
- reaper = ConnectionPool::Reaper.new(fp, 0.0001)
43
- reaper.run
44
- until fp.reaped
45
- Thread.pass
46
- end
47
- assert fp.reaped
48
- end
49
-
50
- def test_pool_has_reaper
51
- assert pool.reaper
52
- end
53
-
54
- def test_reaping_frequency_configuration
55
- spec = ActiveRecord::Base.connection_pool.spec.dup
56
- spec.config[:reaping_frequency] = 100
57
- pool = ConnectionPool.new spec
58
- assert_equal 100, pool.reaper.frequency
59
- end
60
-
61
- def test_connection_pool_starts_reaper
62
- spec = ActiveRecord::Base.connection_pool.spec.dup
63
- spec.config[:reaping_frequency] = '0.0001'
64
-
65
- pool = ConnectionPool.new spec
66
-
67
- conn = nil
68
- child = Thread.new do
69
- conn = pool.checkout
70
- Thread.stop
71
- end
72
- Thread.pass while conn.nil?
73
-
74
- assert conn.in_use?
75
-
76
- child.terminate
77
-
78
- while conn.in_use?
79
- Thread.pass
80
- end
81
- assert !conn.in_use?
82
- end
83
- end
84
- end
85
- end
1
+ require "cases/helper"
2
+
3
+ module ActiveRecord
4
+ module ConnectionAdapters
5
+ class ReaperTest < ActiveRecord::TestCase
6
+ attr_reader :pool
7
+
8
+ def setup
9
+ super
10
+ @pool = ConnectionPool.new ActiveRecord::Base.connection_pool.spec
11
+ end
12
+
13
+ teardown do
14
+ @pool.connections.each(&:close)
15
+ end
16
+
17
+ class FakePool
18
+ attr_reader :reaped
19
+
20
+ def initialize
21
+ @reaped = false
22
+ end
23
+
24
+ def reap
25
+ @reaped = true
26
+ end
27
+ end
28
+
29
+ # A reaper with nil time should never reap connections
30
+ def test_nil_time
31
+ fp = FakePool.new
32
+ assert !fp.reaped
33
+ reaper = ConnectionPool::Reaper.new(fp, nil)
34
+ reaper.run
35
+ assert !fp.reaped
36
+ end
37
+
38
+ def test_some_time
39
+ fp = FakePool.new
40
+ assert !fp.reaped
41
+
42
+ reaper = ConnectionPool::Reaper.new(fp, 0.0001)
43
+ reaper.run
44
+ until fp.reaped
45
+ Thread.pass
46
+ end
47
+ assert fp.reaped
48
+ end
49
+
50
+ def test_pool_has_reaper
51
+ assert pool.reaper
52
+ end
53
+
54
+ def test_reaping_frequency_configuration
55
+ spec = ActiveRecord::Base.connection_pool.spec.dup
56
+ spec.config[:reaping_frequency] = 100
57
+ pool = ConnectionPool.new spec
58
+ assert_equal 100, pool.reaper.frequency
59
+ end
60
+
61
+ def test_connection_pool_starts_reaper
62
+ spec = ActiveRecord::Base.connection_pool.spec.dup
63
+ spec.config[:reaping_frequency] = '0.0001'
64
+
65
+ pool = ConnectionPool.new spec
66
+
67
+ conn = nil
68
+ child = Thread.new do
69
+ conn = pool.checkout
70
+ Thread.stop
71
+ end
72
+ Thread.pass while conn.nil?
73
+
74
+ assert conn.in_use?
75
+
76
+ child.terminate
77
+
78
+ while conn.in_use?
79
+ Thread.pass
80
+ end
81
+ assert !conn.in_use?
82
+ end
83
+ end
84
+ end
85
+ end
@@ -1,509 +1,509 @@
1
- require "cases/helper"
2
- require 'models/topic'
3
- require 'models/customer'
4
- require 'models/company'
5
- require 'models/company_in_module'
6
- require 'models/ship'
7
- require 'models/pirate'
8
- require 'models/price_estimate'
9
- require 'models/essay'
10
- require 'models/author'
11
- require 'models/organization'
12
- require 'models/post'
13
- require 'models/tagging'
14
- require 'models/category'
15
- require 'models/book'
16
- require 'models/subscriber'
17
- require 'models/subscription'
18
- require 'models/tag'
19
- require 'models/sponsor'
20
- require 'models/edge'
21
- require 'models/hotel'
22
- require 'models/chef'
23
- require 'models/department'
24
- require 'models/cake_designer'
25
- require 'models/drink_designer'
26
- require 'models/mocktail_designer'
27
- require 'models/recipe'
28
-
29
- class ReflectionTest < ActiveRecord::TestCase
30
- include ActiveRecord::Reflection
31
-
32
- fixtures :topics, :customers, :companies, :subscribers, :price_estimates
33
-
34
- def setup
35
- @first = Topic.find(1)
36
- end
37
-
38
- def test_human_name
39
- assert_equal "Price estimate", PriceEstimate.model_name.human
40
- assert_equal "Subscriber", Subscriber.model_name.human
41
- end
42
-
43
- def test_read_attribute_names
44
- assert_equal(
45
- %w( id title author_name author_email_address bonus_time written_on last_read content important group approved replies_count unique_replies_count parent_id parent_title type created_at updated_at ).sort,
46
- @first.attribute_names.sort
47
- )
48
- end
49
-
50
- def test_columns
51
- assert_equal 18, Topic.columns.length
52
- end
53
-
54
- def test_columns_are_returned_in_the_order_they_were_declared
55
- column_names = Topic.columns.map(&:name)
56
- assert_equal %w(id title author_name author_email_address written_on bonus_time last_read content important approved replies_count unique_replies_count parent_id parent_title type group created_at updated_at), column_names
57
- end
58
-
59
- def test_content_columns
60
- content_columns = Topic.content_columns
61
- content_column_names = content_columns.map(&:name)
62
- assert_equal 13, content_columns.length
63
- assert_equal %w(title author_name author_email_address written_on bonus_time last_read content important group approved parent_title created_at updated_at).sort, content_column_names.sort
64
- end
65
-
66
- def test_column_string_type_and_limit
67
- assert_equal :string, @first.column_for_attribute("title").type
68
- assert_equal 250, @first.column_for_attribute("title").limit
69
- end
70
-
71
- def test_column_null_not_null
72
- subscriber = Subscriber.first
73
- assert subscriber.column_for_attribute("name").null
74
- assert !subscriber.column_for_attribute("nick").null
75
- end
76
-
77
- def test_human_name_for_column
78
- assert_equal "Author name", @first.column_for_attribute("author_name").human_name
79
- end
80
-
81
- def test_integer_columns
82
- assert_equal :integer, @first.column_for_attribute("id").type
83
- end
84
-
85
- def test_non_existent_columns_return_null_object
86
- column = @first.column_for_attribute("attribute_that_doesnt_exist")
87
- assert_instance_of ActiveRecord::ConnectionAdapters::NullColumn, column
88
- assert_equal "attribute_that_doesnt_exist", column.name
89
- assert_equal nil, column.sql_type
90
- assert_equal nil, column.type
91
- end
92
-
93
- def test_non_existent_types_are_identity_types
94
- type = @first.type_for_attribute("attribute_that_doesnt_exist")
95
- object = Object.new
96
-
97
- assert_equal object, type.deserialize(object)
98
- assert_equal object, type.cast(object)
99
- assert_equal object, type.serialize(object)
100
- end
101
-
102
- def test_reflection_klass_for_nested_class_name
103
- reflection = ActiveRecord::Reflection.create(:has_many, nil, nil, { :class_name => 'MyApplication::Business::Company' }, ActiveRecord::Base)
104
- assert_nothing_raised do
105
- assert_equal MyApplication::Business::Company, reflection.klass
106
- end
107
- end
108
-
109
- def test_irregular_reflection_class_name
110
- ActiveSupport::Inflector.inflections do |inflect|
111
- inflect.irregular 'plural_irregular', 'plurales_irregulares'
112
- end
113
- reflection = ActiveRecord::Reflection.create(:has_many, 'plurales_irregulares', nil, {}, ActiveRecord::Base)
114
- assert_equal 'PluralIrregular', reflection.class_name
115
- end
116
-
117
- def test_aggregation_reflection
118
- reflection_for_address = AggregateReflection.new(
119
- :address, nil, { :mapping => [ %w(address_street street), %w(address_city city), %w(address_country country) ] }, Customer
120
- )
121
-
122
- reflection_for_balance = AggregateReflection.new(
123
- :balance, nil, { :class_name => "Money", :mapping => %w(balance amount) }, Customer
124
- )
125
-
126
- reflection_for_gps_location = AggregateReflection.new(
127
- :gps_location, nil, { }, Customer
128
- )
129
-
130
- assert Customer.reflect_on_all_aggregations.include?(reflection_for_gps_location)
131
- assert Customer.reflect_on_all_aggregations.include?(reflection_for_balance)
132
- assert Customer.reflect_on_all_aggregations.include?(reflection_for_address)
133
-
134
- assert_equal reflection_for_address, Customer.reflect_on_aggregation(:address)
135
-
136
- assert_equal Address, Customer.reflect_on_aggregation(:address).klass
137
-
138
- assert_equal Money, Customer.reflect_on_aggregation(:balance).klass
139
- end
140
-
141
- def test_reflect_on_all_autosave_associations
142
- expected = Pirate.reflect_on_all_associations.select { |r| r.options[:autosave] }
143
- received = Pirate.reflect_on_all_autosave_associations
144
-
145
- assert !received.empty?
146
- assert_not_equal Pirate.reflect_on_all_associations.length, received.length
147
- assert_equal expected, received
148
- end
149
-
150
- def test_has_many_reflection
151
- reflection_for_clients = ActiveRecord::Reflection.create(:has_many, :clients, nil, { :order => "id", :dependent => :destroy }, Firm)
152
-
153
- assert_equal reflection_for_clients, Firm.reflect_on_association(:clients)
154
-
155
- assert_equal Client, Firm.reflect_on_association(:clients).klass
156
- assert_equal 'companies', Firm.reflect_on_association(:clients).table_name
157
-
158
- assert_equal Client, Firm.reflect_on_association(:clients_of_firm).klass
159
- assert_equal 'companies', Firm.reflect_on_association(:clients_of_firm).table_name
160
- end
161
-
162
- def test_has_one_reflection
163
- reflection_for_account = ActiveRecord::Reflection.create(:has_one, :account, nil, { :foreign_key => "firm_id", :dependent => :destroy }, Firm)
164
- assert_equal reflection_for_account, Firm.reflect_on_association(:account)
165
-
166
- assert_equal Account, Firm.reflect_on_association(:account).klass
167
- assert_equal 'accounts', Firm.reflect_on_association(:account).table_name
168
- end
169
-
170
- def test_belongs_to_inferred_foreign_key_from_assoc_name
171
- Company.belongs_to :foo
172
- assert_equal "foo_id", Company.reflect_on_association(:foo).foreign_key
173
- Company.belongs_to :bar, :class_name => "Xyzzy"
174
- assert_equal "bar_id", Company.reflect_on_association(:bar).foreign_key
175
- Company.belongs_to :baz, :class_name => "Xyzzy", :foreign_key => "xyzzy_id"
176
- assert_equal "xyzzy_id", Company.reflect_on_association(:baz).foreign_key
177
- end
178
-
179
- def test_association_reflection_in_modules
180
- ActiveRecord::Base.store_full_sti_class = false
181
-
182
- assert_reflection MyApplication::Business::Firm,
183
- :clients_of_firm,
184
- :klass => MyApplication::Business::Client,
185
- :class_name => 'Client',
186
- :table_name => 'companies'
187
-
188
- assert_reflection MyApplication::Billing::Account,
189
- :firm,
190
- :klass => MyApplication::Business::Firm,
191
- :class_name => 'MyApplication::Business::Firm',
192
- :table_name => 'companies'
193
-
194
- assert_reflection MyApplication::Billing::Account,
195
- :qualified_billing_firm,
196
- :klass => MyApplication::Billing::Firm,
197
- :class_name => 'MyApplication::Billing::Firm',
198
- :table_name => 'companies'
199
-
200
- assert_reflection MyApplication::Billing::Account,
201
- :unqualified_billing_firm,
202
- :klass => MyApplication::Billing::Firm,
203
- :class_name => 'Firm',
204
- :table_name => 'companies'
205
-
206
- assert_reflection MyApplication::Billing::Account,
207
- :nested_qualified_billing_firm,
208
- :klass => MyApplication::Billing::Nested::Firm,
209
- :class_name => 'MyApplication::Billing::Nested::Firm',
210
- :table_name => 'companies'
211
-
212
- assert_reflection MyApplication::Billing::Account,
213
- :nested_unqualified_billing_firm,
214
- :klass => MyApplication::Billing::Nested::Firm,
215
- :class_name => 'Nested::Firm',
216
- :table_name => 'companies'
217
- ensure
218
- ActiveRecord::Base.store_full_sti_class = true
219
- end
220
-
221
- def test_reflection_should_not_raise_error_when_compared_to_other_object
222
- assert_not_equal Object.new, Firm._reflections['clients']
223
- end
224
-
225
- def test_reflections_should_return_keys_as_strings
226
- assert Category.reflections.keys.all? { |key| key.is_a? String }, "Model.reflections is expected to return string for keys"
227
- end
228
-
229
- def test_has_and_belongs_to_many_reflection
230
- assert_equal :has_and_belongs_to_many, Category.reflections['posts'].macro
231
- assert_equal :posts, Category.reflect_on_all_associations(:has_and_belongs_to_many).first.name
232
- end
233
-
234
- def test_has_many_through_reflection
235
- assert_kind_of ThroughReflection, Subscriber.reflect_on_association(:books)
236
- end
237
-
238
- def test_chain
239
- expected = [
240
- Organization.reflect_on_association(:author_essay_categories),
241
- Author.reflect_on_association(:essays),
242
- Organization.reflect_on_association(:authors)
243
- ]
244
- actual = Organization.reflect_on_association(:author_essay_categories).chain
245
-
246
- assert_equal expected, actual
247
- end
248
-
249
- def test_scope_chain
250
- expected = [
251
- [Tagging.reflect_on_association(:tag).scope, Post.reflect_on_association(:first_blue_tags).scope],
252
- [Post.reflect_on_association(:first_taggings).scope],
253
- [Author.reflect_on_association(:misc_posts).scope]
254
- ]
255
- actual = Author.reflect_on_association(:misc_post_first_blue_tags).scope_chain
256
- assert_equal expected, actual
257
-
258
- expected = [
259
- [
260
- Tagging.reflect_on_association(:blue_tag).scope,
261
- Post.reflect_on_association(:first_blue_tags_2).scope,
262
- Author.reflect_on_association(:misc_post_first_blue_tags_2).scope
263
- ],
264
- [],
265
- []
266
- ]
267
- actual = Author.reflect_on_association(:misc_post_first_blue_tags_2).scope_chain
268
- assert_equal expected, actual
269
- end
270
-
271
- def test_scope_chain_does_not_interfere_with_hmt_with_polymorphic_case
272
- @hotel = Hotel.create!
273
- @department = @hotel.departments.create!
274
- @department.chefs.create!(employable: CakeDesigner.create!)
275
- @department.chefs.create!(employable: DrinkDesigner.create!)
276
-
277
- assert_equal 1, @hotel.cake_designers.size
278
- assert_equal 1, @hotel.drink_designers.size
279
- assert_equal 2, @hotel.chefs.size
280
- end
281
-
282
- def test_scope_chain_does_not_interfere_with_hmt_with_polymorphic_case_and_sti
283
- @hotel = Hotel.create!
284
- @hotel.mocktail_designers << MocktailDesigner.create!
285
-
286
- assert_equal 1, @hotel.mocktail_designers.size
287
- assert_equal 1, @hotel.mocktail_designers.count
288
- assert_equal 1, @hotel.chef_lists.size
289
- end
290
-
291
- def test_scope_chain_of_polymorphic_association_does_not_leak_into_other_hmt_associations
292
- hotel = Hotel.create!
293
- department = hotel.departments.create!
294
- drink = department.chefs.create!(employable: DrinkDesigner.create!)
295
- Recipe.create!(chef_id: drink.id, hotel_id: hotel.id)
296
-
297
- expected_sql = capture_sql { hotel.recipes.to_a }
298
-
299
- Hotel.reflect_on_association(:recipes).clear_association_scope_cache
300
- hotel.reload
301
- hotel.drink_designers.to_a
302
- loaded_sql = capture_sql { hotel.recipes.to_a }
303
-
304
- assert_equal expected_sql, loaded_sql
305
- end
306
-
307
- def test_nested?
308
- assert !Author.reflect_on_association(:comments).nested?
309
- assert Author.reflect_on_association(:tags).nested?
310
-
311
- # Only goes :through once, but the through_reflection is a has_and_belongs_to_many, so this is
312
- # a nested through association
313
- assert Category.reflect_on_association(:post_comments).nested?
314
- end
315
-
316
- def test_association_primary_key
317
- # Normal association
318
- assert_equal "id", Author.reflect_on_association(:posts).association_primary_key.to_s
319
- assert_equal "name", Author.reflect_on_association(:essay).association_primary_key.to_s
320
- assert_equal "name", Essay.reflect_on_association(:writer).association_primary_key.to_s
321
-
322
- # Through association (uses the :primary_key option from the source reflection)
323
- assert_equal "nick", Author.reflect_on_association(:subscribers).association_primary_key.to_s
324
- assert_equal "name", Author.reflect_on_association(:essay_category).association_primary_key.to_s
325
- assert_equal "custom_primary_key", Author.reflect_on_association(:tags_with_primary_key).association_primary_key.to_s # nested
326
- end
327
-
328
- def test_association_primary_key_type
329
- # Normal Association
330
- assert_equal :integer, Author.reflect_on_association(:posts).association_primary_key_type.type
331
- assert_equal :string, Author.reflect_on_association(:essay).association_primary_key_type.type
332
-
333
- # Through Association
334
- assert_equal :string, Author.reflect_on_association(:essay_category).association_primary_key_type.type
335
- end
336
-
337
- def test_association_primary_key_raises_when_missing_primary_key
338
- reflection = ActiveRecord::Reflection.create(:has_many, :edge, nil, {}, Author)
339
- assert_raises(ActiveRecord::UnknownPrimaryKey) { reflection.association_primary_key }
340
-
341
- through = Class.new(ActiveRecord::Reflection::ThroughReflection) {
342
- define_method(:source_reflection) { reflection }
343
- }.new(reflection)
344
- assert_raises(ActiveRecord::UnknownPrimaryKey) { through.association_primary_key }
345
- end
346
-
347
- def test_active_record_primary_key
348
- assert_equal "nick", Subscriber.reflect_on_association(:subscriptions).active_record_primary_key.to_s
349
- assert_equal "name", Author.reflect_on_association(:essay).active_record_primary_key.to_s
350
- end
351
-
352
- def test_active_record_primary_key_raises_when_missing_primary_key
353
- reflection = ActiveRecord::Reflection.create(:has_many, :author, nil, {}, Edge)
354
- assert_raises(ActiveRecord::UnknownPrimaryKey) { reflection.active_record_primary_key }
355
- end
356
-
357
- def test_foreign_type
358
- assert_equal "sponsorable_type", Sponsor.reflect_on_association(:sponsorable).foreign_type.to_s
359
- assert_equal "sponsorable_type", Sponsor.reflect_on_association(:thing).foreign_type.to_s
360
- end
361
-
362
- def test_collection_association
363
- assert Pirate.reflect_on_association(:birds).collection?
364
- assert Pirate.reflect_on_association(:parrots).collection?
365
-
366
- assert !Pirate.reflect_on_association(:ship).collection?
367
- assert !Ship.reflect_on_association(:pirate).collection?
368
- end
369
-
370
- def test_default_association_validation
371
- assert ActiveRecord::Reflection.create(:has_many, :clients, nil, {}, Firm).validate?
372
-
373
- assert !ActiveRecord::Reflection.create(:has_one, :client, nil, {}, Firm).validate?
374
- assert !ActiveRecord::Reflection.create(:belongs_to, :client, nil, {}, Firm).validate?
375
- end
376
-
377
- def test_always_validate_association_if_explicit
378
- assert ActiveRecord::Reflection.create(:has_one, :client, nil, { :validate => true }, Firm).validate?
379
- assert ActiveRecord::Reflection.create(:belongs_to, :client, nil, { :validate => true }, Firm).validate?
380
- assert ActiveRecord::Reflection.create(:has_many, :clients, nil, { :validate => true }, Firm).validate?
381
- end
382
-
383
- def test_validate_association_if_autosave
384
- assert ActiveRecord::Reflection.create(:has_one, :client, nil, { :autosave => true }, Firm).validate?
385
- assert ActiveRecord::Reflection.create(:belongs_to, :client, nil, { :autosave => true }, Firm).validate?
386
- assert ActiveRecord::Reflection.create(:has_many, :clients, nil, { :autosave => true }, Firm).validate?
387
- end
388
-
389
- def test_never_validate_association_if_explicit
390
- assert !ActiveRecord::Reflection.create(:has_one, :client, nil, { :autosave => true, :validate => false }, Firm).validate?
391
- assert !ActiveRecord::Reflection.create(:belongs_to, :client, nil, { :autosave => true, :validate => false }, Firm).validate?
392
- assert !ActiveRecord::Reflection.create(:has_many, :clients, nil, { :autosave => true, :validate => false }, Firm).validate?
393
- end
394
-
395
- def test_foreign_key
396
- assert_equal "author_id", Author.reflect_on_association(:posts).foreign_key.to_s
397
- assert_equal "category_id", Post.reflect_on_association(:categorizations).foreign_key.to_s
398
- end
399
-
400
- def test_through_reflection_scope_chain_does_not_modify_other_reflections
401
- orig_conds = Post.reflect_on_association(:first_blue_tags_2).scope_chain.inspect
402
- Author.reflect_on_association(:misc_post_first_blue_tags_2).scope_chain
403
- assert_equal orig_conds, Post.reflect_on_association(:first_blue_tags_2).scope_chain.inspect
404
- end
405
-
406
- def test_symbol_for_class_name
407
- assert_equal Client, Firm.reflect_on_association(:unsorted_clients_with_symbol).klass
408
- end
409
-
410
- def test_join_table
411
- category = Struct.new(:table_name, :pluralize_table_names).new('categories', true)
412
- product = Struct.new(:table_name, :pluralize_table_names).new('products', true)
413
-
414
- reflection = ActiveRecord::Reflection.create(:has_many, :categories, nil, {}, product)
415
- reflection.stub(:klass, category) do
416
- assert_equal 'categories_products', reflection.join_table
417
- end
418
-
419
- reflection = ActiveRecord::Reflection.create(:has_many, :products, nil, {}, category)
420
- reflection.stub(:klass, product) do
421
- assert_equal 'categories_products', reflection.join_table
422
- end
423
- end
424
-
425
- def test_join_table_with_common_prefix
426
- category = Struct.new(:table_name, :pluralize_table_names).new('catalog_categories', true)
427
- product = Struct.new(:table_name, :pluralize_table_names).new('catalog_products', true)
428
-
429
- reflection = ActiveRecord::Reflection.create(:has_many, :categories, nil, {}, product)
430
- reflection.stub(:klass, category) do
431
- assert_equal 'catalog_categories_products', reflection.join_table
432
- end
433
-
434
- reflection = ActiveRecord::Reflection.create(:has_many, :products, nil, {}, category)
435
- reflection.stub(:klass, product) do
436
- assert_equal 'catalog_categories_products', reflection.join_table
437
- end
438
- end
439
-
440
- def test_join_table_with_different_prefix
441
- category = Struct.new(:table_name, :pluralize_table_names).new('catalog_categories', true)
442
- page = Struct.new(:table_name, :pluralize_table_names).new('content_pages', true)
443
-
444
- reflection = ActiveRecord::Reflection.create(:has_many, :categories, nil, {}, page)
445
- reflection.stub(:klass, category) do
446
- assert_equal 'catalog_categories_content_pages', reflection.join_table
447
- end
448
-
449
- reflection = ActiveRecord::Reflection.create(:has_many, :pages, nil, {}, category)
450
- reflection.stub(:klass, page) do
451
- assert_equal 'catalog_categories_content_pages', reflection.join_table
452
- end
453
- end
454
-
455
- def test_join_table_can_be_overridden
456
- category = Struct.new(:table_name, :pluralize_table_names).new('categories', true)
457
- product = Struct.new(:table_name, :pluralize_table_names).new('products', true)
458
-
459
- reflection = ActiveRecord::Reflection.create(:has_many, :categories, nil, { :join_table => 'product_categories' }, product)
460
- reflection.stub(:klass, category) do
461
- assert_equal 'product_categories', reflection.join_table
462
- end
463
-
464
- reflection = ActiveRecord::Reflection.create(:has_many, :products, nil, { :join_table => 'product_categories' }, category)
465
- reflection.stub(:klass, product) do
466
- assert_equal 'product_categories', reflection.join_table
467
- end
468
- end
469
-
470
- def test_includes_accepts_symbols
471
- hotel = Hotel.create!
472
- department = hotel.departments.create!
473
- department.chefs.create!
474
-
475
- assert_nothing_raised do
476
- assert_equal department.chefs, Hotel.includes([departments: :chefs]).first.chefs
477
- end
478
- end
479
-
480
- def test_includes_accepts_strings
481
- hotel = Hotel.create!
482
- department = hotel.departments.create!
483
- department.chefs.create!
484
-
485
- assert_nothing_raised do
486
- assert_equal department.chefs, Hotel.includes(['departments' => 'chefs']).first.chefs
487
- end
488
- end
489
-
490
- def test_reflect_on_association_accepts_symbols
491
- assert_nothing_raised do
492
- assert_equal Hotel.reflect_on_association(:departments).name, :departments
493
- end
494
- end
495
-
496
- def test_reflect_on_association_accepts_strings
497
- assert_nothing_raised do
498
- assert_equal Hotel.reflect_on_association("departments").name, :departments
499
- end
500
- end
501
-
502
- private
503
- def assert_reflection(klass, association, options)
504
- assert reflection = klass.reflect_on_association(association)
505
- options.each do |method, value|
506
- assert_equal(value, reflection.send(method))
507
- end
508
- end
509
- end
1
+ require "cases/helper"
2
+ require 'models/topic'
3
+ require 'models/customer'
4
+ require 'models/company'
5
+ require 'models/company_in_module'
6
+ require 'models/ship'
7
+ require 'models/pirate'
8
+ require 'models/price_estimate'
9
+ require 'models/essay'
10
+ require 'models/author'
11
+ require 'models/organization'
12
+ require 'models/post'
13
+ require 'models/tagging'
14
+ require 'models/category'
15
+ require 'models/book'
16
+ require 'models/subscriber'
17
+ require 'models/subscription'
18
+ require 'models/tag'
19
+ require 'models/sponsor'
20
+ require 'models/edge'
21
+ require 'models/hotel'
22
+ require 'models/chef'
23
+ require 'models/department'
24
+ require 'models/cake_designer'
25
+ require 'models/drink_designer'
26
+ require 'models/mocktail_designer'
27
+ require 'models/recipe'
28
+
29
+ class ReflectionTest < ActiveRecord::TestCase
30
+ include ActiveRecord::Reflection
31
+
32
+ fixtures :topics, :customers, :companies, :subscribers, :price_estimates
33
+
34
+ def setup
35
+ @first = Topic.find(1)
36
+ end
37
+
38
+ def test_human_name
39
+ assert_equal "Price estimate", PriceEstimate.model_name.human
40
+ assert_equal "Subscriber", Subscriber.model_name.human
41
+ end
42
+
43
+ def test_read_attribute_names
44
+ assert_equal(
45
+ %w( id title author_name author_email_address bonus_time written_on last_read content important group approved replies_count unique_replies_count parent_id parent_title type created_at updated_at ).sort,
46
+ @first.attribute_names.sort
47
+ )
48
+ end
49
+
50
+ def test_columns
51
+ assert_equal 18, Topic.columns.length
52
+ end
53
+
54
+ def test_columns_are_returned_in_the_order_they_were_declared
55
+ column_names = Topic.columns.map(&:name)
56
+ assert_equal %w(id title author_name author_email_address written_on bonus_time last_read content important approved replies_count unique_replies_count parent_id parent_title type group created_at updated_at), column_names
57
+ end
58
+
59
+ def test_content_columns
60
+ content_columns = Topic.content_columns
61
+ content_column_names = content_columns.map(&:name)
62
+ assert_equal 13, content_columns.length
63
+ assert_equal %w(title author_name author_email_address written_on bonus_time last_read content important group approved parent_title created_at updated_at).sort, content_column_names.sort
64
+ end
65
+
66
+ def test_column_string_type_and_limit
67
+ assert_equal :string, @first.column_for_attribute("title").type
68
+ assert_equal 250, @first.column_for_attribute("title").limit
69
+ end
70
+
71
+ def test_column_null_not_null
72
+ subscriber = Subscriber.first
73
+ assert subscriber.column_for_attribute("name").null
74
+ assert !subscriber.column_for_attribute("nick").null
75
+ end
76
+
77
+ def test_human_name_for_column
78
+ assert_equal "Author name", @first.column_for_attribute("author_name").human_name
79
+ end
80
+
81
+ def test_integer_columns
82
+ assert_equal :integer, @first.column_for_attribute("id").type
83
+ end
84
+
85
+ def test_non_existent_columns_return_null_object
86
+ column = @first.column_for_attribute("attribute_that_doesnt_exist")
87
+ assert_instance_of ActiveRecord::ConnectionAdapters::NullColumn, column
88
+ assert_equal "attribute_that_doesnt_exist", column.name
89
+ assert_equal nil, column.sql_type
90
+ assert_equal nil, column.type
91
+ end
92
+
93
+ def test_non_existent_types_are_identity_types
94
+ type = @first.type_for_attribute("attribute_that_doesnt_exist")
95
+ object = Object.new
96
+
97
+ assert_equal object, type.deserialize(object)
98
+ assert_equal object, type.cast(object)
99
+ assert_equal object, type.serialize(object)
100
+ end
101
+
102
+ def test_reflection_klass_for_nested_class_name
103
+ reflection = ActiveRecord::Reflection.create(:has_many, nil, nil, { :class_name => 'MyApplication::Business::Company' }, ActiveRecord::Base)
104
+ assert_nothing_raised do
105
+ assert_equal MyApplication::Business::Company, reflection.klass
106
+ end
107
+ end
108
+
109
+ def test_irregular_reflection_class_name
110
+ ActiveSupport::Inflector.inflections do |inflect|
111
+ inflect.irregular 'plural_irregular', 'plurales_irregulares'
112
+ end
113
+ reflection = ActiveRecord::Reflection.create(:has_many, 'plurales_irregulares', nil, {}, ActiveRecord::Base)
114
+ assert_equal 'PluralIrregular', reflection.class_name
115
+ end
116
+
117
+ def test_aggregation_reflection
118
+ reflection_for_address = AggregateReflection.new(
119
+ :address, nil, { :mapping => [ %w(address_street street), %w(address_city city), %w(address_country country) ] }, Customer
120
+ )
121
+
122
+ reflection_for_balance = AggregateReflection.new(
123
+ :balance, nil, { :class_name => "Money", :mapping => %w(balance amount) }, Customer
124
+ )
125
+
126
+ reflection_for_gps_location = AggregateReflection.new(
127
+ :gps_location, nil, { }, Customer
128
+ )
129
+
130
+ assert Customer.reflect_on_all_aggregations.include?(reflection_for_gps_location)
131
+ assert Customer.reflect_on_all_aggregations.include?(reflection_for_balance)
132
+ assert Customer.reflect_on_all_aggregations.include?(reflection_for_address)
133
+
134
+ assert_equal reflection_for_address, Customer.reflect_on_aggregation(:address)
135
+
136
+ assert_equal Address, Customer.reflect_on_aggregation(:address).klass
137
+
138
+ assert_equal Money, Customer.reflect_on_aggregation(:balance).klass
139
+ end
140
+
141
+ def test_reflect_on_all_autosave_associations
142
+ expected = Pirate.reflect_on_all_associations.select { |r| r.options[:autosave] }
143
+ received = Pirate.reflect_on_all_autosave_associations
144
+
145
+ assert !received.empty?
146
+ assert_not_equal Pirate.reflect_on_all_associations.length, received.length
147
+ assert_equal expected, received
148
+ end
149
+
150
+ def test_has_many_reflection
151
+ reflection_for_clients = ActiveRecord::Reflection.create(:has_many, :clients, nil, { :order => "id", :dependent => :destroy }, Firm)
152
+
153
+ assert_equal reflection_for_clients, Firm.reflect_on_association(:clients)
154
+
155
+ assert_equal Client, Firm.reflect_on_association(:clients).klass
156
+ assert_equal 'companies', Firm.reflect_on_association(:clients).table_name
157
+
158
+ assert_equal Client, Firm.reflect_on_association(:clients_of_firm).klass
159
+ assert_equal 'companies', Firm.reflect_on_association(:clients_of_firm).table_name
160
+ end
161
+
162
+ def test_has_one_reflection
163
+ reflection_for_account = ActiveRecord::Reflection.create(:has_one, :account, nil, { :foreign_key => "firm_id", :dependent => :destroy }, Firm)
164
+ assert_equal reflection_for_account, Firm.reflect_on_association(:account)
165
+
166
+ assert_equal Account, Firm.reflect_on_association(:account).klass
167
+ assert_equal 'accounts', Firm.reflect_on_association(:account).table_name
168
+ end
169
+
170
+ def test_belongs_to_inferred_foreign_key_from_assoc_name
171
+ Company.belongs_to :foo
172
+ assert_equal "foo_id", Company.reflect_on_association(:foo).foreign_key
173
+ Company.belongs_to :bar, :class_name => "Xyzzy"
174
+ assert_equal "bar_id", Company.reflect_on_association(:bar).foreign_key
175
+ Company.belongs_to :baz, :class_name => "Xyzzy", :foreign_key => "xyzzy_id"
176
+ assert_equal "xyzzy_id", Company.reflect_on_association(:baz).foreign_key
177
+ end
178
+
179
+ def test_association_reflection_in_modules
180
+ ActiveRecord::Base.store_full_sti_class = false
181
+
182
+ assert_reflection MyApplication::Business::Firm,
183
+ :clients_of_firm,
184
+ :klass => MyApplication::Business::Client,
185
+ :class_name => 'Client',
186
+ :table_name => 'companies'
187
+
188
+ assert_reflection MyApplication::Billing::Account,
189
+ :firm,
190
+ :klass => MyApplication::Business::Firm,
191
+ :class_name => 'MyApplication::Business::Firm',
192
+ :table_name => 'companies'
193
+
194
+ assert_reflection MyApplication::Billing::Account,
195
+ :qualified_billing_firm,
196
+ :klass => MyApplication::Billing::Firm,
197
+ :class_name => 'MyApplication::Billing::Firm',
198
+ :table_name => 'companies'
199
+
200
+ assert_reflection MyApplication::Billing::Account,
201
+ :unqualified_billing_firm,
202
+ :klass => MyApplication::Billing::Firm,
203
+ :class_name => 'Firm',
204
+ :table_name => 'companies'
205
+
206
+ assert_reflection MyApplication::Billing::Account,
207
+ :nested_qualified_billing_firm,
208
+ :klass => MyApplication::Billing::Nested::Firm,
209
+ :class_name => 'MyApplication::Billing::Nested::Firm',
210
+ :table_name => 'companies'
211
+
212
+ assert_reflection MyApplication::Billing::Account,
213
+ :nested_unqualified_billing_firm,
214
+ :klass => MyApplication::Billing::Nested::Firm,
215
+ :class_name => 'Nested::Firm',
216
+ :table_name => 'companies'
217
+ ensure
218
+ ActiveRecord::Base.store_full_sti_class = true
219
+ end
220
+
221
+ def test_reflection_should_not_raise_error_when_compared_to_other_object
222
+ assert_not_equal Object.new, Firm._reflections['clients']
223
+ end
224
+
225
+ def test_reflections_should_return_keys_as_strings
226
+ assert Category.reflections.keys.all? { |key| key.is_a? String }, "Model.reflections is expected to return string for keys"
227
+ end
228
+
229
+ def test_has_and_belongs_to_many_reflection
230
+ assert_equal :has_and_belongs_to_many, Category.reflections['posts'].macro
231
+ assert_equal :posts, Category.reflect_on_all_associations(:has_and_belongs_to_many).first.name
232
+ end
233
+
234
+ def test_has_many_through_reflection
235
+ assert_kind_of ThroughReflection, Subscriber.reflect_on_association(:books)
236
+ end
237
+
238
+ def test_chain
239
+ expected = [
240
+ Organization.reflect_on_association(:author_essay_categories),
241
+ Author.reflect_on_association(:essays),
242
+ Organization.reflect_on_association(:authors)
243
+ ]
244
+ actual = Organization.reflect_on_association(:author_essay_categories).chain
245
+
246
+ assert_equal expected, actual
247
+ end
248
+
249
+ def test_scope_chain
250
+ expected = [
251
+ [Tagging.reflect_on_association(:tag).scope, Post.reflect_on_association(:first_blue_tags).scope],
252
+ [Post.reflect_on_association(:first_taggings).scope],
253
+ [Author.reflect_on_association(:misc_posts).scope]
254
+ ]
255
+ actual = Author.reflect_on_association(:misc_post_first_blue_tags).scope_chain
256
+ assert_equal expected, actual
257
+
258
+ expected = [
259
+ [
260
+ Tagging.reflect_on_association(:blue_tag).scope,
261
+ Post.reflect_on_association(:first_blue_tags_2).scope,
262
+ Author.reflect_on_association(:misc_post_first_blue_tags_2).scope
263
+ ],
264
+ [],
265
+ []
266
+ ]
267
+ actual = Author.reflect_on_association(:misc_post_first_blue_tags_2).scope_chain
268
+ assert_equal expected, actual
269
+ end
270
+
271
+ def test_scope_chain_does_not_interfere_with_hmt_with_polymorphic_case
272
+ @hotel = Hotel.create!
273
+ @department = @hotel.departments.create!
274
+ @department.chefs.create!(employable: CakeDesigner.create!)
275
+ @department.chefs.create!(employable: DrinkDesigner.create!)
276
+
277
+ assert_equal 1, @hotel.cake_designers.size
278
+ assert_equal 1, @hotel.drink_designers.size
279
+ assert_equal 2, @hotel.chefs.size
280
+ end
281
+
282
+ def test_scope_chain_does_not_interfere_with_hmt_with_polymorphic_case_and_sti
283
+ @hotel = Hotel.create!
284
+ @hotel.mocktail_designers << MocktailDesigner.create!
285
+
286
+ assert_equal 1, @hotel.mocktail_designers.size
287
+ assert_equal 1, @hotel.mocktail_designers.count
288
+ assert_equal 1, @hotel.chef_lists.size
289
+ end
290
+
291
+ def test_scope_chain_of_polymorphic_association_does_not_leak_into_other_hmt_associations
292
+ hotel = Hotel.create!
293
+ department = hotel.departments.create!
294
+ drink = department.chefs.create!(employable: DrinkDesigner.create!)
295
+ Recipe.create!(chef_id: drink.id, hotel_id: hotel.id)
296
+
297
+ expected_sql = capture_sql { hotel.recipes.to_a }
298
+
299
+ Hotel.reflect_on_association(:recipes).clear_association_scope_cache
300
+ hotel.reload
301
+ hotel.drink_designers.to_a
302
+ loaded_sql = capture_sql { hotel.recipes.to_a }
303
+
304
+ assert_equal expected_sql, loaded_sql
305
+ end
306
+
307
+ def test_nested?
308
+ assert !Author.reflect_on_association(:comments).nested?
309
+ assert Author.reflect_on_association(:tags).nested?
310
+
311
+ # Only goes :through once, but the through_reflection is a has_and_belongs_to_many, so this is
312
+ # a nested through association
313
+ assert Category.reflect_on_association(:post_comments).nested?
314
+ end
315
+
316
+ def test_association_primary_key
317
+ # Normal association
318
+ assert_equal "id", Author.reflect_on_association(:posts).association_primary_key.to_s
319
+ assert_equal "name", Author.reflect_on_association(:essay).association_primary_key.to_s
320
+ assert_equal "name", Essay.reflect_on_association(:writer).association_primary_key.to_s
321
+
322
+ # Through association (uses the :primary_key option from the source reflection)
323
+ assert_equal "nick", Author.reflect_on_association(:subscribers).association_primary_key.to_s
324
+ assert_equal "name", Author.reflect_on_association(:essay_category).association_primary_key.to_s
325
+ assert_equal "custom_primary_key", Author.reflect_on_association(:tags_with_primary_key).association_primary_key.to_s # nested
326
+ end
327
+
328
+ def test_association_primary_key_type
329
+ # Normal Association
330
+ assert_equal :integer, Author.reflect_on_association(:posts).association_primary_key_type.type
331
+ assert_equal :string, Author.reflect_on_association(:essay).association_primary_key_type.type
332
+
333
+ # Through Association
334
+ assert_equal :string, Author.reflect_on_association(:essay_category).association_primary_key_type.type
335
+ end
336
+
337
+ def test_association_primary_key_raises_when_missing_primary_key
338
+ reflection = ActiveRecord::Reflection.create(:has_many, :edge, nil, {}, Author)
339
+ assert_raises(ActiveRecord::UnknownPrimaryKey) { reflection.association_primary_key }
340
+
341
+ through = Class.new(ActiveRecord::Reflection::ThroughReflection) {
342
+ define_method(:source_reflection) { reflection }
343
+ }.new(reflection)
344
+ assert_raises(ActiveRecord::UnknownPrimaryKey) { through.association_primary_key }
345
+ end
346
+
347
+ def test_active_record_primary_key
348
+ assert_equal "nick", Subscriber.reflect_on_association(:subscriptions).active_record_primary_key.to_s
349
+ assert_equal "name", Author.reflect_on_association(:essay).active_record_primary_key.to_s
350
+ end
351
+
352
+ def test_active_record_primary_key_raises_when_missing_primary_key
353
+ reflection = ActiveRecord::Reflection.create(:has_many, :author, nil, {}, Edge)
354
+ assert_raises(ActiveRecord::UnknownPrimaryKey) { reflection.active_record_primary_key }
355
+ end
356
+
357
+ def test_foreign_type
358
+ assert_equal "sponsorable_type", Sponsor.reflect_on_association(:sponsorable).foreign_type.to_s
359
+ assert_equal "sponsorable_type", Sponsor.reflect_on_association(:thing).foreign_type.to_s
360
+ end
361
+
362
+ def test_collection_association
363
+ assert Pirate.reflect_on_association(:birds).collection?
364
+ assert Pirate.reflect_on_association(:parrots).collection?
365
+
366
+ assert !Pirate.reflect_on_association(:ship).collection?
367
+ assert !Ship.reflect_on_association(:pirate).collection?
368
+ end
369
+
370
+ def test_default_association_validation
371
+ assert ActiveRecord::Reflection.create(:has_many, :clients, nil, {}, Firm).validate?
372
+
373
+ assert !ActiveRecord::Reflection.create(:has_one, :client, nil, {}, Firm).validate?
374
+ assert !ActiveRecord::Reflection.create(:belongs_to, :client, nil, {}, Firm).validate?
375
+ end
376
+
377
+ def test_always_validate_association_if_explicit
378
+ assert ActiveRecord::Reflection.create(:has_one, :client, nil, { :validate => true }, Firm).validate?
379
+ assert ActiveRecord::Reflection.create(:belongs_to, :client, nil, { :validate => true }, Firm).validate?
380
+ assert ActiveRecord::Reflection.create(:has_many, :clients, nil, { :validate => true }, Firm).validate?
381
+ end
382
+
383
+ def test_validate_association_if_autosave
384
+ assert ActiveRecord::Reflection.create(:has_one, :client, nil, { :autosave => true }, Firm).validate?
385
+ assert ActiveRecord::Reflection.create(:belongs_to, :client, nil, { :autosave => true }, Firm).validate?
386
+ assert ActiveRecord::Reflection.create(:has_many, :clients, nil, { :autosave => true }, Firm).validate?
387
+ end
388
+
389
+ def test_never_validate_association_if_explicit
390
+ assert !ActiveRecord::Reflection.create(:has_one, :client, nil, { :autosave => true, :validate => false }, Firm).validate?
391
+ assert !ActiveRecord::Reflection.create(:belongs_to, :client, nil, { :autosave => true, :validate => false }, Firm).validate?
392
+ assert !ActiveRecord::Reflection.create(:has_many, :clients, nil, { :autosave => true, :validate => false }, Firm).validate?
393
+ end
394
+
395
+ def test_foreign_key
396
+ assert_equal "author_id", Author.reflect_on_association(:posts).foreign_key.to_s
397
+ assert_equal "category_id", Post.reflect_on_association(:categorizations).foreign_key.to_s
398
+ end
399
+
400
+ def test_through_reflection_scope_chain_does_not_modify_other_reflections
401
+ orig_conds = Post.reflect_on_association(:first_blue_tags_2).scope_chain.inspect
402
+ Author.reflect_on_association(:misc_post_first_blue_tags_2).scope_chain
403
+ assert_equal orig_conds, Post.reflect_on_association(:first_blue_tags_2).scope_chain.inspect
404
+ end
405
+
406
+ def test_symbol_for_class_name
407
+ assert_equal Client, Firm.reflect_on_association(:unsorted_clients_with_symbol).klass
408
+ end
409
+
410
+ def test_join_table
411
+ category = Struct.new(:table_name, :pluralize_table_names).new('categories', true)
412
+ product = Struct.new(:table_name, :pluralize_table_names).new('products', true)
413
+
414
+ reflection = ActiveRecord::Reflection.create(:has_many, :categories, nil, {}, product)
415
+ reflection.stub(:klass, category) do
416
+ assert_equal 'categories_products', reflection.join_table
417
+ end
418
+
419
+ reflection = ActiveRecord::Reflection.create(:has_many, :products, nil, {}, category)
420
+ reflection.stub(:klass, product) do
421
+ assert_equal 'categories_products', reflection.join_table
422
+ end
423
+ end
424
+
425
+ def test_join_table_with_common_prefix
426
+ category = Struct.new(:table_name, :pluralize_table_names).new('catalog_categories', true)
427
+ product = Struct.new(:table_name, :pluralize_table_names).new('catalog_products', true)
428
+
429
+ reflection = ActiveRecord::Reflection.create(:has_many, :categories, nil, {}, product)
430
+ reflection.stub(:klass, category) do
431
+ assert_equal 'catalog_categories_products', reflection.join_table
432
+ end
433
+
434
+ reflection = ActiveRecord::Reflection.create(:has_many, :products, nil, {}, category)
435
+ reflection.stub(:klass, product) do
436
+ assert_equal 'catalog_categories_products', reflection.join_table
437
+ end
438
+ end
439
+
440
+ def test_join_table_with_different_prefix
441
+ category = Struct.new(:table_name, :pluralize_table_names).new('catalog_categories', true)
442
+ page = Struct.new(:table_name, :pluralize_table_names).new('content_pages', true)
443
+
444
+ reflection = ActiveRecord::Reflection.create(:has_many, :categories, nil, {}, page)
445
+ reflection.stub(:klass, category) do
446
+ assert_equal 'catalog_categories_content_pages', reflection.join_table
447
+ end
448
+
449
+ reflection = ActiveRecord::Reflection.create(:has_many, :pages, nil, {}, category)
450
+ reflection.stub(:klass, page) do
451
+ assert_equal 'catalog_categories_content_pages', reflection.join_table
452
+ end
453
+ end
454
+
455
+ def test_join_table_can_be_overridden
456
+ category = Struct.new(:table_name, :pluralize_table_names).new('categories', true)
457
+ product = Struct.new(:table_name, :pluralize_table_names).new('products', true)
458
+
459
+ reflection = ActiveRecord::Reflection.create(:has_many, :categories, nil, { :join_table => 'product_categories' }, product)
460
+ reflection.stub(:klass, category) do
461
+ assert_equal 'product_categories', reflection.join_table
462
+ end
463
+
464
+ reflection = ActiveRecord::Reflection.create(:has_many, :products, nil, { :join_table => 'product_categories' }, category)
465
+ reflection.stub(:klass, product) do
466
+ assert_equal 'product_categories', reflection.join_table
467
+ end
468
+ end
469
+
470
+ def test_includes_accepts_symbols
471
+ hotel = Hotel.create!
472
+ department = hotel.departments.create!
473
+ department.chefs.create!
474
+
475
+ assert_nothing_raised do
476
+ assert_equal department.chefs, Hotel.includes([departments: :chefs]).first.chefs
477
+ end
478
+ end
479
+
480
+ def test_includes_accepts_strings
481
+ hotel = Hotel.create!
482
+ department = hotel.departments.create!
483
+ department.chefs.create!
484
+
485
+ assert_nothing_raised do
486
+ assert_equal department.chefs, Hotel.includes(['departments' => 'chefs']).first.chefs
487
+ end
488
+ end
489
+
490
+ def test_reflect_on_association_accepts_symbols
491
+ assert_nothing_raised do
492
+ assert_equal Hotel.reflect_on_association(:departments).name, :departments
493
+ end
494
+ end
495
+
496
+ def test_reflect_on_association_accepts_strings
497
+ assert_nothing_raised do
498
+ assert_equal Hotel.reflect_on_association("departments").name, :departments
499
+ end
500
+ end
501
+
502
+ private
503
+ def assert_reflection(klass, association, options)
504
+ assert reflection = klass.reflect_on_association(association)
505
+ options.each do |method, value|
506
+ assert_equal(value, reflection.send(method))
507
+ end
508
+ end
509
+ end