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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (586) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGES +4 -0
  3. data/LICENSE +1 -1
  4. data/MANIFEST +14 -14
  5. data/ParameterizedQueries README +6 -6
  6. data/README +208 -225
  7. data/ext/Makefile.nt32 +181 -181
  8. data/ext/Makefile.nt32.191 +212 -212
  9. data/ext/extconf.rb +291 -291
  10. data/ext/ibm_db.c +11887 -11887
  11. data/ext/ruby_ibm_db.h +241 -241
  12. data/ext/ruby_ibm_db_cli.c +866 -866
  13. data/ext/ruby_ibm_db_cli.h +500 -500
  14. data/init.rb +41 -41
  15. data/lib/IBM_DB.rb +27 -27
  16. data/lib/active_record/connection_adapters/ibm_db_adapter.rb +3452 -3177
  17. data/lib/active_record/connection_adapters/ibmdb_adapter.rb +5 -2
  18. data/lib/active_record/vendor/db2-i5-zOS.yaml +328 -328
  19. data/lib/mswin32/ibm_db.rb +91 -123
  20. data/lib/mswin32/rb2x/i386/ibm_db.so +0 -0
  21. data/test/active_record/connection_adapters/fake_adapter.rb +49 -46
  22. data/test/assets/example.log +1 -1
  23. data/test/assets/test.txt +1 -1
  24. data/test/cases/adapter_test.rb +351 -276
  25. data/test/cases/adapters/mysql2/active_schema_test.rb +193 -0
  26. data/test/cases/adapters/mysql2/bind_parameter_test.rb +50 -0
  27. data/test/cases/adapters/mysql2/boolean_test.rb +100 -0
  28. data/test/cases/adapters/mysql2/case_sensitivity_test.rb +63 -0
  29. data/test/cases/adapters/mysql2/charset_collation_test.rb +54 -0
  30. data/test/cases/adapters/mysql2/connection_test.rb +210 -0
  31. data/test/cases/adapters/mysql2/datetime_precision_quoting_test.rb +45 -0
  32. data/test/cases/adapters/mysql2/enum_test.rb +26 -0
  33. data/test/cases/adapters/mysql2/explain_test.rb +21 -0
  34. data/test/cases/adapters/mysql2/json_test.rb +195 -0
  35. data/test/cases/adapters/mysql2/mysql2_adapter_test.rb +83 -0
  36. data/test/cases/adapters/mysql2/reserved_word_test.rb +152 -0
  37. data/test/cases/adapters/mysql2/schema_migrations_test.rb +59 -0
  38. data/test/cases/adapters/mysql2/schema_test.rb +126 -0
  39. data/test/cases/adapters/mysql2/sp_test.rb +36 -0
  40. data/test/cases/adapters/mysql2/sql_types_test.rb +14 -0
  41. data/test/cases/adapters/mysql2/table_options_test.rb +42 -0
  42. data/test/cases/adapters/mysql2/unsigned_type_test.rb +66 -0
  43. data/test/cases/adapters/postgresql/active_schema_test.rb +98 -0
  44. data/test/cases/adapters/postgresql/array_test.rb +339 -0
  45. data/test/cases/adapters/postgresql/bit_string_test.rb +82 -0
  46. data/test/cases/adapters/postgresql/bytea_test.rb +134 -0
  47. data/test/cases/adapters/postgresql/case_insensitive_test.rb +26 -0
  48. data/test/cases/adapters/postgresql/change_schema_test.rb +38 -0
  49. data/test/cases/adapters/postgresql/cidr_test.rb +25 -0
  50. data/test/cases/adapters/postgresql/citext_test.rb +78 -0
  51. data/test/cases/adapters/postgresql/collation_test.rb +53 -0
  52. data/test/cases/adapters/postgresql/composite_test.rb +132 -0
  53. data/test/cases/adapters/postgresql/connection_test.rb +257 -0
  54. data/test/cases/adapters/postgresql/datatype_test.rb +92 -0
  55. data/test/cases/adapters/postgresql/domain_test.rb +47 -0
  56. data/test/cases/adapters/postgresql/enum_test.rb +91 -0
  57. data/test/cases/adapters/postgresql/explain_test.rb +20 -0
  58. data/test/cases/adapters/postgresql/extension_migration_test.rb +63 -0
  59. data/test/cases/adapters/postgresql/full_text_test.rb +44 -0
  60. data/test/cases/adapters/postgresql/geometric_test.rb +378 -0
  61. data/test/cases/adapters/postgresql/hstore_test.rb +382 -0
  62. data/test/cases/adapters/postgresql/infinity_test.rb +69 -0
  63. data/test/cases/adapters/postgresql/integer_test.rb +25 -0
  64. data/test/cases/adapters/postgresql/json_test.rb +237 -0
  65. data/test/cases/adapters/postgresql/ltree_test.rb +53 -0
  66. data/test/cases/adapters/postgresql/money_test.rb +96 -0
  67. data/test/cases/adapters/postgresql/network_test.rb +94 -0
  68. data/test/cases/adapters/postgresql/numbers_test.rb +49 -0
  69. data/test/cases/adapters/postgresql/postgresql_adapter_test.rb +405 -0
  70. data/test/cases/adapters/postgresql/prepared_statements_test.rb +22 -0
  71. data/test/cases/adapters/postgresql/quoting_test.rb +44 -0
  72. data/test/cases/adapters/postgresql/range_test.rb +343 -0
  73. data/test/cases/adapters/postgresql/referential_integrity_test.rb +111 -0
  74. data/test/cases/adapters/postgresql/rename_table_test.rb +34 -0
  75. data/test/cases/adapters/postgresql/schema_authorization_test.rb +119 -0
  76. data/test/cases/adapters/postgresql/schema_test.rb +597 -0
  77. data/test/cases/adapters/postgresql/serial_test.rb +154 -0
  78. data/test/cases/adapters/postgresql/statement_pool_test.rb +41 -0
  79. data/test/cases/adapters/postgresql/timestamp_test.rb +90 -0
  80. data/test/cases/adapters/postgresql/type_lookup_test.rb +33 -0
  81. data/test/cases/adapters/postgresql/utils_test.rb +62 -0
  82. data/test/cases/adapters/postgresql/uuid_test.rb +294 -0
  83. data/test/cases/adapters/postgresql/xml_test.rb +54 -0
  84. data/test/cases/adapters/sqlite3/collation_test.rb +53 -0
  85. data/test/cases/adapters/sqlite3/copy_table_test.rb +98 -0
  86. data/test/cases/adapters/sqlite3/explain_test.rb +21 -0
  87. data/test/cases/adapters/sqlite3/quoting_test.rb +101 -0
  88. data/test/cases/adapters/sqlite3/sqlite3_adapter_test.rb +441 -0
  89. data/test/cases/adapters/sqlite3/sqlite3_create_folder_test.rb +24 -0
  90. data/test/cases/adapters/sqlite3/statement_pool_test.rb +20 -0
  91. data/test/cases/aggregations_test.rb +168 -158
  92. data/test/cases/ar_schema_test.rb +146 -161
  93. data/test/cases/associations/association_scope_test.rb +16 -21
  94. data/test/cases/associations/belongs_to_associations_test.rb +1141 -1029
  95. data/test/cases/associations/bidirectional_destroy_dependencies_test.rb +41 -0
  96. data/test/cases/associations/callbacks_test.rb +190 -192
  97. data/test/cases/associations/cascaded_eager_loading_test.rb +188 -188
  98. data/test/cases/associations/eager_load_includes_full_sti_class_test.rb +36 -36
  99. data/test/cases/associations/eager_load_nested_include_test.rb +126 -128
  100. data/test/cases/associations/eager_singularization_test.rb +148 -148
  101. data/test/cases/associations/eager_test.rb +1514 -1429
  102. data/test/cases/associations/extension_test.rb +87 -82
  103. data/test/cases/associations/has_and_belongs_to_many_associations_test.rb +1004 -972
  104. data/test/cases/associations/has_many_associations_test.rb +2501 -2182
  105. data/test/cases/associations/has_many_through_associations_test.rb +1271 -1204
  106. data/test/cases/associations/has_one_associations_test.rb +707 -610
  107. data/test/cases/associations/has_one_through_associations_test.rb +383 -380
  108. data/test/cases/associations/inner_join_association_test.rb +139 -139
  109. data/test/cases/associations/inverse_associations_test.rb +733 -706
  110. data/test/cases/associations/join_model_test.rb +777 -754
  111. data/test/cases/associations/left_outer_join_association_test.rb +88 -0
  112. data/test/cases/associations/nested_through_associations_test.rb +579 -579
  113. data/test/cases/associations/required_test.rb +102 -82
  114. data/test/cases/associations_test.rb +385 -380
  115. data/test/cases/attribute_decorators_test.rb +125 -125
  116. data/test/cases/attribute_methods/read_test.rb +60 -60
  117. data/test/cases/attribute_methods_test.rb +1009 -952
  118. data/test/cases/attribute_set_test.rb +270 -210
  119. data/test/cases/attribute_test.rb +246 -180
  120. data/test/cases/attributes_test.rb +253 -136
  121. data/test/cases/autosave_association_test.rb +1708 -1595
  122. data/test/cases/base_test.rb +1713 -1664
  123. data/test/cases/batches_test.rb +489 -212
  124. data/test/cases/binary_test.rb +44 -52
  125. data/test/cases/bind_parameter_test.rb +110 -100
  126. data/test/cases/cache_key_test.rb +25 -0
  127. data/test/cases/calculations_test.rb +798 -646
  128. data/test/cases/callbacks_test.rb +636 -543
  129. data/test/cases/clone_test.rb +40 -40
  130. data/test/cases/coders/json_test.rb +15 -0
  131. data/test/cases/coders/yaml_column_test.rb +63 -63
  132. data/test/cases/collection_cache_key_test.rb +115 -0
  133. data/test/cases/column_alias_test.rb +17 -17
  134. data/test/cases/column_definition_test.rb +92 -123
  135. data/test/cases/comment_test.rb +143 -0
  136. data/test/cases/connection_adapters/adapter_leasing_test.rb +56 -54
  137. data/test/cases/connection_adapters/connection_handler_test.rb +160 -53
  138. data/test/cases/connection_adapters/connection_specification_test.rb +12 -12
  139. data/test/cases/connection_adapters/merge_and_resolve_default_url_config_test.rb +255 -293
  140. data/test/cases/connection_adapters/mysql_type_lookup_test.rb +69 -65
  141. data/test/cases/connection_adapters/quoting_test.rb +13 -13
  142. data/test/cases/connection_adapters/schema_cache_test.rb +61 -56
  143. data/test/cases/connection_adapters/type_lookup_test.rb +118 -110
  144. data/test/cases/connection_management_test.rb +112 -122
  145. data/test/cases/connection_pool_test.rb +521 -346
  146. data/test/cases/connection_specification/resolver_test.rb +131 -116
  147. data/test/cases/core_test.rb +112 -112
  148. data/test/cases/counter_cache_test.rb +214 -209
  149. data/test/cases/custom_locking_test.rb +17 -17
  150. data/test/cases/database_statements_test.rb +34 -19
  151. data/test/cases/{invalid_date_test.rb → date_test.rb} +44 -32
  152. data/test/cases/date_time_precision_test.rb +106 -0
  153. data/test/cases/date_time_test.rb +61 -61
  154. data/test/cases/defaults_test.rb +218 -223
  155. data/test/cases/dirty_test.rb +763 -785
  156. data/test/cases/disconnected_test.rb +30 -28
  157. data/test/cases/dup_test.rb +157 -157
  158. data/test/cases/enum_test.rb +444 -290
  159. data/test/cases/errors_test.rb +16 -0
  160. data/test/cases/explain_subscriber_test.rb +64 -64
  161. data/test/cases/explain_test.rb +87 -76
  162. data/test/cases/finder_respond_to_test.rb +60 -60
  163. data/test/cases/finder_test.rb +1294 -1169
  164. data/test/cases/fixture_set/file_test.rb +156 -138
  165. data/test/cases/fixtures_test.rb +988 -908
  166. data/test/cases/forbidden_attributes_protection_test.rb +165 -99
  167. data/test/cases/habtm_destroy_order_test.rb +61 -61
  168. data/test/cases/helper.rb +204 -210
  169. data/test/cases/hot_compatibility_test.rb +142 -54
  170. data/test/cases/i18n_test.rb +45 -45
  171. data/test/cases/inheritance_test.rb +606 -375
  172. data/test/cases/integration_test.rb +155 -139
  173. data/test/cases/invalid_connection_test.rb +24 -22
  174. data/test/cases/invertible_migration_test.rb +387 -295
  175. data/test/cases/json_serialization_test.rb +311 -302
  176. data/test/cases/locking_test.rb +493 -477
  177. data/test/cases/log_subscriber_test.rb +225 -136
  178. data/test/cases/migration/change_schema_test.rb +458 -512
  179. data/test/cases/migration/change_table_test.rb +256 -224
  180. data/test/cases/migration/column_attributes_test.rb +176 -192
  181. data/test/cases/migration/column_positioning_test.rb +56 -56
  182. data/test/cases/migration/columns_test.rb +310 -304
  183. data/test/cases/migration/command_recorder_test.rb +350 -305
  184. data/test/cases/migration/compatibility_test.rb +118 -0
  185. data/test/cases/migration/create_join_table_test.rb +157 -148
  186. data/test/cases/migration/foreign_key_test.rb +360 -328
  187. data/test/cases/migration/helper.rb +39 -39
  188. data/test/cases/migration/index_test.rb +218 -216
  189. data/test/cases/migration/logger_test.rb +36 -36
  190. data/test/cases/migration/pending_migrations_test.rb +52 -53
  191. data/test/cases/migration/references_foreign_key_test.rb +216 -169
  192. data/test/cases/migration/references_index_test.rb +101 -101
  193. data/test/cases/migration/references_statements_test.rb +136 -116
  194. data/test/cases/migration/rename_table_test.rb +93 -93
  195. data/test/cases/migration_test.rb +1157 -959
  196. data/test/cases/migrator_test.rb +470 -388
  197. data/test/cases/mixin_test.rb +68 -70
  198. data/test/cases/modules_test.rb +172 -173
  199. data/test/cases/multiparameter_attributes_test.rb +372 -350
  200. data/test/cases/multiple_db_test.rb +122 -115
  201. data/test/cases/nested_attributes_test.rb +1098 -1070
  202. data/test/cases/nested_attributes_with_callbacks_test.rb +144 -144
  203. data/test/cases/persistence_test.rb +1001 -909
  204. data/test/cases/pooled_connections_test.rb +81 -81
  205. data/test/cases/primary_keys_test.rb +376 -237
  206. data/test/cases/query_cache_test.rb +446 -326
  207. data/test/cases/quoting_test.rb +202 -156
  208. data/test/cases/readonly_test.rb +119 -118
  209. data/test/cases/reaper_test.rb +85 -85
  210. data/test/cases/reflection_test.rb +509 -463
  211. data/test/cases/relation/delegation_test.rb +63 -68
  212. data/test/cases/relation/merging_test.rb +157 -161
  213. data/test/cases/relation/mutation_test.rb +183 -165
  214. data/test/cases/relation/or_test.rb +92 -0
  215. data/test/cases/relation/predicate_builder_test.rb +16 -14
  216. data/test/cases/relation/record_fetch_warning_test.rb +40 -0
  217. data/test/cases/relation/where_chain_test.rb +105 -181
  218. data/test/cases/relation/where_clause_test.rb +182 -0
  219. data/test/cases/relation/where_test.rb +322 -300
  220. data/test/cases/relation_test.rb +328 -319
  221. data/test/cases/relations_test.rb +2026 -1815
  222. data/test/cases/reload_models_test.rb +22 -22
  223. data/test/cases/result_test.rb +90 -80
  224. data/test/cases/sanitize_test.rb +176 -83
  225. data/test/cases/schema_dumper_test.rb +457 -463
  226. data/test/cases/schema_loading_test.rb +52 -0
  227. data/test/cases/scoping/default_scoping_test.rb +528 -454
  228. data/test/cases/scoping/named_scoping_test.rb +561 -524
  229. data/test/cases/scoping/relation_scoping_test.rb +400 -357
  230. data/test/cases/secure_token_test.rb +32 -0
  231. data/test/cases/serialization_test.rb +104 -104
  232. data/test/cases/serialized_attribute_test.rb +364 -277
  233. data/test/cases/statement_cache_test.rb +136 -98
  234. data/test/cases/store_test.rb +195 -194
  235. data/test/cases/suppressor_test.rb +63 -0
  236. data/test/cases/tasks/database_tasks_test.rb +462 -398
  237. data/test/cases/tasks/mysql_rake_test.rb +345 -324
  238. data/test/cases/tasks/postgresql_rake_test.rb +304 -250
  239. data/test/cases/tasks/sqlite_rake_test.rb +220 -193
  240. data/test/cases/test_case.rb +131 -123
  241. data/test/cases/test_fixtures_test.rb +36 -0
  242. data/test/cases/time_precision_test.rb +102 -0
  243. data/test/cases/timestamp_test.rb +501 -467
  244. data/test/cases/touch_later_test.rb +121 -0
  245. data/test/cases/transaction_callbacks_test.rb +518 -452
  246. data/test/cases/transaction_isolation_test.rb +106 -106
  247. data/test/cases/transactions_test.rb +834 -817
  248. data/test/cases/type/adapter_specific_registry_test.rb +133 -0
  249. data/test/cases/type/date_time_test.rb +14 -0
  250. data/test/cases/type/integer_test.rb +27 -121
  251. data/test/cases/type/string_test.rb +22 -36
  252. data/test/cases/type/type_map_test.rb +177 -177
  253. data/test/cases/type_test.rb +39 -0
  254. data/test/cases/types_test.rb +24 -141
  255. data/test/cases/unconnected_test.rb +33 -33
  256. data/test/cases/validations/absence_validation_test.rb +73 -0
  257. data/test/cases/validations/association_validation_test.rb +97 -86
  258. data/test/cases/validations/i18n_generate_message_validation_test.rb +84 -84
  259. data/test/cases/validations/i18n_validation_test.rb +86 -90
  260. data/test/cases/validations/length_validation_test.rb +79 -47
  261. data/test/cases/validations/presence_validation_test.rb +103 -68
  262. data/test/cases/validations/uniqueness_validation_test.rb +548 -457
  263. data/test/cases/validations_repair_helper.rb +19 -23
  264. data/test/cases/validations_test.rb +194 -165
  265. data/test/cases/view_test.rb +216 -119
  266. data/test/cases/yaml_serialization_test.rb +121 -126
  267. data/test/config.example.yml +97 -0
  268. data/test/config.rb +5 -5
  269. data/test/fixtures/accounts.yml +29 -29
  270. data/test/fixtures/admin/accounts.yml +2 -2
  271. data/test/fixtures/admin/users.yml +10 -10
  272. data/test/fixtures/author_addresses.original +11 -0
  273. data/test/fixtures/author_addresses.yml +17 -17
  274. data/test/fixtures/author_favorites.yml +3 -3
  275. data/test/fixtures/authors.original +17 -0
  276. data/test/fixtures/authors.yml +23 -23
  277. data/test/fixtures/bad_posts.yml +9 -0
  278. data/test/fixtures/binaries.yml +133 -133
  279. data/test/fixtures/books.yml +31 -11
  280. data/test/fixtures/bulbs.yml +5 -5
  281. data/test/fixtures/cars.yml +9 -9
  282. data/test/fixtures/categories.yml +19 -19
  283. data/test/fixtures/categories/special_categories.yml +9 -9
  284. data/test/fixtures/categories/subsubdir/arbitrary_filename.yml +4 -4
  285. data/test/fixtures/categories_ordered.yml +7 -7
  286. data/test/fixtures/categories_posts.yml +31 -31
  287. data/test/fixtures/categorizations.yml +23 -23
  288. data/test/fixtures/clubs.yml +8 -8
  289. data/test/fixtures/collections.yml +3 -3
  290. data/test/fixtures/colleges.yml +3 -3
  291. data/test/fixtures/comments.yml +65 -65
  292. data/test/fixtures/companies.yml +67 -67
  293. data/test/fixtures/computers.yml +10 -10
  294. data/test/fixtures/content.yml +3 -0
  295. data/test/fixtures/content_positions.yml +3 -0
  296. data/test/fixtures/courses.yml +8 -8
  297. data/test/fixtures/customers.yml +25 -25
  298. data/test/fixtures/dashboards.yml +6 -6
  299. data/test/fixtures/dead_parrots.yml +5 -0
  300. data/test/fixtures/developers.yml +22 -22
  301. data/test/fixtures/developers_projects.yml +16 -16
  302. data/test/fixtures/dog_lovers.yml +7 -7
  303. data/test/fixtures/dogs.yml +4 -4
  304. data/test/fixtures/doubloons.yml +3 -3
  305. data/test/fixtures/edges.yml +5 -5
  306. data/test/fixtures/entrants.yml +14 -14
  307. data/test/fixtures/essays.yml +6 -6
  308. data/test/fixtures/faces.yml +11 -11
  309. data/test/fixtures/fk_test_has_fk.yml +3 -3
  310. data/test/fixtures/fk_test_has_pk.yml +1 -1
  311. data/test/fixtures/friendships.yml +4 -4
  312. data/test/fixtures/funny_jokes.yml +10 -10
  313. data/test/fixtures/interests.yml +33 -33
  314. data/test/fixtures/items.yml +3 -3
  315. data/test/fixtures/jobs.yml +7 -7
  316. data/test/fixtures/legacy_things.yml +3 -3
  317. data/test/fixtures/live_parrots.yml +4 -0
  318. data/test/fixtures/mateys.yml +4 -4
  319. data/test/fixtures/member_details.yml +8 -8
  320. data/test/fixtures/member_types.yml +6 -6
  321. data/test/fixtures/members.yml +11 -11
  322. data/test/fixtures/memberships.yml +34 -34
  323. data/test/fixtures/men.yml +5 -5
  324. data/test/fixtures/minimalistics.yml +2 -2
  325. data/test/fixtures/minivans.yml +5 -5
  326. data/test/fixtures/mixed_case_monkeys.yml +6 -6
  327. data/test/fixtures/mixins.yml +29 -29
  328. data/test/fixtures/movies.yml +7 -7
  329. data/test/fixtures/naked/yml/accounts.yml +1 -1
  330. data/test/fixtures/naked/yml/companies.yml +1 -1
  331. data/test/fixtures/naked/yml/courses.yml +1 -1
  332. data/test/fixtures/naked/yml/parrots.yml +2 -0
  333. data/test/fixtures/naked/yml/trees.yml +3 -0
  334. data/test/fixtures/nodes.yml +29 -0
  335. data/test/fixtures/organizations.yml +5 -5
  336. data/test/fixtures/other_comments.yml +6 -0
  337. data/test/fixtures/other_dogs.yml +2 -0
  338. data/test/fixtures/other_posts.yml +7 -0
  339. data/test/fixtures/other_topics.yml +42 -42
  340. data/test/fixtures/owners.yml +9 -9
  341. data/test/fixtures/parrots.yml +27 -27
  342. data/test/fixtures/parrots_pirates.yml +7 -7
  343. data/test/fixtures/people.yml +24 -24
  344. data/test/fixtures/peoples_treasures.yml +3 -3
  345. data/test/fixtures/pets.yml +19 -19
  346. data/test/fixtures/pirates.yml +15 -12
  347. data/test/fixtures/posts.yml +80 -80
  348. data/test/fixtures/price_estimates.yml +16 -7
  349. data/test/fixtures/products.yml +4 -4
  350. data/test/fixtures/projects.yml +7 -7
  351. data/test/fixtures/ratings.yml +14 -14
  352. data/test/fixtures/readers.yml +11 -11
  353. data/test/fixtures/references.yml +17 -17
  354. data/test/fixtures/reserved_words/distinct.yml +5 -5
  355. data/test/fixtures/reserved_words/distinct_select.yml +11 -11
  356. data/test/fixtures/reserved_words/group.yml +14 -14
  357. data/test/fixtures/reserved_words/select.yml +8 -8
  358. data/test/fixtures/reserved_words/values.yml +7 -7
  359. data/test/fixtures/ships.yml +6 -6
  360. data/test/fixtures/speedometers.yml +8 -8
  361. data/test/fixtures/sponsors.yml +12 -12
  362. data/test/fixtures/string_key_objects.yml +7 -7
  363. data/test/fixtures/subscribers.yml +10 -10
  364. data/test/fixtures/subscriptions.yml +12 -12
  365. data/test/fixtures/taggings.yml +78 -78
  366. data/test/fixtures/tags.yml +11 -11
  367. data/test/fixtures/tasks.yml +7 -7
  368. data/test/fixtures/teapots.yml +3 -3
  369. data/test/fixtures/to_be_linked/accounts.yml +2 -2
  370. data/test/fixtures/to_be_linked/users.yml +10 -10
  371. data/test/fixtures/topics.yml +49 -49
  372. data/test/fixtures/toys.yml +14 -14
  373. data/test/fixtures/traffic_lights.yml +9 -9
  374. data/test/fixtures/treasures.yml +10 -10
  375. data/test/fixtures/trees.yml +3 -0
  376. data/test/fixtures/uuid_children.yml +3 -3
  377. data/test/fixtures/uuid_parents.yml +2 -2
  378. data/test/fixtures/variants.yml +4 -4
  379. data/test/fixtures/vegetables.yml +19 -19
  380. data/test/fixtures/vertices.yml +3 -3
  381. data/test/fixtures/warehouse_things.yml +2 -2
  382. data/test/fixtures/zines.yml +5 -5
  383. data/test/migrations/10_urban/9_add_expressions.rb +11 -11
  384. data/test/migrations/decimal/1_give_me_big_numbers.rb +15 -15
  385. data/test/migrations/magic/1_currencies_have_symbols.rb +12 -12
  386. data/test/migrations/missing/1000_people_have_middle_names.rb +9 -9
  387. data/test/migrations/missing/1_people_have_last_names.rb +9 -9
  388. data/test/migrations/missing/3_we_need_reminders.rb +12 -12
  389. data/test/migrations/missing/4_innocent_jointable.rb +12 -12
  390. data/test/migrations/rename/1_we_need_things.rb +11 -11
  391. data/test/migrations/rename/2_rename_things.rb +9 -9
  392. data/test/migrations/to_copy/1_people_have_hobbies.rb +9 -9
  393. data/test/migrations/to_copy/2_people_have_descriptions.rb +9 -9
  394. data/test/migrations/to_copy2/1_create_articles.rb +7 -7
  395. data/test/migrations/to_copy2/2_create_comments.rb +7 -7
  396. data/test/migrations/to_copy_with_name_collision/1_people_have_hobbies.rb +9 -9
  397. data/test/migrations/to_copy_with_timestamps/20090101010101_people_have_hobbies.rb +9 -9
  398. data/test/migrations/to_copy_with_timestamps/20090101010202_people_have_descriptions.rb +9 -9
  399. data/test/migrations/to_copy_with_timestamps2/20090101010101_create_articles.rb +7 -7
  400. data/test/migrations/to_copy_with_timestamps2/20090101010202_create_comments.rb +7 -7
  401. data/test/migrations/valid/1_valid_people_have_last_names.rb +9 -9
  402. data/test/migrations/valid/2_we_need_reminders.rb +12 -12
  403. data/test/migrations/valid/3_innocent_jointable.rb +12 -12
  404. data/test/migrations/valid_with_subdirectories/1_valid_people_have_last_names.rb +9 -9
  405. data/test/migrations/valid_with_subdirectories/sub/2_we_need_reminders.rb +12 -12
  406. data/test/migrations/valid_with_subdirectories/sub1/3_innocent_jointable.rb +12 -12
  407. data/test/migrations/valid_with_timestamps/20100101010101_valid_with_timestamps_people_have_last_names.rb +9 -9
  408. data/test/migrations/valid_with_timestamps/20100201010101_valid_with_timestamps_we_need_reminders.rb +12 -12
  409. data/test/migrations/valid_with_timestamps/20100301010101_valid_with_timestamps_innocent_jointable.rb +12 -12
  410. data/test/migrations/version_check/20131219224947_migration_version_check.rb +8 -8
  411. data/test/models/admin.rb +5 -5
  412. data/test/models/admin/account.rb +3 -3
  413. data/test/models/admin/randomly_named_c1.rb +6 -2
  414. data/test/models/admin/user.rb +40 -40
  415. data/test/models/aircraft.rb +5 -4
  416. data/test/models/arunit2_model.rb +3 -3
  417. data/test/models/author.rb +209 -212
  418. data/test/models/auto_id.rb +4 -4
  419. data/test/models/autoloadable/extra_firm.rb +2 -2
  420. data/test/models/binary.rb +2 -2
  421. data/test/models/bird.rb +12 -12
  422. data/test/models/book.rb +23 -18
  423. data/test/models/boolean.rb +2 -2
  424. data/test/models/bulb.rb +52 -51
  425. data/test/models/cake_designer.rb +3 -3
  426. data/test/models/car.rb +29 -26
  427. data/test/models/carrier.rb +2 -2
  428. data/test/models/cat.rb +10 -0
  429. data/test/models/categorization.rb +19 -19
  430. data/test/models/category.rb +35 -35
  431. data/test/models/chef.rb +8 -7
  432. data/test/models/citation.rb +3 -3
  433. data/test/models/club.rb +25 -23
  434. data/test/models/college.rb +10 -10
  435. data/test/models/column.rb +3 -3
  436. data/test/models/column_name.rb +3 -3
  437. data/test/models/comment.rb +76 -64
  438. data/test/models/company.rb +230 -228
  439. data/test/models/company_in_module.rb +98 -98
  440. data/test/models/computer.rb +3 -3
  441. data/test/models/contact.rb +41 -41
  442. data/test/models/content.rb +40 -0
  443. data/test/models/contract.rb +20 -20
  444. data/test/models/country.rb +7 -7
  445. data/test/models/course.rb +6 -6
  446. data/test/models/customer.rb +83 -77
  447. data/test/models/customer_carrier.rb +14 -14
  448. data/test/models/dashboard.rb +3 -3
  449. data/test/models/default.rb +2 -2
  450. data/test/models/department.rb +4 -4
  451. data/test/models/developer.rb +274 -255
  452. data/test/models/dog.rb +5 -5
  453. data/test/models/dog_lover.rb +5 -5
  454. data/test/models/doubloon.rb +12 -12
  455. data/test/models/drink_designer.rb +3 -3
  456. data/test/models/edge.rb +5 -5
  457. data/test/models/electron.rb +5 -5
  458. data/test/models/engine.rb +4 -4
  459. data/test/models/entrant.rb +3 -3
  460. data/test/models/essay.rb +5 -5
  461. data/test/models/event.rb +3 -3
  462. data/test/models/eye.rb +37 -37
  463. data/test/models/face.rb +9 -9
  464. data/test/models/friendship.rb +6 -6
  465. data/test/models/guid.rb +2 -2
  466. data/test/models/guitar.rb +4 -0
  467. data/test/models/hotel.rb +11 -9
  468. data/test/models/image.rb +3 -3
  469. data/test/models/interest.rb +5 -5
  470. data/test/models/invoice.rb +4 -4
  471. data/test/models/item.rb +7 -7
  472. data/test/models/job.rb +7 -7
  473. data/test/models/joke.rb +7 -7
  474. data/test/models/keyboard.rb +3 -3
  475. data/test/models/legacy_thing.rb +3 -3
  476. data/test/models/lesson.rb +11 -11
  477. data/test/models/line_item.rb +3 -3
  478. data/test/models/liquid.rb +4 -4
  479. data/test/models/man.rb +11 -11
  480. data/test/models/matey.rb +4 -4
  481. data/test/models/member.rb +42 -41
  482. data/test/models/member_detail.rb +8 -7
  483. data/test/models/member_type.rb +3 -3
  484. data/test/models/membership.rb +35 -35
  485. data/test/models/mentor.rb +3 -0
  486. data/test/models/minimalistic.rb +2 -2
  487. data/test/models/minivan.rb +9 -9
  488. data/test/models/mixed_case_monkey.rb +3 -3
  489. data/test/models/mocktail_designer.rb +2 -0
  490. data/test/models/molecule.rb +6 -6
  491. data/test/models/movie.rb +5 -5
  492. data/test/models/node.rb +5 -0
  493. data/test/models/non_primary_key.rb +2 -0
  494. data/test/models/notification.rb +3 -0
  495. data/test/models/order.rb +4 -4
  496. data/test/models/organization.rb +14 -14
  497. data/test/models/other_dog.rb +5 -0
  498. data/test/models/owner.rb +37 -34
  499. data/test/models/parrot.rb +28 -29
  500. data/test/models/person.rb +142 -143
  501. data/test/models/personal_legacy_thing.rb +4 -4
  502. data/test/models/pet.rb +18 -15
  503. data/test/models/pet_treasure.rb +6 -0
  504. data/test/models/pirate.rb +92 -92
  505. data/test/models/possession.rb +3 -3
  506. data/test/models/post.rb +273 -264
  507. data/test/models/price_estimate.rb +4 -4
  508. data/test/models/professor.rb +5 -5
  509. data/test/models/project.rb +40 -31
  510. data/test/models/publisher.rb +2 -2
  511. data/test/models/publisher/article.rb +4 -4
  512. data/test/models/publisher/magazine.rb +3 -3
  513. data/test/models/randomly_named_c1.rb +1 -1
  514. data/test/models/rating.rb +4 -4
  515. data/test/models/reader.rb +23 -23
  516. data/test/models/recipe.rb +3 -0
  517. data/test/models/record.rb +2 -2
  518. data/test/models/reference.rb +22 -22
  519. data/test/models/reply.rb +61 -61
  520. data/test/models/ship.rb +39 -33
  521. data/test/models/ship_part.rb +8 -8
  522. data/test/models/shop.rb +17 -17
  523. data/test/models/shop_account.rb +6 -6
  524. data/test/models/speedometer.rb +6 -6
  525. data/test/models/sponsor.rb +7 -7
  526. data/test/models/string_key_object.rb +3 -3
  527. data/test/models/student.rb +4 -4
  528. data/test/models/subject.rb +16 -16
  529. data/test/models/subscriber.rb +8 -8
  530. data/test/models/subscription.rb +4 -4
  531. data/test/models/tag.rb +13 -7
  532. data/test/models/tagging.rb +13 -13
  533. data/test/models/task.rb +5 -5
  534. data/test/models/topic.rb +118 -124
  535. data/test/models/toy.rb +6 -6
  536. data/test/models/traffic_light.rb +4 -4
  537. data/test/models/treasure.rb +14 -14
  538. data/test/models/treaty.rb +7 -7
  539. data/test/models/tree.rb +3 -0
  540. data/test/models/tuning_peg.rb +4 -0
  541. data/test/models/tyre.rb +11 -11
  542. data/test/models/user.rb +14 -0
  543. data/test/models/uuid_child.rb +3 -3
  544. data/test/models/uuid_item.rb +6 -0
  545. data/test/models/uuid_parent.rb +3 -3
  546. data/test/models/vegetables.rb +24 -24
  547. data/test/models/vehicle.rb +6 -6
  548. data/test/models/vertex.rb +9 -9
  549. data/test/models/warehouse_thing.rb +5 -5
  550. data/test/models/wheel.rb +3 -3
  551. data/test/models/without_table.rb +3 -3
  552. data/test/models/zine.rb +3 -3
  553. data/test/schema/mysql2_specific_schema.rb +68 -58
  554. data/test/schema/oracle_specific_schema.rb +40 -43
  555. data/test/schema/postgresql_specific_schema.rb +114 -202
  556. data/test/schema/schema.rb +1057 -952
  557. data/test/schema/schema.rb.original +1057 -0
  558. data/test/schema/sqlite_specific_schema.rb +18 -22
  559. data/test/support/config.rb +43 -43
  560. data/test/support/connection.rb +23 -22
  561. data/test/support/connection_helper.rb +14 -14
  562. data/test/support/ddl_helper.rb +8 -8
  563. data/test/support/schema_dumping_helper.rb +20 -20
  564. data/test/support/yaml_compatibility_fixtures/rails_4_1.yml +22 -0
  565. data/test/support/yaml_compatibility_fixtures/rails_4_2_0.yml +182 -0
  566. metadata +129 -28
  567. data/lib/mswin32/rb19x/ibm_db.so +0 -0
  568. data/lib/mswin32/rb21x/i386/ibm_db.so +0 -0
  569. data/lib/mswin32/rb22x/i386/ibm_db.so +0 -0
  570. data/lib/mswin32/rb23x/i386/ibm_db.so +0 -0
  571. data/test/cases/associations/deprecated_counter_cache_on_has_many_through_test.rb +0 -26
  572. data/test/cases/attribute_methods/serialization_test.rb +0 -29
  573. data/test/cases/migration/change_schema_test - Copy.rb +0 -448
  574. data/test/cases/migration/foreign_key_test - Changed.rb +0 -325
  575. data/test/cases/migration/table_and_index_test.rb +0 -24
  576. data/test/cases/relation/where_test2.rb +0 -36
  577. data/test/cases/type/decimal_test.rb +0 -56
  578. data/test/cases/type/unsigned_integer_test.rb +0 -18
  579. data/test/cases/xml_serialization_test.rb +0 -457
  580. data/test/connections/native_ibm_db/connection.rb +0 -44
  581. data/test/fixtures/naked/csv/accounts.csv +0 -1
  582. data/test/schema/i5/ibm_db_specific_schema.rb +0 -137
  583. data/test/schema/ids/ibm_db_specific_schema.rb +0 -140
  584. data/test/schema/luw/ibm_db_specific_schema.rb +0 -137
  585. data/test/schema/mysql_specific_schema.rb +0 -70
  586. data/test/schema/zOS/ibm_db_specific_schema.rb +0 -208
@@ -1,305 +1,350 @@
1
- require "cases/helper"
2
-
3
- module ActiveRecord
4
- class Migration
5
- class CommandRecorderTest < ActiveRecord::TestCase
6
- def setup
7
- connection = ActiveRecord::Base.connection
8
- @recorder = CommandRecorder.new(connection)
9
- end
10
-
11
- def test_respond_to_delegates
12
- recorder = CommandRecorder.new(Class.new {
13
- def america; end
14
- }.new)
15
- assert recorder.respond_to?(:america)
16
- end
17
-
18
- def test_send_calls_super
19
- assert_raises(NoMethodError) do
20
- @recorder.send(:non_existing_method, :horses)
21
- end
22
- end
23
-
24
- def test_send_delegates_to_record
25
- recorder = CommandRecorder.new(Class.new {
26
- def create_table(name); end
27
- }.new)
28
- assert recorder.respond_to?(:create_table), 'respond_to? create_table'
29
- recorder.send(:create_table, :horses)
30
- assert_equal [[:create_table, [:horses], nil]], recorder.commands
31
- end
32
-
33
- def test_unknown_commands_delegate
34
- recorder = CommandRecorder.new(stub(:foo => 'bar'))
35
- assert_equal 'bar', recorder.foo
36
- end
37
-
38
- def test_inverse_of_raise_exception_on_unknown_commands
39
- assert_raises(ActiveRecord::IrreversibleMigration) do
40
- @recorder.inverse_of :execute, ['some sql']
41
- end
42
- end
43
-
44
- def test_irreversible_commands_raise_exception
45
- assert_raises(ActiveRecord::IrreversibleMigration) do
46
- @recorder.revert{ @recorder.execute 'some sql' }
47
- end
48
- end
49
-
50
- def test_record
51
- @recorder.record :create_table, [:system_settings]
52
- assert_equal 1, @recorder.commands.length
53
- end
54
-
55
- def test_inverted_commands_are_reversed
56
- @recorder.revert do
57
- @recorder.record :create_table, [:hello]
58
- @recorder.record :create_table, [:world]
59
- end
60
- tables = @recorder.commands.map{|_cmd, args, _block| args}
61
- assert_equal [[:world], [:hello]], tables
62
- end
63
-
64
- def test_revert_order
65
- block = Proc.new{|t| t.string :name }
66
- @recorder.instance_eval do
67
- create_table("apples", &block)
68
- revert do
69
- create_table("bananas", &block)
70
- revert do
71
- create_table("clementines", &block)
72
- create_table("dates")
73
- end
74
- create_table("elderberries")
75
- end
76
- revert do
77
- create_table("figs", &block)
78
- create_table("grapes")
79
- end
80
- end
81
- assert_equal [[:create_table, ["apples"], block], [:drop_table, ["elderberries"], nil],
82
- [:create_table, ["clementines"], block], [:create_table, ["dates"], nil],
83
- [:drop_table, ["bananas"], block], [:drop_table, ["grapes"], nil],
84
- [:drop_table, ["figs"], block]], @recorder.commands
85
- end
86
-
87
- def test_invert_change_table
88
- @recorder.revert do
89
- @recorder.change_table :fruits do |t|
90
- t.string :name
91
- t.rename :kind, :cultivar
92
- end
93
- end
94
- assert_equal [
95
- [:rename_column, [:fruits, :cultivar, :kind]],
96
- [:remove_column, [:fruits, :name, :string, {}], nil],
97
- ], @recorder.commands
98
-
99
- assert_raises(ActiveRecord::IrreversibleMigration) do
100
- @recorder.revert do
101
- @recorder.change_table :fruits do |t|
102
- t.remove :kind
103
- end
104
- end
105
- end
106
- end
107
-
108
- def test_invert_create_table
109
- @recorder.revert do
110
- @recorder.record :create_table, [:system_settings]
111
- end
112
- drop_table = @recorder.commands.first
113
- assert_equal [:drop_table, [:system_settings], nil], drop_table
114
- end
115
-
116
- def test_invert_create_table_with_options_and_block
117
- block = Proc.new{}
118
- drop_table = @recorder.inverse_of :create_table, [:people_reminders, id: false], &block
119
- assert_equal [:drop_table, [:people_reminders, id: false], block], drop_table
120
- end
121
-
122
- def test_invert_drop_table
123
- block = Proc.new{}
124
- create_table = @recorder.inverse_of :drop_table, [:people_reminders, id: false], &block
125
- assert_equal [:create_table, [:people_reminders, id: false], block], create_table
126
- end
127
-
128
- def test_invert_drop_table_without_a_block_nor_option
129
- assert_raises(ActiveRecord::IrreversibleMigration) do
130
- @recorder.inverse_of :drop_table, [:people_reminders]
131
- end
132
- end
133
-
134
- def test_invert_create_join_table
135
- drop_join_table = @recorder.inverse_of :create_join_table, [:musics, :artists]
136
- assert_equal [:drop_join_table, [:musics, :artists], nil], drop_join_table
137
- end
138
-
139
- def test_invert_create_join_table_with_table_name
140
- drop_join_table = @recorder.inverse_of :create_join_table, [:musics, :artists, table_name: :catalog]
141
- assert_equal [:drop_join_table, [:musics, :artists, table_name: :catalog], nil], drop_join_table
142
- end
143
-
144
- def test_invert_drop_join_table
145
- block = Proc.new{}
146
- create_join_table = @recorder.inverse_of :drop_join_table, [:musics, :artists, table_name: :catalog], &block
147
- assert_equal [:create_join_table, [:musics, :artists, table_name: :catalog], block], create_join_table
148
- end
149
-
150
- def test_invert_rename_table
151
- rename = @recorder.inverse_of :rename_table, [:old, :new]
152
- assert_equal [:rename_table, [:new, :old]], rename
153
- end
154
-
155
- def test_invert_add_column
156
- remove = @recorder.inverse_of :add_column, [:table, :column, :type, {}]
157
- assert_equal [:remove_column, [:table, :column, :type, {}], nil], remove
158
- end
159
-
160
- def test_invert_change_column
161
- assert_raises(ActiveRecord::IrreversibleMigration) do
162
- @recorder.inverse_of :change_column, [:table, :column, :type, {}]
163
- end
164
- end
165
-
166
- def test_invert_change_column_default
167
- assert_raises(ActiveRecord::IrreversibleMigration) do
168
- @recorder.inverse_of :change_column_default, [:table, :column, 'default_value']
169
- end
170
- end
171
-
172
- def test_invert_change_column_null
173
- add = @recorder.inverse_of :change_column_null, [:table, :column, true]
174
- assert_equal [:change_column_null, [:table, :column, false]], add
175
- end
176
-
177
- def test_invert_remove_column
178
- add = @recorder.inverse_of :remove_column, [:table, :column, :type, {}]
179
- assert_equal [:add_column, [:table, :column, :type, {}], nil], add
180
- end
181
-
182
- def test_invert_remove_column_without_type
183
- assert_raises(ActiveRecord::IrreversibleMigration) do
184
- @recorder.inverse_of :remove_column, [:table, :column]
185
- end
186
- end
187
-
188
- def test_invert_rename_column
189
- rename = @recorder.inverse_of :rename_column, [:table, :old, :new]
190
- assert_equal [:rename_column, [:table, :new, :old]], rename
191
- end
192
-
193
- def test_invert_add_index
194
- remove = @recorder.inverse_of :add_index, [:table, [:one, :two]]
195
- assert_equal [:remove_index, [:table, {column: [:one, :two]}]], remove
196
- end
197
-
198
- def test_invert_add_index_with_name
199
- remove = @recorder.inverse_of :add_index, [:table, [:one, :two], name: "new_index"]
200
- assert_equal [:remove_index, [:table, {name: "new_index"}]], remove
201
- end
202
-
203
- def test_invert_add_index_with_no_options
204
- remove = @recorder.inverse_of :add_index, [:table, [:one, :two]]
205
- assert_equal [:remove_index, [:table, {column: [:one, :two]}]], remove
206
- end
207
-
208
- def test_invert_remove_index
209
- add = @recorder.inverse_of :remove_index, [:table, {column: [:one, :two], options: true}]
210
- assert_equal [:add_index, [:table, [:one, :two], options: true]], add
211
- end
212
-
213
- def test_invert_remove_index_with_name
214
- add = @recorder.inverse_of :remove_index, [:table, {column: [:one, :two], name: "new_index"}]
215
- assert_equal [:add_index, [:table, [:one, :two], name: "new_index"]], add
216
- end
217
-
218
- def test_invert_remove_index_with_no_special_options
219
- add = @recorder.inverse_of :remove_index, [:table, {column: [:one, :two]}]
220
- assert_equal [:add_index, [:table, [:one, :two], {}]], add
221
- end
222
-
223
- def test_invert_remove_index_with_no_column
224
- assert_raises(ActiveRecord::IrreversibleMigration) do
225
- @recorder.inverse_of :remove_index, [:table, name: "new_index"]
226
- end
227
- end
228
-
229
- def test_invert_rename_index
230
- rename = @recorder.inverse_of :rename_index, [:table, :old, :new]
231
- assert_equal [:rename_index, [:table, :new, :old]], rename
232
- end
233
-
234
- def test_invert_add_timestamps
235
- remove = @recorder.inverse_of :add_timestamps, [:table]
236
- assert_equal [:remove_timestamps, [:table], nil], remove
237
- end
238
-
239
- def test_invert_remove_timestamps
240
- add = @recorder.inverse_of :remove_timestamps, [:table, { null: true }]
241
- assert_equal [:add_timestamps, [:table, {null: true }], nil], add
242
- end
243
-
244
- def test_invert_add_reference
245
- remove = @recorder.inverse_of :add_reference, [:table, :taggable, { polymorphic: true }]
246
- assert_equal [:remove_reference, [:table, :taggable, { polymorphic: true }], nil], remove
247
- end
248
-
249
- def test_invert_add_belongs_to_alias
250
- remove = @recorder.inverse_of :add_belongs_to, [:table, :user]
251
- assert_equal [:remove_reference, [:table, :user], nil], remove
252
- end
253
-
254
- def test_invert_remove_reference
255
- add = @recorder.inverse_of :remove_reference, [:table, :taggable, { polymorphic: true }]
256
- assert_equal [:add_reference, [:table, :taggable, { polymorphic: true }], nil], add
257
- end
258
-
259
- def test_invert_remove_reference_with_index_and_foreign_key
260
- add = @recorder.inverse_of :remove_reference, [:table, :taggable, { index: true, foreign_key: true }]
261
- assert_equal [:add_reference, [:table, :taggable, { index: true, foreign_key: true }], nil], add
262
- end
263
-
264
- def test_invert_remove_belongs_to_alias
265
- add = @recorder.inverse_of :remove_belongs_to, [:table, :user]
266
- assert_equal [:add_reference, [:table, :user], nil], add
267
- end
268
-
269
- def test_invert_enable_extension
270
- disable = @recorder.inverse_of :enable_extension, ['uuid-ossp']
271
- assert_equal [:disable_extension, ['uuid-ossp'], nil], disable
272
- end
273
-
274
- def test_invert_disable_extension
275
- enable = @recorder.inverse_of :disable_extension, ['uuid-ossp']
276
- assert_equal [:enable_extension, ['uuid-ossp'], nil], enable
277
- end
278
-
279
- def test_invert_add_foreign_key
280
- enable = @recorder.inverse_of :add_foreign_key, [:dogs, :people]
281
- assert_equal [:remove_foreign_key, [:dogs, :people]], enable
282
- end
283
-
284
- def test_invert_add_foreign_key_with_column
285
- enable = @recorder.inverse_of :add_foreign_key, [:dogs, :people, column: "owner_id"]
286
- assert_equal [:remove_foreign_key, [:dogs, column: "owner_id"]], enable
287
- end
288
-
289
- def test_invert_add_foreign_key_with_column_and_name
290
- enable = @recorder.inverse_of :add_foreign_key, [:dogs, :people, column: "owner_id", name: "fk"]
291
- assert_equal [:remove_foreign_key, [:dogs, name: "fk"]], enable
292
- end
293
-
294
- def test_remove_foreign_key_is_irreversible
295
- assert_raises ActiveRecord::IrreversibleMigration do
296
- @recorder.inverse_of :remove_foreign_key, [:dogs, column: "owner_id"]
297
- end
298
-
299
- assert_raises ActiveRecord::IrreversibleMigration do
300
- @recorder.inverse_of :remove_foreign_key, [:dogs, name: "fk"]
301
- end
302
- end
303
- end
304
- end
305
- end
1
+ require "cases/helper"
2
+
3
+ module ActiveRecord
4
+ class Migration
5
+ class CommandRecorderTest < ActiveRecord::TestCase
6
+ def setup
7
+ connection = ActiveRecord::Base.connection
8
+ @recorder = CommandRecorder.new(connection)
9
+ end
10
+
11
+ def test_respond_to_delegates
12
+ recorder = CommandRecorder.new(Class.new {
13
+ def america; end
14
+ }.new)
15
+ assert recorder.respond_to?(:america)
16
+ end
17
+
18
+ def test_send_calls_super
19
+ assert_raises(NoMethodError) do
20
+ @recorder.send(:non_existing_method, :horses)
21
+ end
22
+ end
23
+
24
+ def test_send_delegates_to_record
25
+ recorder = CommandRecorder.new(Class.new {
26
+ def create_table(name); end
27
+ }.new)
28
+ assert recorder.respond_to?(:create_table), 'respond_to? create_table'
29
+ recorder.send(:create_table, :horses)
30
+ assert_equal [[:create_table, [:horses], nil]], recorder.commands
31
+ end
32
+
33
+ def test_unknown_commands_delegate
34
+ recorder = Struct.new(:foo)
35
+ recorder = CommandRecorder.new(recorder.new('bar'))
36
+ assert_equal 'bar', recorder.foo
37
+ end
38
+
39
+ def test_inverse_of_raise_exception_on_unknown_commands
40
+ assert_raises(ActiveRecord::IrreversibleMigration) do
41
+ @recorder.inverse_of :execute, ['some sql']
42
+ end
43
+ end
44
+
45
+ def test_irreversible_commands_raise_exception
46
+ assert_raises(ActiveRecord::IrreversibleMigration) do
47
+ @recorder.revert{ @recorder.execute 'some sql' }
48
+ end
49
+ end
50
+
51
+ def test_record
52
+ @recorder.record :create_table, [:system_settings]
53
+ assert_equal 1, @recorder.commands.length
54
+ end
55
+
56
+ def test_inverted_commands_are_reversed
57
+ @recorder.revert do
58
+ @recorder.record :create_table, [:hello]
59
+ @recorder.record :create_table, [:world]
60
+ end
61
+ tables = @recorder.commands.map{|_cmd, args, _block| args}
62
+ assert_equal [[:world], [:hello]], tables
63
+ end
64
+
65
+ def test_revert_order
66
+ block = Proc.new{|t| t.string :name }
67
+ @recorder.instance_eval do
68
+ create_table("apples", &block)
69
+ revert do
70
+ create_table("bananas", &block)
71
+ revert do
72
+ create_table("clementines", &block)
73
+ create_table("dates")
74
+ end
75
+ create_table("elderberries")
76
+ end
77
+ revert do
78
+ create_table("figs", &block)
79
+ create_table("grapes")
80
+ end
81
+ end
82
+ assert_equal [[:create_table, ["apples"], block], [:drop_table, ["elderberries"], nil],
83
+ [:create_table, ["clementines"], block], [:create_table, ["dates"], nil],
84
+ [:drop_table, ["bananas"], block], [:drop_table, ["grapes"], nil],
85
+ [:drop_table, ["figs"], block]], @recorder.commands
86
+ end
87
+
88
+ def test_invert_change_table
89
+ @recorder.revert do
90
+ @recorder.change_table :fruits do |t|
91
+ t.string :name
92
+ t.rename :kind, :cultivar
93
+ end
94
+ end
95
+ assert_equal [
96
+ [:rename_column, [:fruits, :cultivar, :kind]],
97
+ [:remove_column, [:fruits, :name, :string, {}], nil],
98
+ ], @recorder.commands
99
+
100
+ assert_raises(ActiveRecord::IrreversibleMigration) do
101
+ @recorder.revert do
102
+ @recorder.change_table :fruits do |t|
103
+ t.remove :kind
104
+ end
105
+ end
106
+ end
107
+ end
108
+
109
+ def test_invert_create_table
110
+ @recorder.revert do
111
+ @recorder.record :create_table, [:system_settings]
112
+ end
113
+ drop_table = @recorder.commands.first
114
+ assert_equal [:drop_table, [:system_settings], nil], drop_table
115
+ end
116
+
117
+ def test_invert_create_table_with_options_and_block
118
+ block = Proc.new{}
119
+ drop_table = @recorder.inverse_of :create_table, [:people_reminders, id: false], &block
120
+ assert_equal [:drop_table, [:people_reminders, id: false], block], drop_table
121
+ end
122
+
123
+ def test_invert_drop_table
124
+ block = Proc.new{}
125
+ create_table = @recorder.inverse_of :drop_table, [:people_reminders, id: false], &block
126
+ assert_equal [:create_table, [:people_reminders, id: false], block], create_table
127
+ end
128
+
129
+ def test_invert_drop_table_without_a_block_nor_option
130
+ assert_raises(ActiveRecord::IrreversibleMigration) do
131
+ @recorder.inverse_of :drop_table, [:people_reminders]
132
+ end
133
+ end
134
+
135
+ def test_invert_create_join_table
136
+ drop_join_table = @recorder.inverse_of :create_join_table, [:musics, :artists]
137
+ assert_equal [:drop_join_table, [:musics, :artists], nil], drop_join_table
138
+ end
139
+
140
+ def test_invert_create_join_table_with_table_name
141
+ drop_join_table = @recorder.inverse_of :create_join_table, [:musics, :artists, table_name: :catalog]
142
+ assert_equal [:drop_join_table, [:musics, :artists, table_name: :catalog], nil], drop_join_table
143
+ end
144
+
145
+ def test_invert_drop_join_table
146
+ block = Proc.new{}
147
+ create_join_table = @recorder.inverse_of :drop_join_table, [:musics, :artists, table_name: :catalog], &block
148
+ assert_equal [:create_join_table, [:musics, :artists, table_name: :catalog], block], create_join_table
149
+ end
150
+
151
+ def test_invert_rename_table
152
+ rename = @recorder.inverse_of :rename_table, [:old, :new]
153
+ assert_equal [:rename_table, [:new, :old]], rename
154
+ end
155
+
156
+ def test_invert_add_column
157
+ remove = @recorder.inverse_of :add_column, [:table, :column, :type, {}]
158
+ assert_equal [:remove_column, [:table, :column, :type, {}], nil], remove
159
+ end
160
+
161
+ def test_invert_change_column
162
+ assert_raises(ActiveRecord::IrreversibleMigration) do
163
+ @recorder.inverse_of :change_column, [:table, :column, :type, {}]
164
+ end
165
+ end
166
+
167
+ def test_invert_change_column_default
168
+ assert_raises(ActiveRecord::IrreversibleMigration) do
169
+ @recorder.inverse_of :change_column_default, [:table, :column, 'default_value']
170
+ end
171
+ end
172
+
173
+ def test_invert_change_column_default_with_from_and_to
174
+ change = @recorder.inverse_of :change_column_default, [:table, :column, from: "old_value", to: "new_value"]
175
+ assert_equal [:change_column_default, [:table, :column, from: "new_value", to: "old_value"]], change
176
+ end
177
+
178
+ def test_invert_change_column_default_with_from_and_to_with_boolean
179
+ change = @recorder.inverse_of :change_column_default, [:table, :column, from: true, to: false]
180
+ assert_equal [:change_column_default, [:table, :column, from: false, to: true]], change
181
+ end
182
+
183
+ def test_invert_change_column_null
184
+ add = @recorder.inverse_of :change_column_null, [:table, :column, true]
185
+ assert_equal [:change_column_null, [:table, :column, false]], add
186
+ end
187
+
188
+ def test_invert_remove_column
189
+ add = @recorder.inverse_of :remove_column, [:table, :column, :type, {}]
190
+ assert_equal [:add_column, [:table, :column, :type, {}], nil], add
191
+ end
192
+
193
+ def test_invert_remove_column_without_type
194
+ assert_raises(ActiveRecord::IrreversibleMigration) do
195
+ @recorder.inverse_of :remove_column, [:table, :column]
196
+ end
197
+ end
198
+
199
+ def test_invert_rename_column
200
+ rename = @recorder.inverse_of :rename_column, [:table, :old, :new]
201
+ assert_equal [:rename_column, [:table, :new, :old]], rename
202
+ end
203
+
204
+ def test_invert_add_index
205
+ remove = @recorder.inverse_of :add_index, [:table, [:one, :two]]
206
+ assert_equal [:remove_index, [:table, {column: [:one, :two]}]], remove
207
+ end
208
+
209
+ def test_invert_add_index_with_name
210
+ remove = @recorder.inverse_of :add_index, [:table, [:one, :two], name: "new_index"]
211
+ assert_equal [:remove_index, [:table, {name: "new_index"}]], remove
212
+ end
213
+
214
+ def test_invert_add_index_with_no_options
215
+ remove = @recorder.inverse_of :add_index, [:table, [:one, :two]]
216
+ assert_equal [:remove_index, [:table, {column: [:one, :two]}]], remove
217
+ end
218
+
219
+ def test_invert_remove_index
220
+ add = @recorder.inverse_of :remove_index, [:table, :one]
221
+ assert_equal [:add_index, [:table, :one]], add
222
+ end
223
+
224
+ def test_invert_remove_index_with_column
225
+ add = @recorder.inverse_of :remove_index, [:table, {column: [:one, :two], options: true}]
226
+ assert_equal [:add_index, [:table, [:one, :two], options: true]], add
227
+ end
228
+
229
+ def test_invert_remove_index_with_name
230
+ add = @recorder.inverse_of :remove_index, [:table, {column: [:one, :two], name: "new_index"}]
231
+ assert_equal [:add_index, [:table, [:one, :two], name: "new_index"]], add
232
+ end
233
+
234
+ def test_invert_remove_index_with_no_special_options
235
+ add = @recorder.inverse_of :remove_index, [:table, {column: [:one, :two]}]
236
+ assert_equal [:add_index, [:table, [:one, :two], {}]], add
237
+ end
238
+
239
+ def test_invert_remove_index_with_no_column
240
+ assert_raises(ActiveRecord::IrreversibleMigration) do
241
+ @recorder.inverse_of :remove_index, [:table, name: "new_index"]
242
+ end
243
+ end
244
+
245
+ def test_invert_rename_index
246
+ rename = @recorder.inverse_of :rename_index, [:table, :old, :new]
247
+ assert_equal [:rename_index, [:table, :new, :old]], rename
248
+ end
249
+
250
+ def test_invert_add_timestamps
251
+ remove = @recorder.inverse_of :add_timestamps, [:table]
252
+ assert_equal [:remove_timestamps, [:table], nil], remove
253
+ end
254
+
255
+ def test_invert_remove_timestamps
256
+ add = @recorder.inverse_of :remove_timestamps, [:table, { null: true }]
257
+ assert_equal [:add_timestamps, [:table, {null: true }], nil], add
258
+ end
259
+
260
+ def test_invert_add_reference
261
+ remove = @recorder.inverse_of :add_reference, [:table, :taggable, { polymorphic: true }]
262
+ assert_equal [:remove_reference, [:table, :taggable, { polymorphic: true }], nil], remove
263
+ end
264
+
265
+ def test_invert_add_belongs_to_alias
266
+ remove = @recorder.inverse_of :add_belongs_to, [:table, :user]
267
+ assert_equal [:remove_reference, [:table, :user], nil], remove
268
+ end
269
+
270
+ def test_invert_remove_reference
271
+ add = @recorder.inverse_of :remove_reference, [:table, :taggable, { polymorphic: true }]
272
+ assert_equal [:add_reference, [:table, :taggable, { polymorphic: true }], nil], add
273
+ end
274
+
275
+ def test_invert_remove_reference_with_index_and_foreign_key
276
+ add = @recorder.inverse_of :remove_reference, [:table, :taggable, { index: true, foreign_key: true }]
277
+ assert_equal [:add_reference, [:table, :taggable, { index: true, foreign_key: true }], nil], add
278
+ end
279
+
280
+ def test_invert_remove_belongs_to_alias
281
+ add = @recorder.inverse_of :remove_belongs_to, [:table, :user]
282
+ assert_equal [:add_reference, [:table, :user], nil], add
283
+ end
284
+
285
+ def test_invert_enable_extension
286
+ disable = @recorder.inverse_of :enable_extension, ['uuid-ossp']
287
+ assert_equal [:disable_extension, ['uuid-ossp'], nil], disable
288
+ end
289
+
290
+ def test_invert_disable_extension
291
+ enable = @recorder.inverse_of :disable_extension, ['uuid-ossp']
292
+ assert_equal [:enable_extension, ['uuid-ossp'], nil], enable
293
+ end
294
+
295
+ def test_invert_add_foreign_key
296
+ enable = @recorder.inverse_of :add_foreign_key, [:dogs, :people]
297
+ assert_equal [:remove_foreign_key, [:dogs, :people]], enable
298
+ end
299
+
300
+ def test_invert_remove_foreign_key
301
+ enable = @recorder.inverse_of :remove_foreign_key, [:dogs, :people]
302
+ assert_equal [:add_foreign_key, [:dogs, :people]], enable
303
+ end
304
+
305
+ def test_invert_add_foreign_key_with_column
306
+ enable = @recorder.inverse_of :add_foreign_key, [:dogs, :people, column: "owner_id"]
307
+ assert_equal [:remove_foreign_key, [:dogs, column: "owner_id"]], enable
308
+ end
309
+
310
+ def test_invert_remove_foreign_key_with_column
311
+ enable = @recorder.inverse_of :remove_foreign_key, [:dogs, :people, column: "owner_id"]
312
+ assert_equal [:add_foreign_key, [:dogs, :people, column: "owner_id"]], enable
313
+ end
314
+
315
+ def test_invert_add_foreign_key_with_column_and_name
316
+ enable = @recorder.inverse_of :add_foreign_key, [:dogs, :people, column: "owner_id", name: "fk"]
317
+ assert_equal [:remove_foreign_key, [:dogs, name: "fk"]], enable
318
+ end
319
+
320
+ def test_invert_remove_foreign_key_with_column_and_name
321
+ enable = @recorder.inverse_of :remove_foreign_key, [:dogs, :people, column: "owner_id", name: "fk"]
322
+ assert_equal [:add_foreign_key, [:dogs, :people, column: "owner_id", name: "fk"]], enable
323
+ end
324
+
325
+ def test_invert_remove_foreign_key_with_primary_key
326
+ enable = @recorder.inverse_of :remove_foreign_key, [:dogs, :people, primary_key: "person_id"]
327
+ assert_equal [:add_foreign_key, [:dogs, :people, primary_key: "person_id"]], enable
328
+ end
329
+
330
+ def test_invert_remove_foreign_key_with_on_delete_on_update
331
+ enable = @recorder.inverse_of :remove_foreign_key, [:dogs, :people, on_delete: :nullify, on_update: :cascade]
332
+ assert_equal [:add_foreign_key, [:dogs, :people, on_delete: :nullify, on_update: :cascade]], enable
333
+ end
334
+
335
+ def test_invert_remove_foreign_key_is_irreversible_without_to_table
336
+ assert_raises ActiveRecord::IrreversibleMigration do
337
+ @recorder.inverse_of :remove_foreign_key, [:dogs, column: "owner_id"]
338
+ end
339
+
340
+ assert_raises ActiveRecord::IrreversibleMigration do
341
+ @recorder.inverse_of :remove_foreign_key, [:dogs, name: "fk"]
342
+ end
343
+
344
+ assert_raises ActiveRecord::IrreversibleMigration do
345
+ @recorder.inverse_of :remove_foreign_key, [:dogs]
346
+ end
347
+ end
348
+ end
349
+ end
350
+ end