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,388 +1,470 @@
1
- require "cases/helper"
2
- require "cases/migration/helper"
3
-
4
- class MigratorTest < ActiveRecord::TestCase
5
- self.use_transactional_fixtures = false
6
-
7
- # Use this class to sense if migrations have gone
8
- # up or down.
9
- class Sensor < ActiveRecord::Migration
10
- attr_reader :went_up, :went_down
11
-
12
- def initialize name = self.class.name, version = nil
13
- super
14
- @went_up = false
15
- @went_down = false
16
- end
17
-
18
- def up; @went_up = true; end
19
- def down; @went_down = true; end
20
- end
21
-
22
- def setup
23
- super
24
- ActiveRecord::SchemaMigration.create_table
25
- ActiveRecord::SchemaMigration.delete_all rescue nil
26
- @verbose_was = ActiveRecord::Migration.verbose
27
- ActiveRecord::Migration.message_count = 0
28
- ActiveRecord::Migration.class_eval do
29
- undef :puts
30
- def puts(*)
31
- ActiveRecord::Migration.message_count += 1
32
- end
33
- end
34
- end
35
-
36
- teardown do
37
- ActiveRecord::SchemaMigration.delete_all rescue nil
38
- ActiveRecord::Migration.verbose = @verbose_was
39
- ActiveRecord::Migration.class_eval do
40
- undef :puts
41
- def puts(*)
42
- super
43
- end
44
- end
45
- end
46
-
47
- def test_migrator_with_duplicate_names
48
- assert_raises(ActiveRecord::DuplicateMigrationNameError, "Multiple migrations have the name Chunky") do
49
- list = [ActiveRecord::Migration.new('Chunky'), ActiveRecord::Migration.new('Chunky')]
50
- ActiveRecord::Migrator.new(:up, list)
51
- end
52
- end
53
-
54
- def test_migrator_with_duplicate_versions
55
- assert_raises(ActiveRecord::DuplicateMigrationVersionError) do
56
- list = [ActiveRecord::Migration.new('Foo', 1), ActiveRecord::Migration.new('Bar', 1)]
57
- ActiveRecord::Migrator.new(:up, list)
58
- end
59
- end
60
-
61
- def test_migrator_with_missing_version_numbers
62
- assert_raises(ActiveRecord::UnknownMigrationVersionError) do
63
- list = [ActiveRecord::Migration.new('Foo', 1), ActiveRecord::Migration.new('Bar', 2)]
64
- ActiveRecord::Migrator.new(:up, list, 3).run
65
- end
66
- end
67
-
68
- def test_finds_migrations
69
- migrations = ActiveRecord::Migrator.migrations(MIGRATIONS_ROOT + "/valid")
70
-
71
- [[1, 'ValidPeopleHaveLastNames'], [2, 'WeNeedReminders'], [3, 'InnocentJointable']].each_with_index do |pair, i|
72
- assert_equal migrations[i].version, pair.first
73
- assert_equal migrations[i].name, pair.last
74
- end
75
- end
76
-
77
- def test_finds_migrations_in_subdirectories
78
- migrations = ActiveRecord::Migrator.migrations(MIGRATIONS_ROOT + "/valid_with_subdirectories")
79
-
80
- [[1, 'ValidPeopleHaveLastNames'], [2, 'WeNeedReminders'], [3, 'InnocentJointable']].each_with_index do |pair, i|
81
- assert_equal migrations[i].version, pair.first
82
- assert_equal migrations[i].name, pair.last
83
- end
84
- end
85
-
86
- def test_finds_migrations_from_two_directories
87
- directories = [MIGRATIONS_ROOT + '/valid_with_timestamps', MIGRATIONS_ROOT + '/to_copy_with_timestamps']
88
- migrations = ActiveRecord::Migrator.migrations directories
89
-
90
- [[20090101010101, "PeopleHaveHobbies"],
91
- [20090101010202, "PeopleHaveDescriptions"],
92
- [20100101010101, "ValidWithTimestampsPeopleHaveLastNames"],
93
- [20100201010101, "ValidWithTimestampsWeNeedReminders"],
94
- [20100301010101, "ValidWithTimestampsInnocentJointable"]].each_with_index do |pair, i|
95
- assert_equal pair.first, migrations[i].version
96
- assert_equal pair.last, migrations[i].name
97
- end
98
- end
99
-
100
- def test_finds_migrations_in_numbered_directory
101
- migrations = ActiveRecord::Migrator.migrations [MIGRATIONS_ROOT + '/10_urban']
102
- assert_equal 9, migrations[0].version
103
- assert_equal 'AddExpressions', migrations[0].name
104
- end
105
-
106
- def test_relative_migrations
107
- list = Dir.chdir(MIGRATIONS_ROOT) do
108
- ActiveRecord::Migrator.migrations("valid")
109
- end
110
-
111
- migration_proxy = list.find { |item|
112
- item.name == 'ValidPeopleHaveLastNames'
113
- }
114
- assert migration_proxy, 'should find pending migration'
115
- end
116
-
117
- def test_finds_pending_migrations
118
- ActiveRecord::SchemaMigration.create!(:version => '1')
119
- migration_list = [ActiveRecord::Migration.new('foo', 1), ActiveRecord::Migration.new('bar', 3)]
120
- migrations = ActiveRecord::Migrator.new(:up, migration_list).pending_migrations
121
-
122
- assert_equal 1, migrations.size
123
- assert_equal migration_list.last, migrations.first
124
- end
125
-
126
- def test_migrator_interleaved_migrations
127
- pass_one = [Sensor.new('One', 1)]
128
-
129
- ActiveRecord::Migrator.new(:up, pass_one).migrate
130
- assert pass_one.first.went_up
131
- assert_not pass_one.first.went_down
132
-
133
- pass_two = [Sensor.new('One', 1), Sensor.new('Three', 3)]
134
- ActiveRecord::Migrator.new(:up, pass_two).migrate
135
- assert_not pass_two[0].went_up
136
- assert pass_two[1].went_up
137
- assert pass_two.all? { |x| !x.went_down }
138
-
139
- pass_three = [Sensor.new('One', 1),
140
- Sensor.new('Two', 2),
141
- Sensor.new('Three', 3)]
142
-
143
- ActiveRecord::Migrator.new(:down, pass_three).migrate
144
- assert pass_three[0].went_down
145
- assert_not pass_three[1].went_down
146
- assert pass_three[2].went_down
147
- end
148
-
149
- def test_up_calls_up
150
- migrations = [Sensor.new(nil, 0), Sensor.new(nil, 1), Sensor.new(nil, 2)]
151
- ActiveRecord::Migrator.new(:up, migrations).migrate
152
- assert migrations.all? { |m| m.went_up }
153
- assert migrations.all? { |m| !m.went_down }
154
- assert_equal 2, ActiveRecord::Migrator.current_version
155
- end
156
-
157
- def test_down_calls_down
158
- test_up_calls_up
159
-
160
- migrations = [Sensor.new(nil, 0), Sensor.new(nil, 1), Sensor.new(nil, 2)]
161
- ActiveRecord::Migrator.new(:down, migrations).migrate
162
- assert migrations.all? { |m| !m.went_up }
163
- assert migrations.all? { |m| m.went_down }
164
- assert_equal 0, ActiveRecord::Migrator.current_version
165
- end
166
-
167
- def test_current_version
168
- ActiveRecord::SchemaMigration.create!(:version => '1000')
169
- assert_equal 1000, ActiveRecord::Migrator.current_version
170
- end
171
-
172
- def test_migrator_one_up
173
- calls, migrations = sensors(3)
174
-
175
- ActiveRecord::Migrator.new(:up, migrations, 1).migrate
176
- assert_equal [[:up, 1]], calls
177
- calls.clear
178
-
179
- ActiveRecord::Migrator.new(:up, migrations, 2).migrate
180
- assert_equal [[:up, 2]], calls
181
- end
182
-
183
- def test_migrator_one_down
184
- calls, migrations = sensors(3)
185
-
186
- ActiveRecord::Migrator.new(:up, migrations).migrate
187
- assert_equal [[:up, 1], [:up, 2], [:up, 3]], calls
188
- calls.clear
189
-
190
- ActiveRecord::Migrator.new(:down, migrations, 1).migrate
191
-
192
- assert_equal [[:down, 3], [:down, 2]], calls
193
- end
194
-
195
- def test_migrator_one_up_one_down
196
- calls, migrations = sensors(3)
197
-
198
- ActiveRecord::Migrator.new(:up, migrations, 1).migrate
199
- assert_equal [[:up, 1]], calls
200
- calls.clear
201
-
202
- ActiveRecord::Migrator.new(:down, migrations, 0).migrate
203
- assert_equal [[:down, 1]], calls
204
- end
205
-
206
- def test_migrator_double_up
207
- calls, migrations = sensors(3)
208
- assert_equal(0, ActiveRecord::Migrator.current_version)
209
-
210
- ActiveRecord::Migrator.new(:up, migrations, 1).migrate
211
- assert_equal [[:up, 1]], calls
212
- calls.clear
213
-
214
- ActiveRecord::Migrator.new(:up, migrations, 1).migrate
215
- assert_equal [], calls
216
- end
217
-
218
- def test_migrator_double_down
219
- calls, migrations = sensors(3)
220
-
221
- assert_equal(0, ActiveRecord::Migrator.current_version)
222
-
223
- ActiveRecord::Migrator.new(:up, migrations, 1).run
224
- assert_equal [[:up, 1]], calls
225
- calls.clear
226
-
227
- ActiveRecord::Migrator.new(:down, migrations, 1).run
228
- assert_equal [[:down, 1]], calls
229
- calls.clear
230
-
231
- ActiveRecord::Migrator.new(:down, migrations, 1).run
232
- assert_equal [], calls
233
-
234
- assert_equal(0, ActiveRecord::Migrator.current_version)
235
- end
236
-
237
- def test_migrator_verbosity
238
- _, migrations = sensors(3)
239
-
240
- ActiveRecord::Migrator.new(:up, migrations, 1).migrate
241
- assert_not_equal 0, ActiveRecord::Migration.message_count
242
-
243
- ActiveRecord::Migration.message_count = 0
244
-
245
- ActiveRecord::Migrator.new(:down, migrations, 0).migrate
246
- assert_not_equal 0, ActiveRecord::Migration.message_count
247
- end
248
-
249
- def test_migrator_verbosity_off
250
- _, migrations = sensors(3)
251
-
252
- ActiveRecord::Migration.message_count = 0
253
- ActiveRecord::Migration.verbose = false
254
- ActiveRecord::Migrator.new(:up, migrations, 1).migrate
255
- assert_equal 0, ActiveRecord::Migration.message_count
256
- ActiveRecord::Migrator.new(:down, migrations, 0).migrate
257
- assert_equal 0, ActiveRecord::Migration.message_count
258
- end
259
-
260
- def test_target_version_zero_should_run_only_once
261
- calls, migrations = sensors(3)
262
-
263
- # migrate up to 1
264
- ActiveRecord::Migrator.new(:up, migrations, 1).migrate
265
- assert_equal [[:up, 1]], calls
266
- calls.clear
267
-
268
- # migrate down to 0
269
- ActiveRecord::Migrator.new(:down, migrations, 0).migrate
270
- assert_equal [[:down, 1]], calls
271
- calls.clear
272
-
273
- # migrate down to 0 again
274
- ActiveRecord::Migrator.new(:down, migrations, 0).migrate
275
- assert_equal [], calls
276
- end
277
-
278
- def test_migrator_going_down_due_to_version_target
279
- calls, migrator = migrator_class(3)
280
-
281
- migrator.up("valid", 1)
282
- assert_equal [[:up, 1]], calls
283
- calls.clear
284
-
285
- migrator.migrate("valid", 0)
286
- assert_equal [[:down, 1]], calls
287
- calls.clear
288
-
289
- migrator.migrate("valid")
290
- assert_equal [[:up, 1], [:up, 2], [:up, 3]], calls
291
- end
292
-
293
- def test_migrator_rollback
294
- _, migrator = migrator_class(3)
295
-
296
- migrator.migrate("valid")
297
- assert_equal(3, ActiveRecord::Migrator.current_version)
298
-
299
- migrator.rollback("valid")
300
- assert_equal(2, ActiveRecord::Migrator.current_version)
301
-
302
- migrator.rollback("valid")
303
- assert_equal(1, ActiveRecord::Migrator.current_version)
304
-
305
- migrator.rollback("valid")
306
- assert_equal(0, ActiveRecord::Migrator.current_version)
307
-
308
- migrator.rollback("valid")
309
- assert_equal(0, ActiveRecord::Migrator.current_version)
310
- end
311
-
312
- def test_migrator_db_has_no_schema_migrations_table
313
- _, migrator = migrator_class(3)
314
-
315
- ActiveRecord::Base.connection.execute("DROP TABLE schema_migrations")
316
- assert_not ActiveRecord::Base.connection.table_exists?('schema_migrations')
317
- migrator.migrate("valid", 1)
318
- assert ActiveRecord::Base.connection.table_exists?('schema_migrations')
319
- end
320
-
321
- def test_migrator_forward
322
- _, migrator = migrator_class(3)
323
- migrator.migrate("/valid", 1)
324
- assert_equal(1, ActiveRecord::Migrator.current_version)
325
-
326
- migrator.forward("/valid", 2)
327
- assert_equal(3, ActiveRecord::Migrator.current_version)
328
-
329
- migrator.forward("/valid")
330
- assert_equal(3, ActiveRecord::Migrator.current_version)
331
- end
332
-
333
- def test_only_loads_pending_migrations
334
- # migrate up to 1
335
- ActiveRecord::SchemaMigration.create!(:version => '1')
336
-
337
- calls, migrator = migrator_class(3)
338
- migrator.migrate("valid", nil)
339
-
340
- assert_equal [[:up, 2], [:up, 3]], calls
341
- end
342
-
343
- def test_get_all_versions
344
- _, migrator = migrator_class(3)
345
-
346
- migrator.migrate("valid")
347
- assert_equal([1,2,3], ActiveRecord::Migrator.get_all_versions)
348
-
349
- migrator.rollback("valid")
350
- assert_equal([1,2], ActiveRecord::Migrator.get_all_versions)
351
-
352
- migrator.rollback("valid")
353
- assert_equal([1], ActiveRecord::Migrator.get_all_versions)
354
-
355
- migrator.rollback("valid")
356
- assert_equal([], ActiveRecord::Migrator.get_all_versions)
357
- end
358
-
359
- private
360
- def m(name, version)
361
- x = Sensor.new name, version
362
- x.extend(Module.new {
363
- define_method(:up) { yield(:up, x); super() }
364
- define_method(:down) { yield(:down, x); super() }
365
- }) if block_given?
366
- end
367
-
368
- def sensors(count)
369
- calls = []
370
- migrations = count.times.map { |i|
371
- m(nil, i + 1) { |c,migration|
372
- calls << [c, migration.version]
373
- }
374
- }
375
- [calls, migrations]
376
- end
377
-
378
- def migrator_class(count)
379
- calls, migrations = sensors(count)
380
-
381
- migrator = Class.new(ActiveRecord::Migrator).extend(Module.new {
382
- define_method(:migrations) { |paths|
383
- migrations
384
- }
385
- })
386
- [calls, migrator]
387
- end
388
- end
1
+ require "cases/helper"
2
+ require "cases/migration/helper"
3
+
4
+ class MigratorTest < ActiveRecord::TestCase
5
+ self.use_transactional_tests = false
6
+
7
+ # Use this class to sense if migrations have gone
8
+ # up or down.
9
+ class Sensor < ActiveRecord::Migration::Current
10
+ attr_reader :went_up, :went_down
11
+
12
+ def initialize name = self.class.name, version = nil
13
+ super
14
+ @went_up = false
15
+ @went_down = false
16
+ end
17
+
18
+ def up; @went_up = true; end
19
+ def down; @went_down = true; end
20
+ end
21
+
22
+ def setup
23
+ super
24
+ ActiveRecord::SchemaMigration.create_table
25
+ ActiveRecord::SchemaMigration.delete_all rescue nil
26
+ @verbose_was = ActiveRecord::Migration.verbose
27
+ ActiveRecord::Migration.message_count = 0
28
+ ActiveRecord::Migration.class_eval do
29
+ undef :puts
30
+ def puts(*)
31
+ ActiveRecord::Migration.message_count += 1
32
+ end
33
+ end
34
+ end
35
+
36
+ teardown do
37
+ ActiveRecord::SchemaMigration.delete_all rescue nil
38
+ ActiveRecord::Migration.verbose = @verbose_was
39
+ ActiveRecord::Migration.class_eval do
40
+ undef :puts
41
+ def puts(*)
42
+ super
43
+ end
44
+ end
45
+ end
46
+
47
+ def test_migrator_with_duplicate_names
48
+ assert_raises(ActiveRecord::DuplicateMigrationNameError, "Multiple migrations have the name Chunky") do
49
+ list = [ActiveRecord::Migration.new('Chunky'), ActiveRecord::Migration.new('Chunky')]
50
+ ActiveRecord::Migrator.new(:up, list)
51
+ end
52
+ end
53
+
54
+ def test_migrator_with_duplicate_versions
55
+ assert_raises(ActiveRecord::DuplicateMigrationVersionError) do
56
+ list = [ActiveRecord::Migration.new('Foo', 1), ActiveRecord::Migration.new('Bar', 1)]
57
+ ActiveRecord::Migrator.new(:up, list)
58
+ end
59
+ end
60
+
61
+ def test_migrator_with_missing_version_numbers
62
+ assert_raises(ActiveRecord::UnknownMigrationVersionError) do
63
+ list = [ActiveRecord::Migration.new('Foo', 1), ActiveRecord::Migration.new('Bar', 2)]
64
+ ActiveRecord::Migrator.new(:up, list, 3).run
65
+ end
66
+ end
67
+
68
+ def test_finds_migrations
69
+ migrations = ActiveRecord::Migrator.migrations(MIGRATIONS_ROOT + "/valid")
70
+
71
+ [[1, 'ValidPeopleHaveLastNames'], [2, 'WeNeedReminders'], [3, 'InnocentJointable']].each_with_index do |pair, i|
72
+ assert_equal migrations[i].version, pair.first
73
+ assert_equal migrations[i].name, pair.last
74
+ end
75
+ end
76
+
77
+ def test_finds_migrations_in_subdirectories
78
+ migrations = ActiveRecord::Migrator.migrations(MIGRATIONS_ROOT + "/valid_with_subdirectories")
79
+
80
+ [[1, 'ValidPeopleHaveLastNames'], [2, 'WeNeedReminders'], [3, 'InnocentJointable']].each_with_index do |pair, i|
81
+ assert_equal migrations[i].version, pair.first
82
+ assert_equal migrations[i].name, pair.last
83
+ end
84
+ end
85
+
86
+ def test_finds_migrations_from_two_directories
87
+ directories = [MIGRATIONS_ROOT + '/valid_with_timestamps', MIGRATIONS_ROOT + '/to_copy_with_timestamps']
88
+ migrations = ActiveRecord::Migrator.migrations directories
89
+
90
+ [[20090101010101, "PeopleHaveHobbies"],
91
+ [20090101010202, "PeopleHaveDescriptions"],
92
+ [20100101010101, "ValidWithTimestampsPeopleHaveLastNames"],
93
+ [20100201010101, "ValidWithTimestampsWeNeedReminders"],
94
+ [20100301010101, "ValidWithTimestampsInnocentJointable"]].each_with_index do |pair, i|
95
+ assert_equal pair.first, migrations[i].version
96
+ assert_equal pair.last, migrations[i].name
97
+ end
98
+ end
99
+
100
+ def test_finds_migrations_in_numbered_directory
101
+ migrations = ActiveRecord::Migrator.migrations [MIGRATIONS_ROOT + '/10_urban']
102
+ assert_equal 9, migrations[0].version
103
+ assert_equal 'AddExpressions', migrations[0].name
104
+ end
105
+
106
+ def test_relative_migrations
107
+ list = Dir.chdir(MIGRATIONS_ROOT) do
108
+ ActiveRecord::Migrator.migrations("valid")
109
+ end
110
+
111
+ migration_proxy = list.find { |item|
112
+ item.name == 'ValidPeopleHaveLastNames'
113
+ }
114
+ assert migration_proxy, 'should find pending migration'
115
+ end
116
+
117
+ def test_finds_pending_migrations
118
+ ActiveRecord::SchemaMigration.create!(:version => '1')
119
+ migration_list = [ActiveRecord::Migration.new('foo', 1), ActiveRecord::Migration.new('bar', 3)]
120
+ migrations = ActiveRecord::Migrator.new(:up, migration_list).pending_migrations
121
+
122
+ assert_equal 1, migrations.size
123
+ assert_equal migration_list.last, migrations.first
124
+ end
125
+
126
+ def test_migrations_status
127
+ path = MIGRATIONS_ROOT + "/valid"
128
+
129
+ ActiveRecord::SchemaMigration.create(version: 2)
130
+ ActiveRecord::SchemaMigration.create(version: 10)
131
+
132
+ assert_equal [
133
+ ["down", "001", "Valid people have last names"],
134
+ ["up", "002", "We need reminders"],
135
+ ["down", "003", "Innocent jointable"],
136
+ ["up", "010", "********** NO FILE **********"],
137
+ ], ActiveRecord::Migrator.migrations_status(path)
138
+ end
139
+
140
+ def test_migrations_status_in_subdirectories
141
+ path = MIGRATIONS_ROOT + "/valid_with_subdirectories"
142
+
143
+ ActiveRecord::SchemaMigration.create(version: 2)
144
+ ActiveRecord::SchemaMigration.create(version: 10)
145
+
146
+ assert_equal [
147
+ ["down", "001", "Valid people have last names"],
148
+ ["up", "002", "We need reminders"],
149
+ ["down", "003", "Innocent jointable"],
150
+ ["up", "010", "********** NO FILE **********"],
151
+ ], ActiveRecord::Migrator.migrations_status(path)
152
+ end
153
+
154
+ def test_migrations_status_with_schema_define_in_subdirectories
155
+ path = MIGRATIONS_ROOT + "/valid_with_subdirectories"
156
+ prev_paths = ActiveRecord::Migrator.migrations_paths
157
+ ActiveRecord::Migrator.migrations_paths = path
158
+
159
+ ActiveRecord::Schema.define(version: 3) do
160
+ end
161
+
162
+ assert_equal [
163
+ ["up", "001", "Valid people have last names"],
164
+ ["up", "002", "We need reminders"],
165
+ ["up", "003", "Innocent jointable"],
166
+ ], ActiveRecord::Migrator.migrations_status(path)
167
+ ensure
168
+ ActiveRecord::Migrator.migrations_paths = prev_paths
169
+ end
170
+
171
+ def test_migrations_status_from_two_directories
172
+ paths = [MIGRATIONS_ROOT + "/valid_with_timestamps", MIGRATIONS_ROOT + "/to_copy_with_timestamps"]
173
+
174
+ ActiveRecord::SchemaMigration.create(version: "20100101010101")
175
+ ActiveRecord::SchemaMigration.create(version: "20160528010101")
176
+
177
+ assert_equal [
178
+ ["down", "20090101010101", "People have hobbies"],
179
+ ["down", "20090101010202", "People have descriptions"],
180
+ ["up", "20100101010101", "Valid with timestamps people have last names"],
181
+ ["down", "20100201010101", "Valid with timestamps we need reminders"],
182
+ ["down", "20100301010101", "Valid with timestamps innocent jointable"],
183
+ ["up", "20160528010101", "********** NO FILE **********"],
184
+ ], ActiveRecord::Migrator.migrations_status(paths)
185
+ end
186
+
187
+ def test_migrator_interleaved_migrations
188
+ pass_one = [Sensor.new('One', 1)]
189
+
190
+ ActiveRecord::Migrator.new(:up, pass_one).migrate
191
+ assert pass_one.first.went_up
192
+ assert_not pass_one.first.went_down
193
+
194
+ pass_two = [Sensor.new('One', 1), Sensor.new('Three', 3)]
195
+ ActiveRecord::Migrator.new(:up, pass_two).migrate
196
+ assert_not pass_two[0].went_up
197
+ assert pass_two[1].went_up
198
+ assert pass_two.all? { |x| !x.went_down }
199
+
200
+ pass_three = [Sensor.new('One', 1),
201
+ Sensor.new('Two', 2),
202
+ Sensor.new('Three', 3)]
203
+
204
+ ActiveRecord::Migrator.new(:down, pass_three).migrate
205
+ assert pass_three[0].went_down
206
+ assert_not pass_three[1].went_down
207
+ assert pass_three[2].went_down
208
+ end
209
+
210
+ def test_up_calls_up
211
+ migrations = [Sensor.new(nil, 0), Sensor.new(nil, 1), Sensor.new(nil, 2)]
212
+ ActiveRecord::Migrator.new(:up, migrations).migrate
213
+ assert migrations.all?(&:went_up)
214
+ assert migrations.all? { |m| !m.went_down }
215
+ assert_equal 2, ActiveRecord::Migrator.current_version
216
+ end
217
+
218
+ def test_down_calls_down
219
+ test_up_calls_up
220
+
221
+ migrations = [Sensor.new(nil, 0), Sensor.new(nil, 1), Sensor.new(nil, 2)]
222
+ ActiveRecord::Migrator.new(:down, migrations).migrate
223
+ assert migrations.all? { |m| !m.went_up }
224
+ assert migrations.all?(&:went_down)
225
+ assert_equal 0, ActiveRecord::Migrator.current_version
226
+ end
227
+
228
+ def test_current_version
229
+ ActiveRecord::SchemaMigration.create!(:version => '1000')
230
+ assert_equal 1000, ActiveRecord::Migrator.current_version
231
+ end
232
+
233
+ def test_migrator_one_up
234
+ calls, migrations = sensors(3)
235
+
236
+ ActiveRecord::Migrator.new(:up, migrations, 1).migrate
237
+ assert_equal [[:up, 1]], calls
238
+ calls.clear
239
+
240
+ ActiveRecord::Migrator.new(:up, migrations, 2).migrate
241
+ assert_equal [[:up, 2]], calls
242
+ end
243
+
244
+ def test_migrator_one_down
245
+ calls, migrations = sensors(3)
246
+
247
+ ActiveRecord::Migrator.new(:up, migrations).migrate
248
+ assert_equal [[:up, 1], [:up, 2], [:up, 3]], calls
249
+ calls.clear
250
+
251
+ ActiveRecord::Migrator.new(:down, migrations, 1).migrate
252
+
253
+ assert_equal [[:down, 3], [:down, 2]], calls
254
+ end
255
+
256
+ def test_migrator_one_up_one_down
257
+ calls, migrations = sensors(3)
258
+
259
+ ActiveRecord::Migrator.new(:up, migrations, 1).migrate
260
+ assert_equal [[:up, 1]], calls
261
+ calls.clear
262
+
263
+ ActiveRecord::Migrator.new(:down, migrations, 0).migrate
264
+ assert_equal [[:down, 1]], calls
265
+ end
266
+
267
+ def test_migrator_double_up
268
+ calls, migrations = sensors(3)
269
+ assert_equal(0, ActiveRecord::Migrator.current_version)
270
+
271
+ ActiveRecord::Migrator.new(:up, migrations, 1).migrate
272
+ assert_equal [[:up, 1]], calls
273
+ calls.clear
274
+
275
+ ActiveRecord::Migrator.new(:up, migrations, 1).migrate
276
+ assert_equal [], calls
277
+ end
278
+
279
+ def test_migrator_double_down
280
+ calls, migrations = sensors(3)
281
+
282
+ assert_equal(0, ActiveRecord::Migrator.current_version)
283
+
284
+ ActiveRecord::Migrator.new(:up, migrations, 1).run
285
+ assert_equal [[:up, 1]], calls
286
+ calls.clear
287
+
288
+ ActiveRecord::Migrator.new(:down, migrations, 1).run
289
+ assert_equal [[:down, 1]], calls
290
+ calls.clear
291
+
292
+ ActiveRecord::Migrator.new(:down, migrations, 1).run
293
+ assert_equal [], calls
294
+
295
+ assert_equal(0, ActiveRecord::Migrator.current_version)
296
+ end
297
+
298
+ def test_migrator_verbosity
299
+ _, migrations = sensors(3)
300
+
301
+ ActiveRecord::Migration.verbose = true
302
+ ActiveRecord::Migrator.new(:up, migrations, 1).migrate
303
+ assert_not_equal 0, ActiveRecord::Migration.message_count
304
+
305
+ ActiveRecord::Migration.message_count = 0
306
+
307
+ ActiveRecord::Migrator.new(:down, migrations, 0).migrate
308
+ assert_not_equal 0, ActiveRecord::Migration.message_count
309
+ end
310
+
311
+ def test_migrator_verbosity_off
312
+ _, migrations = sensors(3)
313
+
314
+ ActiveRecord::Migration.verbose = false
315
+ ActiveRecord::Migrator.new(:up, migrations, 1).migrate
316
+ assert_equal 0, ActiveRecord::Migration.message_count
317
+ ActiveRecord::Migrator.new(:down, migrations, 0).migrate
318
+ assert_equal 0, ActiveRecord::Migration.message_count
319
+ end
320
+
321
+ def test_target_version_zero_should_run_only_once
322
+ calls, migrations = sensors(3)
323
+
324
+ # migrate up to 1
325
+ ActiveRecord::Migrator.new(:up, migrations, 1).migrate
326
+ assert_equal [[:up, 1]], calls
327
+ calls.clear
328
+
329
+ # migrate down to 0
330
+ ActiveRecord::Migrator.new(:down, migrations, 0).migrate
331
+ assert_equal [[:down, 1]], calls
332
+ calls.clear
333
+
334
+ # migrate down to 0 again
335
+ ActiveRecord::Migrator.new(:down, migrations, 0).migrate
336
+ assert_equal [], calls
337
+ end
338
+
339
+ def test_migrator_going_down_due_to_version_target
340
+ calls, migrator = migrator_class(3)
341
+
342
+ migrator.up("valid", 1)
343
+ assert_equal [[:up, 1]], calls
344
+ calls.clear
345
+
346
+ migrator.migrate("valid", 0)
347
+ assert_equal [[:down, 1]], calls
348
+ calls.clear
349
+
350
+ migrator.migrate("valid")
351
+ assert_equal [[:up, 1], [:up, 2], [:up, 3]], calls
352
+ end
353
+
354
+ def test_migrator_output_when_running_multiple_migrations
355
+ _, migrator = migrator_class(3)
356
+
357
+ result = migrator.migrate("valid")
358
+ assert_equal(3, result.count)
359
+
360
+ # Nothing migrated from duplicate run
361
+ result = migrator.migrate("valid")
362
+ assert_equal(0, result.count)
363
+
364
+ result = migrator.rollback("valid")
365
+ assert_equal(1, result.count)
366
+ end
367
+
368
+ def test_migrator_output_when_running_single_migration
369
+ _, migrator = migrator_class(1)
370
+ result = migrator.run(:up, "valid", 1)
371
+
372
+ assert_equal(1, result.version)
373
+ end
374
+
375
+ def test_migrator_rollback
376
+ _, migrator = migrator_class(3)
377
+
378
+ migrator.migrate("valid")
379
+ assert_equal(3, ActiveRecord::Migrator.current_version)
380
+
381
+ migrator.rollback("valid")
382
+ assert_equal(2, ActiveRecord::Migrator.current_version)
383
+
384
+ migrator.rollback("valid")
385
+ assert_equal(1, ActiveRecord::Migrator.current_version)
386
+
387
+ migrator.rollback("valid")
388
+ assert_equal(0, ActiveRecord::Migrator.current_version)
389
+
390
+ migrator.rollback("valid")
391
+ assert_equal(0, ActiveRecord::Migrator.current_version)
392
+ end
393
+
394
+ def test_migrator_db_has_no_schema_migrations_table
395
+ _, migrator = migrator_class(3)
396
+
397
+ ActiveRecord::Base.connection.drop_table "schema_migrations", if_exists: true
398
+ ActiveSupport::Deprecation.silence { assert_not ActiveRecord::Base.connection.table_exists?('schema_migrations') }
399
+ migrator.migrate("valid", 1)
400
+ ActiveSupport::Deprecation.silence { assert ActiveRecord::Base.connection.table_exists?('schema_migrations') }
401
+ end
402
+
403
+ def test_migrator_forward
404
+ _, migrator = migrator_class(3)
405
+ migrator.migrate("/valid", 1)
406
+ assert_equal(1, ActiveRecord::Migrator.current_version)
407
+
408
+ migrator.forward("/valid", 2)
409
+ assert_equal(3, ActiveRecord::Migrator.current_version)
410
+
411
+ migrator.forward("/valid")
412
+ assert_equal(3, ActiveRecord::Migrator.current_version)
413
+ end
414
+
415
+ def test_only_loads_pending_migrations
416
+ # migrate up to 1
417
+ ActiveRecord::SchemaMigration.create!(:version => '1')
418
+
419
+ calls, migrator = migrator_class(3)
420
+ migrator.migrate("valid", nil)
421
+
422
+ assert_equal [[:up, 2], [:up, 3]], calls
423
+ end
424
+
425
+ def test_get_all_versions
426
+ _, migrator = migrator_class(3)
427
+
428
+ migrator.migrate("valid")
429
+ assert_equal([1,2,3], ActiveRecord::Migrator.get_all_versions)
430
+
431
+ migrator.rollback("valid")
432
+ assert_equal([1,2], ActiveRecord::Migrator.get_all_versions)
433
+
434
+ migrator.rollback("valid")
435
+ assert_equal([1], ActiveRecord::Migrator.get_all_versions)
436
+
437
+ migrator.rollback("valid")
438
+ assert_equal([], ActiveRecord::Migrator.get_all_versions)
439
+ end
440
+
441
+ private
442
+ def m(name, version)
443
+ x = Sensor.new name, version
444
+ x.extend(Module.new {
445
+ define_method(:up) { yield(:up, x); super() }
446
+ define_method(:down) { yield(:down, x); super() }
447
+ }) if block_given?
448
+ end
449
+
450
+ def sensors(count)
451
+ calls = []
452
+ migrations = count.times.map { |i|
453
+ m(nil, i + 1) { |c,migration|
454
+ calls << [c, migration.version]
455
+ }
456
+ }
457
+ [calls, migrations]
458
+ end
459
+
460
+ def migrator_class(count)
461
+ calls, migrations = sensors(count)
462
+
463
+ migrator = Class.new(ActiveRecord::Migrator).extend(Module.new {
464
+ define_method(:migrations) { |paths|
465
+ migrations
466
+ }
467
+ })
468
+ [calls, migrator]
469
+ end
470
+ end