ibm_db 3.0.4-x86-mingw32 → 5.0.4-x86-mingw32

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