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,28 +1,30 @@
1
- require "cases/helper"
2
-
3
- class TestRecord < ActiveRecord::Base
4
- end
5
-
6
- class TestDisconnectedAdapter < ActiveRecord::TestCase
7
- self.use_transactional_fixtures = false
8
-
9
- def setup
10
- @connection = ActiveRecord::Base.connection
11
- end
12
-
13
- teardown do
14
- return if in_memory_db?
15
- spec = ActiveRecord::Base.connection_config
16
- ActiveRecord::Base.establish_connection(spec)
17
- end
18
-
19
- unless in_memory_db?
20
- test "can't execute statements while disconnected" do
21
- @connection.execute "SELECT count(*) from products"
22
- @connection.disconnect!
23
- assert_raises(ActiveRecord::StatementInvalid) do
24
- @connection.execute "SELECT count(*) from products"
25
- end
26
- end
27
- end
28
- end
1
+ require "cases/helper"
2
+
3
+ class TestRecord < ActiveRecord::Base
4
+ end
5
+
6
+ class TestDisconnectedAdapter < ActiveRecord::TestCase
7
+ self.use_transactional_tests = false
8
+
9
+ def setup
10
+ @connection = ActiveRecord::Base.connection
11
+ end
12
+
13
+ teardown do
14
+ return if in_memory_db?
15
+ spec = ActiveRecord::Base.connection_config
16
+ ActiveRecord::Base.establish_connection(spec)
17
+ end
18
+
19
+ unless in_memory_db?
20
+ test "can't execute statements while disconnected" do
21
+ @connection.execute "SELECT count(*) from products"
22
+ @connection.disconnect!
23
+ assert_raises(ActiveRecord::StatementInvalid) do
24
+ silence_warnings do
25
+ @connection.execute "SELECT count(*) from products"
26
+ end
27
+ end
28
+ end
29
+ end
30
+ end
@@ -1,157 +1,157 @@
1
- require "cases/helper"
2
- require 'models/reply'
3
- require 'models/topic'
4
-
5
- module ActiveRecord
6
- class DupTest < ActiveRecord::TestCase
7
- fixtures :topics
8
-
9
- def test_dup
10
- assert !Topic.new.freeze.dup.frozen?
11
- end
12
-
13
- def test_not_readonly
14
- topic = Topic.first
15
-
16
- duped = topic.dup
17
- assert !duped.readonly?, 'should not be readonly'
18
- end
19
-
20
- def test_is_readonly
21
- topic = Topic.first
22
- topic.readonly!
23
-
24
- duped = topic.dup
25
- assert duped.readonly?, 'should be readonly'
26
- end
27
-
28
- def test_dup_not_persisted
29
- topic = Topic.first
30
- duped = topic.dup
31
-
32
- assert !duped.persisted?, 'topic not persisted'
33
- assert duped.new_record?, 'topic is new'
34
- end
35
-
36
- def test_dup_not_destroyed
37
- topic = Topic.first
38
- topic.destroy
39
-
40
- duped = topic.dup
41
- assert_not duped.destroyed?
42
- end
43
-
44
- def test_dup_has_no_id
45
- topic = Topic.first
46
- duped = topic.dup
47
- assert_nil duped.id
48
- end
49
-
50
- def test_dup_with_modified_attributes
51
- topic = Topic.first
52
- topic.author_name = 'Aaron'
53
- duped = topic.dup
54
- assert_equal 'Aaron', duped.author_name
55
- end
56
-
57
- def test_dup_with_changes
58
- dbtopic = Topic.first
59
- topic = Topic.new
60
-
61
- topic.attributes = dbtopic.attributes.except("id")
62
-
63
- #duped has no timestamp values
64
- duped = dbtopic.dup
65
-
66
- #clear topic timestamp values
67
- topic.send(:clear_timestamp_attributes)
68
-
69
- assert_equal topic.changes, duped.changes
70
- end
71
-
72
- def test_dup_topics_are_independent
73
- topic = Topic.first
74
- topic.author_name = 'Aaron'
75
- duped = topic.dup
76
-
77
- duped.author_name = 'meow'
78
-
79
- assert_not_equal topic.changes, duped.changes
80
- end
81
-
82
- def test_dup_attributes_are_independent
83
- topic = Topic.first
84
- duped = topic.dup
85
-
86
- duped.author_name = 'meow'
87
- topic.author_name = 'Aaron'
88
-
89
- assert_equal 'Aaron', topic.author_name
90
- assert_equal 'meow', duped.author_name
91
- end
92
-
93
- def test_dup_timestamps_are_cleared
94
- topic = Topic.first
95
- assert_not_nil topic.updated_at
96
- assert_not_nil topic.created_at
97
-
98
- # temporary change to the topic object
99
- topic.updated_at -= 3.days
100
-
101
- #dup should not preserve the timestamps if present
102
- new_topic = topic.dup
103
- assert_nil new_topic.updated_at
104
- assert_nil new_topic.created_at
105
-
106
- new_topic.save
107
- assert_not_nil new_topic.updated_at
108
- assert_not_nil new_topic.created_at
109
- end
110
-
111
- def test_dup_after_initialize_callbacks
112
- topic = Topic.new
113
- assert Topic.after_initialize_called
114
- Topic.after_initialize_called = false
115
- topic.dup
116
- assert Topic.after_initialize_called
117
- end
118
-
119
- def test_dup_validity_is_independent
120
- repair_validations(Topic) do
121
- Topic.validates_presence_of :title
122
- topic = Topic.new("title" => "Literature")
123
- topic.valid?
124
-
125
- duped = topic.dup
126
- duped.title = nil
127
- assert duped.invalid?
128
-
129
- topic.title = nil
130
- duped.title = 'Mathematics'
131
- assert topic.invalid?
132
- assert duped.valid?
133
- end
134
- end
135
-
136
- def test_dup_with_default_scope
137
- prev_default_scopes = Topic.default_scopes
138
- Topic.default_scopes = [proc { Topic.where(:approved => true) }]
139
- topic = Topic.new(:approved => false)
140
- assert !topic.dup.approved?, "should not be overridden by default scopes"
141
- ensure
142
- Topic.default_scopes = prev_default_scopes
143
- end
144
-
145
- def test_dup_without_primary_key
146
- klass = Class.new(ActiveRecord::Base) do
147
- self.table_name = 'parrots_pirates'
148
- end
149
-
150
- record = klass.create!
151
-
152
- assert_nothing_raised do
153
- record.dup
154
- end
155
- end
156
- end
157
- end
1
+ require "cases/helper"
2
+ require 'models/reply'
3
+ require 'models/topic'
4
+
5
+ module ActiveRecord
6
+ class DupTest < ActiveRecord::TestCase
7
+ fixtures :topics
8
+
9
+ def test_dup
10
+ assert !Topic.new.freeze.dup.frozen?
11
+ end
12
+
13
+ def test_not_readonly
14
+ topic = Topic.first
15
+
16
+ duped = topic.dup
17
+ assert !duped.readonly?, 'should not be readonly'
18
+ end
19
+
20
+ def test_is_readonly
21
+ topic = Topic.first
22
+ topic.readonly!
23
+
24
+ duped = topic.dup
25
+ assert duped.readonly?, 'should be readonly'
26
+ end
27
+
28
+ def test_dup_not_persisted
29
+ topic = Topic.first
30
+ duped = topic.dup
31
+
32
+ assert !duped.persisted?, 'topic not persisted'
33
+ assert duped.new_record?, 'topic is new'
34
+ end
35
+
36
+ def test_dup_not_destroyed
37
+ topic = Topic.first
38
+ topic.destroy
39
+
40
+ duped = topic.dup
41
+ assert_not duped.destroyed?
42
+ end
43
+
44
+ def test_dup_has_no_id
45
+ topic = Topic.first
46
+ duped = topic.dup
47
+ assert_nil duped.id
48
+ end
49
+
50
+ def test_dup_with_modified_attributes
51
+ topic = Topic.first
52
+ topic.author_name = 'Aaron'
53
+ duped = topic.dup
54
+ assert_equal 'Aaron', duped.author_name
55
+ end
56
+
57
+ def test_dup_with_changes
58
+ dbtopic = Topic.first
59
+ topic = Topic.new
60
+
61
+ topic.attributes = dbtopic.attributes.except("id")
62
+
63
+ #duped has no timestamp values
64
+ duped = dbtopic.dup
65
+
66
+ #clear topic timestamp values
67
+ topic.send(:clear_timestamp_attributes)
68
+
69
+ assert_equal topic.changes, duped.changes
70
+ end
71
+
72
+ def test_dup_topics_are_independent
73
+ topic = Topic.first
74
+ topic.author_name = 'Aaron'
75
+ duped = topic.dup
76
+
77
+ duped.author_name = 'meow'
78
+
79
+ assert_not_equal topic.changes, duped.changes
80
+ end
81
+
82
+ def test_dup_attributes_are_independent
83
+ topic = Topic.first
84
+ duped = topic.dup
85
+
86
+ duped.author_name = 'meow'
87
+ topic.author_name = 'Aaron'
88
+
89
+ assert_equal 'Aaron', topic.author_name
90
+ assert_equal 'meow', duped.author_name
91
+ end
92
+
93
+ def test_dup_timestamps_are_cleared
94
+ topic = Topic.first
95
+ assert_not_nil topic.updated_at
96
+ assert_not_nil topic.created_at
97
+
98
+ # temporary change to the topic object
99
+ topic.updated_at -= 3.days
100
+
101
+ #dup should not preserve the timestamps if present
102
+ new_topic = topic.dup
103
+ assert_nil new_topic.updated_at
104
+ assert_nil new_topic.created_at
105
+
106
+ new_topic.save
107
+ assert_not_nil new_topic.updated_at
108
+ assert_not_nil new_topic.created_at
109
+ end
110
+
111
+ def test_dup_after_initialize_callbacks
112
+ topic = Topic.new
113
+ assert Topic.after_initialize_called
114
+ Topic.after_initialize_called = false
115
+ topic.dup
116
+ assert Topic.after_initialize_called
117
+ end
118
+
119
+ def test_dup_validity_is_independent
120
+ repair_validations(Topic) do
121
+ Topic.validates_presence_of :title
122
+ topic = Topic.new("title" => "Literature")
123
+ topic.valid?
124
+
125
+ duped = topic.dup
126
+ duped.title = nil
127
+ assert duped.invalid?
128
+
129
+ topic.title = nil
130
+ duped.title = 'Mathematics'
131
+ assert topic.invalid?
132
+ assert duped.valid?
133
+ end
134
+ end
135
+
136
+ def test_dup_with_default_scope
137
+ prev_default_scopes = Topic.default_scopes
138
+ Topic.default_scopes = [proc { Topic.where(:approved => true) }]
139
+ topic = Topic.new(:approved => false)
140
+ assert !topic.dup.approved?, "should not be overridden by default scopes"
141
+ ensure
142
+ Topic.default_scopes = prev_default_scopes
143
+ end
144
+
145
+ def test_dup_without_primary_key
146
+ klass = Class.new(ActiveRecord::Base) do
147
+ self.table_name = 'parrots_pirates'
148
+ end
149
+
150
+ record = klass.create!
151
+
152
+ assert_nothing_raised do
153
+ record.dup
154
+ end
155
+ end
156
+ end
157
+ end
@@ -1,290 +1,444 @@
1
- require 'cases/helper'
2
- require 'models/book'
3
-
4
- class EnumTest < ActiveRecord::TestCase
5
- fixtures :books
6
-
7
- setup do
8
- @book = books(:awdr)
9
- end
10
-
11
- test "query state by predicate" do
12
- assert @book.proposed?
13
- assert_not @book.written?
14
- assert_not @book.published?
15
-
16
- assert @book.unread?
17
- end
18
-
19
- test "query state with strings" do
20
- assert_equal "proposed", @book.status
21
- assert_equal "unread", @book.read_status
22
- end
23
-
24
- test "find via scope" do
25
- assert_equal @book, Book.proposed.first
26
- assert_equal @book, Book.unread.first
27
- end
28
-
29
- test "update by declaration" do
30
- @book.written!
31
- assert @book.written?
32
- end
33
-
34
- test "update by setter" do
35
- @book.update! status: :written
36
- assert @book.written?
37
- end
38
-
39
- test "enum methods are overwritable" do
40
- assert_equal "do publish work...", @book.published!
41
- assert @book.published?
42
- end
43
-
44
- test "direct assignment" do
45
- @book.status = :written
46
- assert @book.written?
47
- end
48
-
49
- test "assign string value" do
50
- @book.status = "written"
51
- assert @book.written?
52
- end
53
-
54
- test "enum changed attributes" do
55
- old_status = @book.status
56
- @book.status = :published
57
- assert_equal old_status, @book.changed_attributes[:status]
58
- end
59
-
60
- test "enum changes" do
61
- old_status = @book.status
62
- @book.status = :published
63
- assert_equal [old_status, 'published'], @book.changes[:status]
64
- end
65
-
66
- test "enum attribute was" do
67
- old_status = @book.status
68
- @book.status = :published
69
- assert_equal old_status, @book.attribute_was(:status)
70
- end
71
-
72
- test "enum attribute changed" do
73
- @book.status = :published
74
- assert @book.attribute_changed?(:status)
75
- end
76
-
77
- test "enum attribute changed to" do
78
- @book.status = :published
79
- assert @book.attribute_changed?(:status, to: 'published')
80
- end
81
-
82
- test "enum attribute changed from" do
83
- old_status = @book.status
84
- @book.status = :published
85
- assert @book.attribute_changed?(:status, from: old_status)
86
- end
87
-
88
- test "enum attribute changed from old status to new status" do
89
- old_status = @book.status
90
- @book.status = :published
91
- assert @book.attribute_changed?(:status, from: old_status, to: 'published')
92
- end
93
-
94
- test "enum didn't change" do
95
- old_status = @book.status
96
- @book.status = old_status
97
- assert_not @book.attribute_changed?(:status)
98
- end
99
-
100
- test "persist changes that are dirty" do
101
- @book.status = :published
102
- assert @book.attribute_changed?(:status)
103
- @book.status = :written
104
- assert @book.attribute_changed?(:status)
105
- end
106
-
107
- test "reverted changes that are not dirty" do
108
- old_status = @book.status
109
- @book.status = :published
110
- assert @book.attribute_changed?(:status)
111
- @book.status = old_status
112
- assert_not @book.attribute_changed?(:status)
113
- end
114
-
115
- test "reverted changes are not dirty going from nil to value and back" do
116
- book = Book.create!(nullable_status: nil)
117
-
118
- book.nullable_status = :married
119
- assert book.attribute_changed?(:nullable_status)
120
-
121
- book.nullable_status = nil
122
- assert_not book.attribute_changed?(:nullable_status)
123
- end
124
-
125
- test "assign non existing value raises an error" do
126
- e = assert_raises(ArgumentError) do
127
- @book.status = :unknown
128
- end
129
- assert_equal "'unknown' is not a valid status", e.message
130
- end
131
-
132
- test "assign nil value" do
133
- @book.status = nil
134
- assert @book.status.nil?
135
- end
136
-
137
- test "assign empty string value" do
138
- @book.status = ''
139
- assert @book.status.nil?
140
- end
141
-
142
- test "assign long empty string value" do
143
- @book.status = ' '
144
- assert @book.status.nil?
145
- end
146
-
147
- test "constant to access the mapping" do
148
- assert_equal 0, Book.statuses[:proposed]
149
- assert_equal 1, Book.statuses["written"]
150
- assert_equal 2, Book.statuses[:published]
151
- end
152
-
153
- test "building new objects with enum scopes" do
154
- assert Book.written.build.written?
155
- assert Book.read.build.read?
156
- end
157
-
158
- test "creating new objects with enum scopes" do
159
- assert Book.written.create.written?
160
- assert Book.read.create.read?
161
- end
162
-
163
- test "_before_type_cast returns the enum label (required for form fields)" do
164
- assert_equal "proposed", @book.status_before_type_cast
165
- end
166
-
167
- test "reserved enum names" do
168
- klass = Class.new(ActiveRecord::Base) do
169
- self.table_name = "books"
170
- enum status: [:proposed, :written, :published]
171
- end
172
-
173
- conflicts = [
174
- :column, # generates class method .columns, which conflicts with an AR method
175
- :logger, # generates #logger, which conflicts with an AR method
176
- :attributes, # generates #attributes=, which conflicts with an AR method
177
- ]
178
-
179
- conflicts.each_with_index do |name, i|
180
- assert_raises(ArgumentError, "enum name `#{name}` should not be allowed") do
181
- klass.class_eval { enum name => ["value_#{i}"] }
182
- end
183
- end
184
- end
185
-
186
- test "reserved enum values" do
187
- klass = Class.new(ActiveRecord::Base) do
188
- self.table_name = "books"
189
- enum status: [:proposed, :written, :published]
190
- end
191
-
192
- conflicts = [
193
- :new, # generates a scope that conflicts with an AR class method
194
- :valid, # generates #valid?, which conflicts with an AR method
195
- :save, # generates #save!, which conflicts with an AR method
196
- :proposed, # same value as an existing enum
197
- :public, :private, :protected, # some important methods on Module and Class
198
- :name, :parent, :superclass
199
- ]
200
-
201
- conflicts.each_with_index do |value, i|
202
- assert_raises(ArgumentError, "enum value `#{value}` should not be allowed") do
203
- klass.class_eval { enum "status_#{i}" => [value] }
204
- end
205
- end
206
- end
207
-
208
- test "overriding enum method should not raise" do
209
- assert_nothing_raised do
210
- Class.new(ActiveRecord::Base) do
211
- self.table_name = "books"
212
-
213
- def published!
214
- super
215
- "do publish work..."
216
- end
217
-
218
- enum status: [:proposed, :written, :published]
219
-
220
- def written!
221
- super
222
- "do written work..."
223
- end
224
- end
225
- end
226
- end
227
-
228
- test "validate uniqueness" do
229
- klass = Class.new(ActiveRecord::Base) do
230
- def self.name; 'Book'; end
231
- enum status: [:proposed, :written]
232
- validates_uniqueness_of :status
233
- end
234
- klass.delete_all
235
- klass.create!(status: "proposed")
236
- book = klass.new(status: "written")
237
- assert book.valid?
238
- book.status = "proposed"
239
- assert_not book.valid?
240
- end
241
-
242
- test "validate inclusion of value in array" do
243
- klass = Class.new(ActiveRecord::Base) do
244
- def self.name; 'Book'; end
245
- enum status: [:proposed, :written]
246
- validates_inclusion_of :status, in: ["written"]
247
- end
248
- klass.delete_all
249
- invalid_book = klass.new(status: "proposed")
250
- assert_not invalid_book.valid?
251
- valid_book = klass.new(status: "written")
252
- assert valid_book.valid?
253
- end
254
-
255
- test "enums are distinct per class" do
256
- klass1 = Class.new(ActiveRecord::Base) do
257
- self.table_name = "books"
258
- enum status: [:proposed, :written]
259
- end
260
-
261
- klass2 = Class.new(ActiveRecord::Base) do
262
- self.table_name = "books"
263
- enum status: [:drafted, :uploaded]
264
- end
265
-
266
- book1 = klass1.proposed.create!
267
- book1.status = :written
268
- assert_equal ['proposed', 'written'], book1.status_change
269
-
270
- book2 = klass2.drafted.create!
271
- book2.status = :uploaded
272
- assert_equal ['drafted', 'uploaded'], book2.status_change
273
- end
274
-
275
- test "enums are inheritable" do
276
- subklass1 = Class.new(Book)
277
-
278
- subklass2 = Class.new(Book) do
279
- enum status: [:drafted, :uploaded]
280
- end
281
-
282
- book1 = subklass1.proposed.create!
283
- book1.status = :written
284
- assert_equal ['proposed', 'written'], book1.status_change
285
-
286
- book2 = subklass2.drafted.create!
287
- book2.status = :uploaded
288
- assert_equal ['drafted', 'uploaded'], book2.status_change
289
- end
290
- end
1
+ require 'cases/helper'
2
+ require 'models/book'
3
+
4
+ class EnumTest < ActiveRecord::TestCase
5
+ fixtures :books
6
+
7
+ setup do
8
+ @book = books(:awdr)
9
+ end
10
+
11
+ test "query state by predicate" do
12
+ assert @book.published?
13
+ assert_not @book.written?
14
+ assert_not @book.proposed?
15
+
16
+ assert @book.read?
17
+ assert @book.in_english?
18
+ assert @book.author_visibility_visible?
19
+ assert @book.illustrator_visibility_visible?
20
+ assert @book.with_medium_font_size?
21
+ end
22
+
23
+ test "query state with strings" do
24
+ assert_equal "published", @book.status
25
+ assert_equal "read", @book.read_status
26
+ assert_equal "english", @book.language
27
+ assert_equal "visible", @book.author_visibility
28
+ assert_equal "visible", @book.illustrator_visibility
29
+ end
30
+
31
+ test "find via scope" do
32
+ assert_equal @book, Book.published.first
33
+ assert_equal @book, Book.read.first
34
+ assert_equal @book, Book.in_english.first
35
+ assert_equal @book, Book.author_visibility_visible.first
36
+ assert_equal @book, Book.illustrator_visibility_visible.first
37
+ end
38
+
39
+ test "find via where with values" do
40
+ published, written = Book.statuses[:published], Book.statuses[:written]
41
+
42
+ assert_equal @book, Book.where(status: published).first
43
+ assert_not_equal @book, Book.where(status: written).first
44
+ assert_equal @book, Book.where(status: [published]).first
45
+ assert_not_equal @book, Book.where(status: [written]).first
46
+ assert_not_equal @book, Book.where("status <> ?", published).first
47
+ assert_equal @book, Book.where("status <> ?", written).first
48
+ end
49
+
50
+ test "find via where with symbols" do
51
+ assert_equal @book, Book.where(status: :published).first
52
+ assert_not_equal @book, Book.where(status: :written).first
53
+ assert_equal @book, Book.where(status: [:published]).first
54
+ assert_not_equal @book, Book.where(status: [:written]).first
55
+ assert_not_equal @book, Book.where.not(status: :published).first
56
+ assert_equal @book, Book.where.not(status: :written).first
57
+ end
58
+
59
+ test "find via where with strings" do
60
+ assert_equal @book, Book.where(status: "published").first
61
+ assert_not_equal @book, Book.where(status: "written").first
62
+ assert_equal @book, Book.where(status: ["published"]).first
63
+ assert_not_equal @book, Book.where(status: ["written"]).first
64
+ assert_not_equal @book, Book.where.not(status: "published").first
65
+ assert_equal @book, Book.where.not(status: "written").first
66
+ end
67
+
68
+ test "build from scope" do
69
+ assert Book.written.build.written?
70
+ assert_not Book.written.build.proposed?
71
+ end
72
+
73
+ test "build from where" do
74
+ assert Book.where(status: Book.statuses[:written]).build.written?
75
+ assert_not Book.where(status: Book.statuses[:written]).build.proposed?
76
+ assert Book.where(status: :written).build.written?
77
+ assert_not Book.where(status: :written).build.proposed?
78
+ assert Book.where(status: "written").build.written?
79
+ assert_not Book.where(status: "written").build.proposed?
80
+ end
81
+
82
+ test "update by declaration" do
83
+ @book.written!
84
+ assert @book.written?
85
+ @book.in_english!
86
+ assert @book.in_english?
87
+ @book.author_visibility_visible!
88
+ assert @book.author_visibility_visible?
89
+ end
90
+
91
+ test "update by setter" do
92
+ @book.update! status: :written
93
+ assert @book.written?
94
+ end
95
+
96
+ test "enum methods are overwritable" do
97
+ assert_equal "do publish work...", @book.published!
98
+ assert @book.published?
99
+ end
100
+
101
+ test "direct assignment" do
102
+ @book.status = :written
103
+ assert @book.written?
104
+ end
105
+
106
+ test "assign string value" do
107
+ @book.status = "written"
108
+ assert @book.written?
109
+ end
110
+
111
+ test "enum changed attributes" do
112
+ old_status = @book.status
113
+ old_language = @book.language
114
+ @book.status = :proposed
115
+ @book.language = :spanish
116
+ assert_equal old_status, @book.changed_attributes[:status]
117
+ assert_equal old_language, @book.changed_attributes[:language]
118
+ end
119
+
120
+ test "enum changes" do
121
+ old_status = @book.status
122
+ old_language = @book.language
123
+ @book.status = :proposed
124
+ @book.language = :spanish
125
+ assert_equal [old_status, 'proposed'], @book.changes[:status]
126
+ assert_equal [old_language, 'spanish'], @book.changes[:language]
127
+ end
128
+
129
+ test "enum attribute was" do
130
+ old_status = @book.status
131
+ old_language = @book.language
132
+ @book.status = :published
133
+ @book.language = :spanish
134
+ assert_equal old_status, @book.attribute_was(:status)
135
+ assert_equal old_language, @book.attribute_was(:language)
136
+ end
137
+
138
+ test "enum attribute changed" do
139
+ @book.status = :proposed
140
+ @book.language = :french
141
+ assert @book.attribute_changed?(:status)
142
+ assert @book.attribute_changed?(:language)
143
+ end
144
+
145
+ test "enum attribute changed to" do
146
+ @book.status = :proposed
147
+ @book.language = :french
148
+ assert @book.attribute_changed?(:status, to: 'proposed')
149
+ assert @book.attribute_changed?(:language, to: 'french')
150
+ end
151
+
152
+ test "enum attribute changed from" do
153
+ old_status = @book.status
154
+ old_language = @book.language
155
+ @book.status = :proposed
156
+ @book.language = :french
157
+ assert @book.attribute_changed?(:status, from: old_status)
158
+ assert @book.attribute_changed?(:language, from: old_language)
159
+ end
160
+
161
+ test "enum attribute changed from old status to new status" do
162
+ old_status = @book.status
163
+ old_language = @book.language
164
+ @book.status = :proposed
165
+ @book.language = :french
166
+ assert @book.attribute_changed?(:status, from: old_status, to: 'proposed')
167
+ assert @book.attribute_changed?(:language, from: old_language, to: 'french')
168
+ end
169
+
170
+ test "enum didn't change" do
171
+ old_status = @book.status
172
+ @book.status = old_status
173
+ assert_not @book.attribute_changed?(:status)
174
+ end
175
+
176
+ test "persist changes that are dirty" do
177
+ @book.status = :proposed
178
+ assert @book.attribute_changed?(:status)
179
+ @book.status = :written
180
+ assert @book.attribute_changed?(:status)
181
+ end
182
+
183
+ test "reverted changes that are not dirty" do
184
+ old_status = @book.status
185
+ @book.status = :proposed
186
+ assert @book.attribute_changed?(:status)
187
+ @book.status = old_status
188
+ assert_not @book.attribute_changed?(:status)
189
+ end
190
+
191
+ test "reverted changes are not dirty going from nil to value and back" do
192
+ book = Book.create!(nullable_status: nil)
193
+
194
+ book.nullable_status = :married
195
+ assert book.attribute_changed?(:nullable_status)
196
+
197
+ book.nullable_status = nil
198
+ assert_not book.attribute_changed?(:nullable_status)
199
+ end
200
+
201
+ test "assign non existing value raises an error" do
202
+ e = assert_raises(ArgumentError) do
203
+ @book.status = :unknown
204
+ end
205
+ assert_equal "'unknown' is not a valid status", e.message
206
+ end
207
+
208
+ test "NULL values from database should be casted to nil" do
209
+ Book.where(id: @book.id).update_all("status = NULL")
210
+ assert_nil @book.reload.status
211
+ end
212
+
213
+ test "assign nil value" do
214
+ @book.status = nil
215
+ assert_nil @book.status
216
+ end
217
+
218
+ test "assign empty string value" do
219
+ @book.status = ''
220
+ assert_nil @book.status
221
+ end
222
+
223
+ test "assign long empty string value" do
224
+ @book.status = ' '
225
+ assert_nil @book.status
226
+ end
227
+
228
+ test "constant to access the mapping" do
229
+ assert_equal 0, Book.statuses[:proposed]
230
+ assert_equal 1, Book.statuses["written"]
231
+ assert_equal 2, Book.statuses[:published]
232
+ end
233
+
234
+ test "building new objects with enum scopes" do
235
+ assert Book.written.build.written?
236
+ assert Book.read.build.read?
237
+ assert Book.in_spanish.build.in_spanish?
238
+ assert Book.illustrator_visibility_invisible.build.illustrator_visibility_invisible?
239
+ end
240
+
241
+ test "creating new objects with enum scopes" do
242
+ assert Book.written.create.written?
243
+ assert Book.read.create.read?
244
+ assert Book.in_spanish.create.in_spanish?
245
+ assert Book.illustrator_visibility_invisible.create.illustrator_visibility_invisible?
246
+ end
247
+
248
+ test "_before_type_cast returns the enum label (required for form fields)" do
249
+ if @book.status_came_from_user?
250
+ assert_equal "published", @book.status_before_type_cast
251
+ else
252
+ assert_equal "published", @book.status
253
+ end
254
+ end
255
+
256
+ test "reserved enum names" do
257
+ klass = Class.new(ActiveRecord::Base) do
258
+ self.table_name = "books"
259
+ enum status: [:proposed, :written, :published]
260
+ end
261
+
262
+ conflicts = [
263
+ :column, # generates class method .columns, which conflicts with an AR method
264
+ :logger, # generates #logger, which conflicts with an AR method
265
+ :attributes, # generates #attributes=, which conflicts with an AR method
266
+ ]
267
+
268
+ conflicts.each_with_index do |name, i|
269
+ e = assert_raises(ArgumentError) do
270
+ klass.class_eval { enum name => ["value_#{i}"] }
271
+ end
272
+ assert_match(/You tried to define an enum named \"#{name}\" on the model/, e.message)
273
+ end
274
+ end
275
+
276
+ test "reserved enum values" do
277
+ klass = Class.new(ActiveRecord::Base) do
278
+ self.table_name = "books"
279
+ enum status: [:proposed, :written, :published]
280
+ end
281
+
282
+ conflicts = [
283
+ :new, # generates a scope that conflicts with an AR class method
284
+ :valid, # generates #valid?, which conflicts with an AR method
285
+ :save, # generates #save!, which conflicts with an AR method
286
+ :proposed, # same value as an existing enum
287
+ :public, :private, :protected, # some important methods on Module and Class
288
+ :name, :parent, :superclass
289
+ ]
290
+
291
+ conflicts.each_with_index do |value, i|
292
+ e = assert_raises(ArgumentError, "enum value `#{value}` should not be allowed") do
293
+ klass.class_eval { enum "status_#{i}" => [value] }
294
+ end
295
+ assert_match(/You tried to define an enum named .* on the model/, e.message)
296
+ end
297
+ end
298
+
299
+ test "overriding enum method should not raise" do
300
+ assert_nothing_raised do
301
+ Class.new(ActiveRecord::Base) do
302
+ self.table_name = "books"
303
+
304
+ def published!
305
+ super
306
+ "do publish work..."
307
+ end
308
+
309
+ enum status: [:proposed, :written, :published]
310
+
311
+ def written!
312
+ super
313
+ "do written work..."
314
+ end
315
+ end
316
+ end
317
+ end
318
+
319
+ test "validate uniqueness" do
320
+ klass = Class.new(ActiveRecord::Base) do
321
+ def self.name; 'Book'; end
322
+ enum status: [:proposed, :written]
323
+ validates_uniqueness_of :status
324
+ end
325
+ klass.delete_all
326
+ klass.create!(status: "proposed")
327
+ book = klass.new(status: "written")
328
+ assert book.valid?
329
+ book.status = "proposed"
330
+ assert_not book.valid?
331
+ end
332
+
333
+ test "validate inclusion of value in array" do
334
+ klass = Class.new(ActiveRecord::Base) do
335
+ def self.name; 'Book'; end
336
+ enum status: [:proposed, :written]
337
+ validates_inclusion_of :status, in: ["written"]
338
+ end
339
+ klass.delete_all
340
+ invalid_book = klass.new(status: "proposed")
341
+ assert_not invalid_book.valid?
342
+ valid_book = klass.new(status: "written")
343
+ assert valid_book.valid?
344
+ end
345
+
346
+ test "enums are distinct per class" do
347
+ klass1 = Class.new(ActiveRecord::Base) do
348
+ self.table_name = "books"
349
+ enum status: [:proposed, :written]
350
+ end
351
+
352
+ klass2 = Class.new(ActiveRecord::Base) do
353
+ self.table_name = "books"
354
+ enum status: [:drafted, :uploaded]
355
+ end
356
+
357
+ book1 = klass1.proposed.create!
358
+ book1.status = :written
359
+ assert_equal ['proposed', 'written'], book1.status_change
360
+
361
+ book2 = klass2.drafted.create!
362
+ book2.status = :uploaded
363
+ assert_equal ['drafted', 'uploaded'], book2.status_change
364
+ end
365
+
366
+ test "enums are inheritable" do
367
+ subklass1 = Class.new(Book)
368
+
369
+ subklass2 = Class.new(Book) do
370
+ enum status: [:drafted, :uploaded]
371
+ end
372
+
373
+ book1 = subklass1.proposed.create!
374
+ book1.status = :written
375
+ assert_equal ['proposed', 'written'], book1.status_change
376
+
377
+ book2 = subklass2.drafted.create!
378
+ book2.status = :uploaded
379
+ assert_equal ['drafted', 'uploaded'], book2.status_change
380
+ end
381
+
382
+ test "declare multiple enums at a time" do
383
+ klass = Class.new(ActiveRecord::Base) do
384
+ self.table_name = "books"
385
+ enum status: [:proposed, :written, :published],
386
+ nullable_status: [:single, :married]
387
+ end
388
+
389
+ book1 = klass.proposed.create!
390
+ assert book1.proposed?
391
+
392
+ book2 = klass.single.create!
393
+ assert book2.single?
394
+ end
395
+
396
+ test "enum with alias_attribute" do
397
+ klass = Class.new(ActiveRecord::Base) do
398
+ self.table_name = "books"
399
+ alias_attribute :aliased_status, :status
400
+ enum aliased_status: [:proposed, :written, :published]
401
+ end
402
+
403
+ book = klass.proposed.create!
404
+ assert book.proposed?
405
+ assert_equal 'proposed', book.aliased_status
406
+
407
+ book = klass.find(book.id)
408
+ assert book.proposed?
409
+ assert_equal 'proposed', book.aliased_status
410
+ end
411
+
412
+ test "query state by predicate with prefix" do
413
+ assert @book.author_visibility_visible?
414
+ assert_not @book.author_visibility_invisible?
415
+ assert @book.illustrator_visibility_visible?
416
+ assert_not @book.illustrator_visibility_invisible?
417
+ end
418
+
419
+ test "query state by predicate with custom prefix" do
420
+ assert @book.in_english?
421
+ assert_not @book.in_spanish?
422
+ assert_not @book.in_french?
423
+ end
424
+
425
+ test "uses default status when no status is provided in fixtures" do
426
+ book = books(:tlg)
427
+ assert book.proposed?, "expected fixture to default to proposed status"
428
+ assert book.in_english?, "expected fixture to default to english language"
429
+ end
430
+
431
+ test "uses default value from database on initialization" do
432
+ book = Book.new
433
+ assert book.proposed?
434
+ end
435
+
436
+ test "uses default value from database on initialization when using custom mapping" do
437
+ book = Book.new
438
+ assert book.hard?
439
+ end
440
+
441
+ test "data type of Enum type" do
442
+ assert_equal :integer, Book.type_for_attribute('status').type
443
+ end
444
+ end