ibm_db 3.0.0-x86-mingw32 → 3.0.1-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 (465) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGES +4 -0
  3. data/MANIFEST +14 -14
  4. data/README +225 -225
  5. data/ext/Makefile.nt32 +181 -181
  6. data/ext/Makefile.nt32.191 +212 -212
  7. data/ext/OLD/extconf.rb +264 -0
  8. data/ext/{extconf_MacOS.rb → OLD/extconf_MacOS.rb} +269 -269
  9. data/ext/extconf.rb +291 -264
  10. data/ext/ibm_db.c +2 -2
  11. data/ext/ruby_ibm_db.h +241 -241
  12. data/ext/ruby_ibm_db_cli.h +500 -500
  13. data/init.rb +41 -41
  14. data/lib/IBM_DB.rb +27 -27
  15. data/lib/active_record/connection_adapters/ibm_db_adapter.rb +4 -4
  16. data/lib/active_record/connection_adapters/ibmdb_adapter.rb +1 -1
  17. data/lib/active_record/vendor/db2-i5-zOS.yaml +328 -328
  18. data/lib/mswin32/ibm_db.rb +115 -115
  19. data/test/active_record/connection_adapters/fake_adapter.rb +46 -0
  20. data/test/assets/example.log +1 -0
  21. data/test/assets/flowers.jpg +0 -0
  22. data/test/assets/test.txt +1 -0
  23. data/test/cases/adapter_test.rb +261 -207
  24. data/test/cases/aggregations_test.rb +158 -0
  25. data/test/cases/ar_schema_test.rb +161 -0
  26. data/test/cases/associations/association_scope_test.rb +21 -0
  27. data/test/cases/associations/belongs_to_associations_test.rb +1029 -711
  28. data/test/cases/associations/callbacks_test.rb +192 -0
  29. data/test/cases/associations/cascaded_eager_loading_test.rb +188 -181
  30. data/test/cases/associations/deprecated_counter_cache_on_has_many_through_test.rb +26 -0
  31. data/test/cases/associations/eager_load_includes_full_sti_class_test.rb +36 -0
  32. data/test/cases/associations/eager_load_nested_include_test.rb +128 -0
  33. data/test/cases/associations/eager_singularization_test.rb +148 -0
  34. data/test/cases/associations/eager_test.rb +1411 -0
  35. data/test/cases/associations/extension_test.rb +82 -0
  36. data/test/cases/associations/has_and_belongs_to_many_associations_test.rb +932 -851
  37. data/test/cases/associations/has_many_associations_test.rb +2162 -0
  38. data/test/cases/associations/has_many_through_associations_test.rb +1204 -0
  39. data/test/cases/associations/has_one_associations_test.rb +610 -0
  40. data/test/cases/associations/has_one_through_associations_test.rb +380 -0
  41. data/test/cases/associations/inner_join_association_test.rb +139 -0
  42. data/test/cases/associations/inverse_associations_test.rb +693 -0
  43. data/test/cases/associations/join_model_test.rb +754 -743
  44. data/test/cases/associations/nested_through_associations_test.rb +579 -0
  45. data/test/cases/associations/required_test.rb +82 -0
  46. data/test/cases/associations_test.rb +380 -0
  47. data/test/cases/attribute_decorators_test.rb +125 -0
  48. data/test/cases/attribute_methods/read_test.rb +60 -0
  49. data/test/cases/attribute_methods/serialization_test.rb +29 -0
  50. data/test/cases/attribute_methods_test.rb +952 -822
  51. data/test/cases/attribute_set_test.rb +200 -0
  52. data/test/cases/attribute_test.rb +180 -0
  53. data/test/cases/attributes_test.rb +136 -0
  54. data/test/cases/autosave_association_test.rb +1595 -0
  55. data/test/cases/base_test.rb +1638 -2133
  56. data/test/cases/batches_test.rb +212 -0
  57. data/test/cases/binary_test.rb +52 -0
  58. data/test/cases/bind_parameter_test.rb +100 -0
  59. data/test/cases/calculations_test.rb +646 -482
  60. data/test/cases/callbacks_test.rb +543 -0
  61. data/test/cases/clone_test.rb +40 -0
  62. data/test/cases/coders/yaml_column_test.rb +63 -0
  63. data/test/cases/column_alias_test.rb +17 -0
  64. data/test/cases/column_definition_test.rb +123 -0
  65. data/test/cases/connection_adapters/adapter_leasing_test.rb +54 -0
  66. data/test/cases/connection_adapters/connection_handler_test.rb +53 -0
  67. data/test/cases/connection_adapters/connection_specification_test.rb +12 -0
  68. data/test/cases/connection_adapters/merge_and_resolve_default_url_config_test.rb +293 -0
  69. data/test/cases/connection_adapters/mysql_type_lookup_test.rb +65 -0
  70. data/test/cases/connection_adapters/quoting_test.rb +13 -0
  71. data/test/cases/connection_adapters/schema_cache_test.rb +56 -0
  72. data/test/cases/connection_adapters/type_lookup_test.rb +110 -0
  73. data/test/cases/connection_management_test.rb +122 -0
  74. data/test/cases/connection_pool_test.rb +346 -0
  75. data/test/cases/connection_specification/resolver_test.rb +116 -0
  76. data/test/cases/core_test.rb +112 -0
  77. data/test/cases/counter_cache_test.rb +209 -0
  78. data/test/cases/custom_locking_test.rb +17 -0
  79. data/test/cases/database_statements_test.rb +19 -0
  80. data/test/cases/date_time_test.rb +61 -0
  81. data/test/cases/defaults_test.rb +223 -0
  82. data/test/cases/dirty_test.rb +775 -0
  83. data/test/cases/disconnected_test.rb +28 -0
  84. data/test/cases/dup_test.rb +157 -0
  85. data/test/cases/enum_test.rb +290 -0
  86. data/test/cases/explain_subscriber_test.rb +64 -0
  87. data/test/cases/explain_test.rb +76 -0
  88. data/test/cases/finder_respond_to_test.rb +60 -0
  89. data/test/cases/finder_test.rb +1166 -0
  90. data/test/cases/fixture_set/file_test.rb +138 -0
  91. data/test/cases/fixtures_test.rb +897 -0
  92. data/test/cases/forbidden_attributes_protection_test.rb +99 -0
  93. data/test/cases/habtm_destroy_order_test.rb +61 -0
  94. data/test/cases/helper.rb +210 -0
  95. data/test/cases/hot_compatibility_test.rb +54 -0
  96. data/test/cases/i18n_test.rb +45 -0
  97. data/test/cases/inheritance_test.rb +375 -0
  98. data/test/cases/integration_test.rb +139 -0
  99. data/test/cases/invalid_connection_test.rb +22 -0
  100. data/test/cases/invalid_date_test.rb +32 -0
  101. data/test/cases/invertible_migration_test.rb +295 -0
  102. data/test/cases/json_serialization_test.rb +302 -0
  103. data/test/cases/locking_test.rb +477 -0
  104. data/test/cases/log_subscriber_test.rb +136 -0
  105. data/test/cases/migration/change_schema_test - Copy.rb +448 -0
  106. data/test/cases/migration/change_schema_test.rb +472 -0
  107. data/test/cases/migration/change_table_test.rb +224 -0
  108. data/test/cases/migration/column_attributes_test.rb +192 -0
  109. data/test/cases/migration/column_positioning_test.rb +56 -0
  110. data/test/cases/migration/columns_test.rb +304 -0
  111. data/test/cases/migration/command_recorder_test.rb +305 -0
  112. data/test/cases/migration/create_join_table_test.rb +148 -0
  113. data/test/cases/migration/foreign_key_test - Changed.rb +325 -0
  114. data/test/cases/migration/foreign_key_test.rb +360 -0
  115. data/test/cases/migration/helper.rb +39 -0
  116. data/test/cases/migration/index_test.rb +216 -0
  117. data/test/cases/migration/logger_test.rb +36 -0
  118. data/test/cases/migration/pending_migrations_test.rb +53 -0
  119. data/test/cases/migration/references_foreign_key_test.rb +214 -0
  120. data/test/cases/migration/references_index_test.rb +101 -0
  121. data/test/cases/migration/references_statements_test.rb +116 -0
  122. data/test/cases/migration/rename_table_test.rb +93 -0
  123. data/test/cases/migration/table_and_index_test.rb +24 -0
  124. data/test/cases/migration_test.rb +959 -2408
  125. data/test/cases/migrator_test.rb +388 -0
  126. data/test/cases/mixin_test.rb +70 -0
  127. data/test/cases/modules_test.rb +173 -0
  128. data/test/cases/multiparameter_attributes_test.rb +350 -0
  129. data/test/cases/multiple_db_test.rb +115 -0
  130. data/test/cases/nested_attributes_test.rb +1057 -0
  131. data/test/cases/nested_attributes_with_callbacks_test.rb +144 -0
  132. data/test/cases/persistence_test.rb +909 -642
  133. data/test/cases/pooled_connections_test.rb +81 -0
  134. data/test/cases/primary_keys_test.rb +237 -0
  135. data/test/cases/query_cache_test.rb +326 -257
  136. data/test/cases/quoting_test.rb +156 -0
  137. data/test/cases/readonly_test.rb +118 -0
  138. data/test/cases/reaper_test.rb +85 -0
  139. data/test/cases/reflection_test.rb +454 -0
  140. data/test/cases/relation/delegation_test.rb +68 -0
  141. data/test/cases/relation/merging_test.rb +161 -0
  142. data/test/cases/relation/mutation_test.rb +165 -0
  143. data/test/cases/relation/predicate_builder_test.rb +14 -0
  144. data/test/cases/relation/where_chain_test.rb +181 -0
  145. data/test/cases/relation/where_test.rb +300 -0
  146. data/test/cases/relation/where_test2.rb +36 -0
  147. data/test/cases/relation_test.rb +297 -0
  148. data/test/cases/relations_test.rb +1815 -1182
  149. data/test/cases/reload_models_test.rb +22 -0
  150. data/test/cases/result_test.rb +80 -0
  151. data/test/cases/sanitize_test.rb +83 -0
  152. data/test/cases/schema_dumper_test.rb +463 -256
  153. data/test/cases/scoping/default_scoping_test.rb +454 -0
  154. data/test/cases/scoping/named_scoping_test.rb +524 -0
  155. data/test/cases/scoping/relation_scoping_test.rb +357 -0
  156. data/test/cases/serialization_test.rb +104 -0
  157. data/test/cases/serialized_attribute_test.rb +277 -0
  158. data/test/cases/statement_cache_test.rb +98 -0
  159. data/test/cases/store_test.rb +194 -0
  160. data/test/cases/tasks/database_tasks_test.rb +396 -0
  161. data/test/cases/tasks/mysql_rake_test.rb +311 -0
  162. data/test/cases/tasks/postgresql_rake_test.rb +245 -0
  163. data/test/cases/tasks/sqlite_rake_test.rb +193 -0
  164. data/test/cases/test_case.rb +123 -0
  165. data/test/cases/timestamp_test.rb +468 -0
  166. data/test/cases/transaction_callbacks_test.rb +452 -300
  167. data/test/cases/transaction_isolation_test.rb +106 -0
  168. data/test/cases/transactions_test.rb +817 -0
  169. data/test/cases/type/decimal_test.rb +51 -0
  170. data/test/cases/type/integer_test.rb +121 -0
  171. data/test/cases/type/string_test.rb +36 -0
  172. data/test/cases/type/type_map_test.rb +177 -0
  173. data/test/cases/type/unsigned_integer_test.rb +18 -0
  174. data/test/cases/types_test.rb +141 -0
  175. data/test/cases/unconnected_test.rb +33 -0
  176. data/test/cases/validations/association_validation_test.rb +86 -0
  177. data/test/cases/validations/i18n_generate_message_validation_test.rb +84 -0
  178. data/test/cases/validations/i18n_validation_test.rb +90 -0
  179. data/test/cases/validations/length_validation_test.rb +47 -0
  180. data/test/cases/validations/presence_validation_test.rb +68 -0
  181. data/test/cases/validations/uniqueness_validation_test.rb +434 -299
  182. data/test/cases/validations_repair_helper.rb +23 -0
  183. data/test/cases/validations_test.rb +165 -0
  184. data/test/cases/view_test.rb +113 -0
  185. data/test/cases/xml_serialization_test.rb +457 -408
  186. data/test/cases/yaml_serialization_test.rb +86 -0
  187. data/test/config.rb +5 -0
  188. data/test/config.yml +154 -154
  189. data/test/connections/native_ibm_db/connection.rb +43 -43
  190. data/test/fixtures/accounts.yml +29 -0
  191. data/test/fixtures/admin/accounts.yml +2 -0
  192. data/test/fixtures/admin/randomly_named_a9.yml +7 -0
  193. data/test/fixtures/admin/randomly_named_b0.yml +7 -0
  194. data/test/fixtures/admin/users.yml +10 -0
  195. data/test/fixtures/all/admin +1 -0
  196. data/test/fixtures/all/developers.yml +0 -0
  197. data/test/fixtures/all/people.yml +0 -0
  198. data/test/fixtures/all/tasks.yml +0 -0
  199. data/test/fixtures/author_addresses.yml +18 -0
  200. data/test/fixtures/author_favorites.yml +4 -0
  201. data/test/fixtures/authors.yml +23 -0
  202. data/test/fixtures/binaries.yml +133 -0
  203. data/test/fixtures/books.yml +11 -0
  204. data/test/fixtures/bulbs.yml +5 -0
  205. data/test/fixtures/cars.yml +9 -0
  206. data/test/fixtures/categories.yml +19 -0
  207. data/test/fixtures/categories/special_categories.yml +9 -0
  208. data/test/fixtures/categories/subsubdir/arbitrary_filename.yml +4 -0
  209. data/test/fixtures/categories_ordered.yml +7 -0
  210. data/test/fixtures/categories_posts.yml +31 -0
  211. data/test/fixtures/categorizations.yml +23 -0
  212. data/test/fixtures/clubs.yml +8 -0
  213. data/test/fixtures/collections.yml +3 -0
  214. data/test/fixtures/colleges.yml +3 -0
  215. data/test/fixtures/comments.yml +65 -0
  216. data/test/fixtures/companies.yml +67 -0
  217. data/test/fixtures/computers.yml +10 -0
  218. data/test/fixtures/courses.yml +8 -0
  219. data/test/fixtures/customers.yml +26 -0
  220. data/test/fixtures/dashboards.yml +6 -0
  221. data/test/fixtures/developers.yml +22 -0
  222. data/test/fixtures/developers_projects.yml +17 -0
  223. data/test/fixtures/dog_lovers.yml +7 -0
  224. data/test/fixtures/dogs.yml +4 -0
  225. data/test/fixtures/doubloons.yml +3 -0
  226. data/test/fixtures/edges.yml +5 -0
  227. data/test/fixtures/entrants.yml +14 -0
  228. data/test/fixtures/essays.yml +6 -0
  229. data/test/fixtures/faces.yml +11 -0
  230. data/test/fixtures/fk_test_has_fk.yml +3 -0
  231. data/test/fixtures/fk_test_has_pk.yml +2 -0
  232. data/test/fixtures/friendships.yml +4 -0
  233. data/test/fixtures/funny_jokes.yml +10 -0
  234. data/test/fixtures/interests.yml +33 -0
  235. data/test/fixtures/items.yml +3 -0
  236. data/test/fixtures/jobs.yml +7 -0
  237. data/test/fixtures/legacy_things.yml +3 -0
  238. data/test/fixtures/mateys.yml +4 -0
  239. data/test/fixtures/member_details.yml +8 -0
  240. data/test/fixtures/member_types.yml +6 -0
  241. data/test/fixtures/members.yml +11 -0
  242. data/test/fixtures/memberships.yml +34 -0
  243. data/test/fixtures/men.yml +5 -0
  244. data/test/fixtures/minimalistics.yml +2 -0
  245. data/test/fixtures/minivans.yml +5 -0
  246. data/test/fixtures/mixed_case_monkeys.yml +6 -0
  247. data/test/fixtures/mixins.yml +29 -0
  248. data/test/fixtures/movies.yml +7 -0
  249. data/test/fixtures/naked/csv/accounts.csv +1 -0
  250. data/test/fixtures/naked/yml/accounts.yml +1 -0
  251. data/test/fixtures/naked/yml/companies.yml +1 -0
  252. data/test/fixtures/naked/yml/courses.yml +1 -0
  253. data/test/fixtures/organizations.yml +5 -0
  254. data/test/fixtures/other_topics.yml +42 -0
  255. data/test/fixtures/owners.yml +9 -0
  256. data/test/fixtures/parrots.yml +27 -0
  257. data/test/fixtures/parrots_pirates.yml +7 -0
  258. data/test/fixtures/people.yml +24 -0
  259. data/test/fixtures/peoples_treasures.yml +3 -0
  260. data/test/fixtures/pets.yml +19 -0
  261. data/test/fixtures/pirates.yml +12 -0
  262. data/test/fixtures/posts.yml +80 -0
  263. data/test/fixtures/price_estimates.yml +7 -0
  264. data/test/fixtures/products.yml +4 -0
  265. data/test/fixtures/projects.yml +7 -0
  266. data/test/fixtures/randomly_named_a9.yml +7 -0
  267. data/test/fixtures/ratings.yml +14 -0
  268. data/test/fixtures/readers.yml +11 -0
  269. data/test/fixtures/references.yml +17 -0
  270. data/test/fixtures/reserved_words/distinct.yml +5 -0
  271. data/test/fixtures/reserved_words/distinct_select.yml +11 -0
  272. data/test/fixtures/reserved_words/group.yml +14 -0
  273. data/test/fixtures/reserved_words/select.yml +8 -0
  274. data/test/fixtures/reserved_words/values.yml +7 -0
  275. data/test/fixtures/ships.yml +6 -0
  276. data/test/fixtures/speedometers.yml +8 -0
  277. data/test/fixtures/sponsors.yml +12 -0
  278. data/test/fixtures/string_key_objects.yml +7 -0
  279. data/test/fixtures/subscribers.yml +11 -0
  280. data/test/fixtures/subscriptions.yml +12 -0
  281. data/test/fixtures/taggings.yml +78 -0
  282. data/test/fixtures/tags.yml +11 -0
  283. data/test/fixtures/tasks.yml +7 -0
  284. data/test/fixtures/teapots.yml +3 -0
  285. data/test/fixtures/to_be_linked/accounts.yml +2 -0
  286. data/test/fixtures/to_be_linked/users.yml +10 -0
  287. data/test/fixtures/topics.yml +49 -0
  288. data/test/fixtures/toys.yml +14 -0
  289. data/test/fixtures/traffic_lights.yml +10 -0
  290. data/test/fixtures/treasures.yml +10 -0
  291. data/test/fixtures/uuid_children.yml +3 -0
  292. data/test/fixtures/uuid_parents.yml +2 -0
  293. data/test/fixtures/variants.yml +4 -0
  294. data/test/fixtures/vegetables.yml +20 -0
  295. data/test/fixtures/vertices.yml +4 -0
  296. data/test/fixtures/warehouse_things.yml +3 -0
  297. data/test/fixtures/zines.yml +5 -0
  298. data/test/ibm_db_test.rb +24 -24
  299. data/test/migrations/10_urban/9_add_expressions.rb +11 -0
  300. data/test/migrations/decimal/1_give_me_big_numbers.rb +15 -0
  301. data/test/migrations/magic/1_currencies_have_symbols.rb +12 -0
  302. data/test/migrations/missing/1000_people_have_middle_names.rb +9 -0
  303. data/test/migrations/missing/1_people_have_last_names.rb +9 -0
  304. data/test/migrations/missing/3_we_need_reminders.rb +12 -0
  305. data/test/migrations/missing/4_innocent_jointable.rb +12 -0
  306. data/test/migrations/rename/1_we_need_things.rb +11 -0
  307. data/test/migrations/rename/2_rename_things.rb +9 -0
  308. data/test/migrations/to_copy/1_people_have_hobbies.rb +9 -0
  309. data/test/migrations/to_copy/2_people_have_descriptions.rb +9 -0
  310. data/test/migrations/to_copy2/1_create_articles.rb +7 -0
  311. data/test/migrations/to_copy2/2_create_comments.rb +7 -0
  312. data/test/migrations/to_copy_with_name_collision/1_people_have_hobbies.rb +9 -0
  313. data/test/migrations/to_copy_with_timestamps/20090101010101_people_have_hobbies.rb +9 -0
  314. data/test/migrations/to_copy_with_timestamps/20090101010202_people_have_descriptions.rb +9 -0
  315. data/test/migrations/to_copy_with_timestamps2/20090101010101_create_articles.rb +7 -0
  316. data/test/migrations/to_copy_with_timestamps2/20090101010202_create_comments.rb +7 -0
  317. data/test/migrations/valid/1_valid_people_have_last_names.rb +9 -0
  318. data/test/migrations/valid/2_we_need_reminders.rb +12 -0
  319. data/test/migrations/valid/3_innocent_jointable.rb +12 -0
  320. data/test/migrations/valid_with_subdirectories/1_valid_people_have_last_names.rb +9 -0
  321. data/test/migrations/valid_with_subdirectories/sub/2_we_need_reminders.rb +12 -0
  322. data/test/migrations/valid_with_subdirectories/sub1/3_innocent_jointable.rb +12 -0
  323. data/test/migrations/valid_with_timestamps/20100101010101_valid_with_timestamps_people_have_last_names.rb +9 -0
  324. data/test/migrations/valid_with_timestamps/20100201010101_valid_with_timestamps_we_need_reminders.rb +12 -0
  325. data/test/migrations/valid_with_timestamps/20100301010101_valid_with_timestamps_innocent_jointable.rb +12 -0
  326. data/test/migrations/version_check/20131219224947_migration_version_check.rb +8 -0
  327. data/test/models/admin.rb +5 -0
  328. data/test/models/admin/account.rb +3 -0
  329. data/test/models/admin/randomly_named_c1.rb +3 -0
  330. data/test/models/admin/user.rb +40 -0
  331. data/test/models/aircraft.rb +4 -0
  332. data/test/models/arunit2_model.rb +3 -0
  333. data/test/models/author.rb +212 -0
  334. data/test/models/auto_id.rb +4 -0
  335. data/test/models/autoloadable/extra_firm.rb +2 -0
  336. data/test/models/binary.rb +2 -0
  337. data/test/models/bird.rb +12 -0
  338. data/test/models/book.rb +18 -0
  339. data/test/models/boolean.rb +2 -0
  340. data/test/models/bulb.rb +51 -0
  341. data/test/models/cake_designer.rb +3 -0
  342. data/test/models/car.rb +26 -0
  343. data/test/models/carrier.rb +2 -0
  344. data/test/models/categorization.rb +19 -0
  345. data/test/models/category.rb +35 -0
  346. data/test/models/chef.rb +3 -0
  347. data/test/models/citation.rb +3 -0
  348. data/test/models/club.rb +23 -0
  349. data/test/models/college.rb +10 -0
  350. data/test/models/column.rb +3 -0
  351. data/test/models/column_name.rb +3 -0
  352. data/test/models/comment.rb +64 -0
  353. data/test/models/company.rb +225 -0
  354. data/test/models/company_in_module.rb +98 -0
  355. data/test/models/computer.rb +3 -0
  356. data/test/models/contact.rb +41 -0
  357. data/test/models/contract.rb +20 -0
  358. data/test/models/country.rb +7 -0
  359. data/test/models/course.rb +6 -0
  360. data/test/models/customer.rb +77 -0
  361. data/test/models/customer_carrier.rb +14 -0
  362. data/test/models/dashboard.rb +3 -0
  363. data/test/models/default.rb +2 -0
  364. data/test/models/department.rb +4 -0
  365. data/test/models/developer.rb +252 -0
  366. data/test/models/dog.rb +5 -0
  367. data/test/models/dog_lover.rb +5 -0
  368. data/test/models/doubloon.rb +12 -0
  369. data/test/models/drink_designer.rb +3 -0
  370. data/test/models/edge.rb +5 -0
  371. data/test/models/electron.rb +5 -0
  372. data/test/models/engine.rb +4 -0
  373. data/test/models/entrant.rb +3 -0
  374. data/test/models/essay.rb +5 -0
  375. data/test/models/event.rb +3 -0
  376. data/test/models/eye.rb +37 -0
  377. data/test/models/face.rb +9 -0
  378. data/test/models/friendship.rb +6 -0
  379. data/test/models/guid.rb +2 -0
  380. data/test/models/hotel.rb +6 -0
  381. data/test/models/image.rb +3 -0
  382. data/test/models/interest.rb +5 -0
  383. data/test/models/invoice.rb +4 -0
  384. data/test/models/item.rb +7 -0
  385. data/test/models/job.rb +7 -0
  386. data/test/models/joke.rb +7 -0
  387. data/test/models/keyboard.rb +3 -0
  388. data/test/models/legacy_thing.rb +3 -0
  389. data/test/models/lesson.rb +11 -0
  390. data/test/models/line_item.rb +3 -0
  391. data/test/models/liquid.rb +4 -0
  392. data/test/models/man.rb +11 -0
  393. data/test/models/matey.rb +4 -0
  394. data/test/models/member.rb +41 -0
  395. data/test/models/member_detail.rb +7 -0
  396. data/test/models/member_type.rb +3 -0
  397. data/test/models/membership.rb +35 -0
  398. data/test/models/minimalistic.rb +2 -0
  399. data/test/models/minivan.rb +9 -0
  400. data/test/models/mixed_case_monkey.rb +3 -0
  401. data/test/models/molecule.rb +6 -0
  402. data/test/models/movie.rb +5 -0
  403. data/test/models/order.rb +4 -0
  404. data/test/models/organization.rb +14 -0
  405. data/test/models/owner.rb +34 -0
  406. data/test/models/parrot.rb +29 -0
  407. data/test/models/person.rb +143 -0
  408. data/test/models/personal_legacy_thing.rb +4 -0
  409. data/test/models/pet.rb +15 -0
  410. data/test/models/pirate.rb +92 -0
  411. data/test/models/possession.rb +3 -0
  412. data/test/models/post.rb +264 -0
  413. data/test/models/price_estimate.rb +4 -0
  414. data/test/models/professor.rb +5 -0
  415. data/test/models/project.rb +29 -0
  416. data/test/models/publisher.rb +2 -0
  417. data/test/models/publisher/article.rb +4 -0
  418. data/test/models/publisher/magazine.rb +3 -0
  419. data/test/models/randomly_named_c1.rb +3 -0
  420. data/test/models/rating.rb +4 -0
  421. data/test/models/reader.rb +23 -0
  422. data/test/models/record.rb +2 -0
  423. data/test/models/reference.rb +22 -0
  424. data/test/models/reply.rb +61 -0
  425. data/test/models/ship.rb +33 -0
  426. data/test/models/ship_part.rb +8 -0
  427. data/test/models/shop.rb +17 -0
  428. data/test/models/shop_account.rb +6 -0
  429. data/test/models/speedometer.rb +6 -0
  430. data/test/models/sponsor.rb +7 -0
  431. data/test/models/string_key_object.rb +3 -0
  432. data/test/models/student.rb +4 -0
  433. data/test/models/subject.rb +16 -0
  434. data/test/models/subscriber.rb +8 -0
  435. data/test/models/subscription.rb +4 -0
  436. data/test/models/tag.rb +7 -0
  437. data/test/models/tagging.rb +13 -0
  438. data/test/models/task.rb +5 -0
  439. data/test/models/topic.rb +124 -0
  440. data/test/models/toy.rb +6 -0
  441. data/test/models/traffic_light.rb +4 -0
  442. data/test/models/treasure.rb +14 -0
  443. data/test/models/treaty.rb +7 -0
  444. data/test/models/tyre.rb +11 -0
  445. data/test/models/uuid_child.rb +3 -0
  446. data/test/models/uuid_parent.rb +3 -0
  447. data/test/models/vegetables.rb +24 -0
  448. data/test/models/vehicle.rb +7 -0
  449. data/test/models/vertex.rb +9 -0
  450. data/test/models/warehouse_thing.rb +5 -5
  451. data/test/models/wheel.rb +3 -0
  452. data/test/models/without_table.rb +3 -0
  453. data/test/models/zine.rb +3 -0
  454. data/test/schema/mysql2_specific_schema.rb +58 -0
  455. data/test/schema/mysql_specific_schema.rb +70 -0
  456. data/test/schema/oracle_specific_schema.rb +43 -0
  457. data/test/schema/postgresql_specific_schema.rb +202 -0
  458. data/test/schema/schema.rb +938 -751
  459. data/test/schema/sqlite_specific_schema.rb +22 -0
  460. data/test/support/config.rb +43 -0
  461. data/test/support/connection.rb +22 -0
  462. data/test/support/connection_helper.rb +14 -0
  463. data/test/support/ddl_helper.rb +8 -0
  464. data/test/support/schema_dumping_helper.rb +20 -0
  465. metadata +444 -18
@@ -0,0 +1,375 @@
1
+ require 'cases/helper'
2
+ require 'models/company'
3
+ require 'models/person'
4
+ require 'models/post'
5
+ require 'models/project'
6
+ require 'models/subscriber'
7
+ require 'models/vegetables'
8
+ require 'models/shop'
9
+
10
+ class InheritanceTest < ActiveRecord::TestCase
11
+ fixtures :companies, :projects, :subscribers, :accounts, :vegetables
12
+
13
+ def test_class_with_store_full_sti_class_returns_full_name
14
+ old = ActiveRecord::Base.store_full_sti_class
15
+ ActiveRecord::Base.store_full_sti_class = true
16
+ assert_equal 'Namespaced::Company', Namespaced::Company.sti_name
17
+ ensure
18
+ ActiveRecord::Base.store_full_sti_class = old
19
+ end
20
+
21
+ def test_class_with_blank_sti_name
22
+ company = Company.first
23
+ company = company.dup
24
+ company.extend(Module.new {
25
+ def _read_attribute(name)
26
+ return ' ' if name == 'type'
27
+ super
28
+ end
29
+ })
30
+ company.save!
31
+ company = Company.all.to_a.find { |x| x.id == company.id }
32
+ assert_equal ' ', company.type
33
+ end
34
+
35
+ def test_class_without_store_full_sti_class_returns_demodulized_name
36
+ old = ActiveRecord::Base.store_full_sti_class
37
+ ActiveRecord::Base.store_full_sti_class = false
38
+ assert_equal 'Company', Namespaced::Company.sti_name
39
+ ensure
40
+ ActiveRecord::Base.store_full_sti_class = old
41
+ end
42
+
43
+ def test_should_store_demodulized_class_name_with_store_full_sti_class_option_disabled
44
+ old = ActiveRecord::Base.store_full_sti_class
45
+ ActiveRecord::Base.store_full_sti_class = false
46
+ item = Namespaced::Company.new
47
+ assert_equal 'Company', item[:type]
48
+ ensure
49
+ ActiveRecord::Base.store_full_sti_class = old
50
+ end
51
+
52
+ def test_should_store_full_class_name_with_store_full_sti_class_option_enabled
53
+ old = ActiveRecord::Base.store_full_sti_class
54
+ ActiveRecord::Base.store_full_sti_class = true
55
+ item = Namespaced::Company.new
56
+ assert_equal 'Namespaced::Company', item[:type]
57
+ ensure
58
+ ActiveRecord::Base.store_full_sti_class = old
59
+ end
60
+
61
+ def test_different_namespace_subclass_should_load_correctly_with_store_full_sti_class_option
62
+ old = ActiveRecord::Base.store_full_sti_class
63
+ ActiveRecord::Base.store_full_sti_class = true
64
+ item = Namespaced::Company.create :name => "Wolverine 2"
65
+ assert_not_nil Company.find(item.id)
66
+ assert_not_nil Namespaced::Company.find(item.id)
67
+ ensure
68
+ ActiveRecord::Base.store_full_sti_class = old
69
+ end
70
+
71
+ def test_company_descends_from_active_record
72
+ assert !ActiveRecord::Base.descends_from_active_record?
73
+ assert AbstractCompany.descends_from_active_record?, 'AbstractCompany should descend from ActiveRecord::Base'
74
+ assert Company.descends_from_active_record?, 'Company should descend from ActiveRecord::Base'
75
+ assert !Class.new(Company).descends_from_active_record?, 'Company subclass should not descend from ActiveRecord::Base'
76
+ end
77
+
78
+ def test_inheritance_base_class
79
+ assert_equal Post, Post.base_class
80
+ assert_equal Post, SpecialPost.base_class
81
+ assert_equal Post, StiPost.base_class
82
+ assert_equal SubStiPost, SubStiPost.base_class
83
+ end
84
+
85
+ def test_abstract_inheritance_base_class
86
+ assert_equal LoosePerson, LoosePerson.base_class
87
+ assert_equal LooseDescendant, LooseDescendant.base_class
88
+ assert_equal TightPerson, TightPerson.base_class
89
+ assert_equal TightPerson, TightDescendant.base_class
90
+ end
91
+
92
+ def test_base_class_activerecord_error
93
+ klass = Class.new { include ActiveRecord::Inheritance }
94
+ assert_raise(ActiveRecord::ActiveRecordError) { klass.base_class }
95
+ end
96
+
97
+ def test_a_bad_type_column
98
+ Company.connection.insert "INSERT INTO companies (id, #{QUOTED_TYPE}, name) VALUES(100, 'bad_class!', 'Not happening')"
99
+
100
+ assert_raise(ActiveRecord::SubclassNotFound) { Company.find(100) }
101
+ end
102
+
103
+ def test_inheritance_find
104
+ assert_kind_of Firm, Company.find(1), "37signals should be a firm"
105
+ assert_kind_of Firm, Firm.find(1), "37signals should be a firm"
106
+ assert_kind_of Client, Company.find(2), "Summit should be a client"
107
+ assert_kind_of Client, Client.find(2), "Summit should be a client"
108
+ end
109
+
110
+ def test_alt_inheritance_find
111
+ assert_kind_of Cucumber, Vegetable.find(1)
112
+ assert_kind_of Cucumber, Cucumber.find(1)
113
+ assert_kind_of Cabbage, Vegetable.find(2)
114
+ assert_kind_of Cabbage, Cabbage.find(2)
115
+ end
116
+
117
+ def test_alt_becomes_works_with_sti
118
+ vegetable = Vegetable.find(1)
119
+ assert_kind_of Vegetable, vegetable
120
+ cabbage = vegetable.becomes(Cabbage)
121
+ assert_kind_of Cabbage, cabbage
122
+ end
123
+
124
+ def test_becomes_and_change_tracking_for_inheritance_columns
125
+ cucumber = Vegetable.find(1)
126
+ cabbage = cucumber.becomes!(Cabbage)
127
+ assert_equal ['Cucumber', 'Cabbage'], cabbage.custom_type_change
128
+ end
129
+
130
+ def test_alt_becomes_bang_resets_inheritance_type_column
131
+ vegetable = Vegetable.create!(name: "Red Pepper")
132
+ assert_nil vegetable.custom_type
133
+
134
+ cabbage = vegetable.becomes!(Cabbage)
135
+ assert_equal "Cabbage", cabbage.custom_type
136
+
137
+ vegetable = cabbage.becomes!(Vegetable)
138
+ assert_nil cabbage.custom_type
139
+ end
140
+
141
+ def test_inheritance_find_all
142
+ companies = Company.all.merge!(:order => 'id').to_a
143
+ assert_kind_of Firm, companies[0], "37signals should be a firm"
144
+ assert_kind_of Client, companies[1], "Summit should be a client"
145
+ end
146
+
147
+ def test_alt_inheritance_find_all
148
+ companies = Vegetable.all.merge!(:order => 'id').to_a
149
+ assert_kind_of Cucumber, companies[0]
150
+ assert_kind_of Cabbage, companies[1]
151
+ end
152
+
153
+ def test_inheritance_save
154
+ firm = Firm.new
155
+ firm.name = "Next Angle"
156
+ firm.save
157
+
158
+ next_angle = Company.find(firm.id)
159
+ assert_kind_of Firm, next_angle, "Next Angle should be a firm"
160
+ end
161
+
162
+ def test_alt_inheritance_save
163
+ cabbage = Cabbage.new(:name => 'Savoy')
164
+ cabbage.save!
165
+
166
+ savoy = Vegetable.find(cabbage.id)
167
+ assert_kind_of Cabbage, savoy
168
+ end
169
+
170
+ def test_inheritance_new_with_default_class
171
+ company = Company.new
172
+ assert_equal Company, company.class
173
+ end
174
+
175
+ def test_inheritance_new_with_base_class
176
+ company = Company.new(:type => 'Company')
177
+ assert_equal Company, company.class
178
+ end
179
+
180
+ def test_inheritance_new_with_subclass
181
+ firm = Company.new(:type => 'Firm')
182
+ assert_equal Firm, firm.class
183
+ end
184
+
185
+ def test_new_with_abstract_class
186
+ e = assert_raises(NotImplementedError) do
187
+ AbstractCompany.new
188
+ end
189
+ assert_equal("AbstractCompany is an abstract class and cannot be instantiated.", e.message)
190
+ end
191
+
192
+ def test_new_with_ar_base
193
+ e = assert_raises(NotImplementedError) do
194
+ ActiveRecord::Base.new
195
+ end
196
+ assert_equal("ActiveRecord::Base is an abstract class and cannot be instantiated.", e.message)
197
+ end
198
+
199
+ def test_new_with_invalid_type
200
+ assert_raise(ActiveRecord::SubclassNotFound) { Company.new(:type => 'InvalidType') }
201
+ end
202
+
203
+ def test_new_with_unrelated_type
204
+ assert_raise(ActiveRecord::SubclassNotFound) { Company.new(:type => 'Account') }
205
+ end
206
+
207
+ def test_new_with_complex_inheritance
208
+ assert_nothing_raised { Client.new(type: 'VerySpecialClient') }
209
+ end
210
+
211
+ def test_new_with_autoload_paths
212
+ path = File.expand_path('../../models/autoloadable', __FILE__)
213
+ ActiveSupport::Dependencies.autoload_paths << path
214
+
215
+ firm = Company.new(:type => 'ExtraFirm')
216
+ assert_equal ExtraFirm, firm.class
217
+ ensure
218
+ ActiveSupport::Dependencies.autoload_paths.reject! { |p| p == path }
219
+ ActiveSupport::Dependencies.clear
220
+ end
221
+
222
+ def test_inheritance_condition
223
+ assert_equal 11, Company.count
224
+ assert_equal 2, Firm.count
225
+ assert_equal 5, Client.count
226
+ end
227
+
228
+ def test_alt_inheritance_condition
229
+ assert_equal 4, Vegetable.count
230
+ assert_equal 1, Cucumber.count
231
+ assert_equal 3, Cabbage.count
232
+ end
233
+
234
+ def test_finding_incorrect_type_data
235
+ assert_raise(ActiveRecord::RecordNotFound) { Firm.find(2) }
236
+ assert_nothing_raised { Firm.find(1) }
237
+ end
238
+
239
+ def test_alt_finding_incorrect_type_data
240
+ assert_raise(ActiveRecord::RecordNotFound) { Cucumber.find(2) }
241
+ assert_nothing_raised { Cucumber.find(1) }
242
+ end
243
+
244
+ def test_update_all_within_inheritance
245
+ Client.update_all "name = 'I am a client'"
246
+ assert_equal "I am a client", Client.first.name
247
+ # Order by added as otherwise Oracle tests were failing because of different order of results
248
+ assert_equal "37signals", Firm.all.merge!(:order => "id").to_a.first.name
249
+ end
250
+
251
+ def test_alt_update_all_within_inheritance
252
+ Cabbage.update_all "name = 'the cabbage'"
253
+ assert_equal "the cabbage", Cabbage.first.name
254
+ assert_equal ["my cucumber"], Cucumber.all.map(&:name).uniq
255
+ end
256
+
257
+ def test_destroy_all_within_inheritance
258
+ Client.destroy_all
259
+ assert_equal 0, Client.count
260
+ assert_equal 2, Firm.count
261
+ end
262
+
263
+ def test_alt_destroy_all_within_inheritance
264
+ Cabbage.destroy_all
265
+ assert_equal 0, Cabbage.count
266
+ assert_equal 1, Cucumber.count
267
+ end
268
+
269
+ def test_find_first_within_inheritance
270
+ assert_kind_of Firm, Company.all.merge!(:where => "name = '37signals'").first
271
+ assert_kind_of Firm, Firm.all.merge!(:where => "name = '37signals'").first
272
+ assert_nil Client.all.merge!(:where => "name = '37signals'").first
273
+ end
274
+
275
+ def test_alt_find_first_within_inheritance
276
+ assert_kind_of Cabbage, Vegetable.all.merge!(:where => "name = 'his cabbage'").first
277
+ assert_kind_of Cabbage, Cabbage.all.merge!(:where => "name = 'his cabbage'").first
278
+ assert_nil Cucumber.all.merge!(:where => "name = 'his cabbage'").first
279
+ end
280
+
281
+ def test_complex_inheritance
282
+ very_special_client = VerySpecialClient.create("name" => "veryspecial")
283
+ assert_equal very_special_client, VerySpecialClient.where("name = 'veryspecial'").first
284
+ assert_equal very_special_client, SpecialClient.all.merge!(:where => "name = 'veryspecial'").first
285
+ assert_equal very_special_client, Company.all.merge!(:where => "name = 'veryspecial'").first
286
+ assert_equal very_special_client, Client.all.merge!(:where => "name = 'veryspecial'").first
287
+ assert_equal 1, Client.all.merge!(:where => "name = 'Summit'").to_a.size
288
+ assert_equal very_special_client, Client.find(very_special_client.id)
289
+ end
290
+
291
+ def test_alt_complex_inheritance
292
+ king_cole = KingCole.create("name" => "uniform heads")
293
+ assert_equal king_cole, KingCole.where("name = 'uniform heads'").first
294
+ assert_equal king_cole, GreenCabbage.all.merge!(:where => "name = 'uniform heads'").first
295
+ assert_equal king_cole, Cabbage.all.merge!(:where => "name = 'uniform heads'").first
296
+ assert_equal king_cole, Vegetable.all.merge!(:where => "name = 'uniform heads'").first
297
+ assert_equal 1, Cabbage.all.merge!(:where => "name = 'his cabbage'").to_a.size
298
+ assert_equal king_cole, Cabbage.find(king_cole.id)
299
+ end
300
+
301
+ def test_eager_load_belongs_to_something_inherited
302
+ account = Account.all.merge!(:includes => :firm).find(1)
303
+ assert account.association(:firm).loaded?, "association was not eager loaded"
304
+ end
305
+
306
+ def test_alt_eager_loading
307
+ cabbage = RedCabbage.all.merge!(:includes => :seller).find(4)
308
+ assert cabbage.association(:seller).loaded?, "association was not eager loaded"
309
+ end
310
+
311
+ def test_eager_load_belongs_to_primary_key_quoting
312
+ con = Account.connection
313
+ assert_sql(/#{con.quote_table_name('companies')}.#{con.quote_column_name('id')} IN \(1\)/) do
314
+ Account.all.merge!(:includes => :firm).find(1)
315
+ end
316
+ end
317
+
318
+ def test_inherits_custom_primary_key
319
+ assert_equal Subscriber.primary_key, SpecialSubscriber.primary_key
320
+ end
321
+
322
+ def test_inheritance_without_mapping
323
+ assert_kind_of SpecialSubscriber, SpecialSubscriber.find("webster132")
324
+ assert_nothing_raised { s = SpecialSubscriber.new("name" => "And breaaaaathe!"); s.id = 'roger'; s.save }
325
+ end
326
+
327
+ def test_scope_inherited_properly
328
+ assert_nothing_raised { Company.of_first_firm }
329
+ assert_nothing_raised { Client.of_first_firm }
330
+ end
331
+ end
332
+
333
+ class InheritanceComputeTypeTest < ActiveRecord::TestCase
334
+ fixtures :companies
335
+
336
+ def setup
337
+ ActiveSupport::Dependencies.log_activity = true
338
+ end
339
+
340
+ teardown do
341
+ ActiveSupport::Dependencies.log_activity = false
342
+ self.class.const_remove :FirmOnTheFly rescue nil
343
+ Firm.const_remove :FirmOnTheFly rescue nil
344
+ end
345
+
346
+ def test_instantiation_doesnt_try_to_require_corresponding_file
347
+ ActiveRecord::Base.store_full_sti_class = false
348
+ foo = Firm.first.clone
349
+ foo.type = 'FirmOnTheFly'
350
+ foo.save!
351
+
352
+ # Should fail without FirmOnTheFly in the type condition.
353
+ assert_raise(ActiveRecord::RecordNotFound) { Firm.find(foo.id) }
354
+
355
+ # Nest FirmOnTheFly in the test case where Dependencies won't see it.
356
+ self.class.const_set :FirmOnTheFly, Class.new(Firm)
357
+ assert_raise(ActiveRecord::SubclassNotFound) { Firm.find(foo.id) }
358
+
359
+ # Nest FirmOnTheFly in Firm where Dependencies will see it.
360
+ # This is analogous to nesting models in a migration.
361
+ Firm.const_set :FirmOnTheFly, Class.new(Firm)
362
+
363
+ # And instantiate will find the existing constant rather than trying
364
+ # to require firm_on_the_fly.
365
+ assert_nothing_raised { assert_kind_of Firm::FirmOnTheFly, Firm.find(foo.id) }
366
+ ensure
367
+ ActiveRecord::Base.store_full_sti_class = true
368
+ end
369
+
370
+ def test_sti_type_from_attributes_disabled_in_non_sti_class
371
+ phone = Shop::Product::Type.new(name: 'Phone')
372
+ product = Shop::Product.new(:type => phone)
373
+ assert product.save
374
+ end
375
+ end
@@ -0,0 +1,139 @@
1
+ # encoding: utf-8
2
+
3
+ require 'cases/helper'
4
+ require 'models/company'
5
+ require 'models/developer'
6
+ require 'models/computer'
7
+ require 'models/owner'
8
+ require 'models/pet'
9
+
10
+ class IntegrationTest < ActiveRecord::TestCase
11
+ fixtures :companies, :developers, :owners, :pets
12
+
13
+ def test_to_param_should_return_string
14
+ assert_kind_of String, Client.first.to_param
15
+ end
16
+
17
+ def test_to_param_returns_nil_if_not_persisted
18
+ client = Client.new
19
+ assert_equal nil, client.to_param
20
+ end
21
+
22
+ def test_to_param_returns_id_if_not_persisted_but_id_is_set
23
+ client = Client.new
24
+ client.id = 1
25
+ assert_equal '1', client.to_param
26
+ end
27
+
28
+ def test_to_param_class_method
29
+ firm = Firm.find(4)
30
+ assert_equal '4-flamboyant-software', firm.to_param
31
+ end
32
+
33
+ def test_to_param_class_method_truncates
34
+ firm = Firm.find(4)
35
+ firm.name = 'a ' * 100
36
+ assert_equal '4-a-a-a-a-a-a-a-a-a', firm.to_param
37
+ end
38
+
39
+ def test_to_param_class_method_truncates_edge_case
40
+ firm = Firm.find(4)
41
+ firm.name = 'David HeinemeierHansson'
42
+ assert_equal '4-david', firm.to_param
43
+ end
44
+
45
+ def test_to_param_class_method_squishes
46
+ firm = Firm.find(4)
47
+ firm.name = "ab \n" * 100
48
+ assert_equal '4-ab-ab-ab-ab-ab-ab', firm.to_param
49
+ end
50
+
51
+ def test_to_param_class_method_multibyte_character
52
+ firm = Firm.find(4)
53
+ firm.name = "戦場ヶ原 ひたぎ"
54
+ assert_equal '4', firm.to_param
55
+ end
56
+
57
+ def test_to_param_class_method_uses_default_if_blank
58
+ firm = Firm.find(4)
59
+ firm.name = nil
60
+ assert_equal '4', firm.to_param
61
+ firm.name = ' '
62
+ assert_equal '4', firm.to_param
63
+ end
64
+
65
+ def test_to_param_class_method_uses_default_if_not_persisted
66
+ firm = Firm.new(name: 'Fancy Shirts')
67
+ assert_equal nil, firm.to_param
68
+ end
69
+
70
+ def test_to_param_with_no_arguments
71
+ assert_equal 'Firm', Firm.to_param
72
+ end
73
+
74
+ def test_cache_key_for_existing_record_is_not_timezone_dependent
75
+ utc_key = Developer.first.cache_key
76
+
77
+ with_timezone_config zone: "EST" do
78
+ est_key = Developer.first.cache_key
79
+ assert_equal utc_key, est_key
80
+ end
81
+ end
82
+
83
+ def test_cache_key_format_for_existing_record_with_updated_at
84
+ dev = Developer.first
85
+ assert_equal "developers/#{dev.id}-#{dev.updated_at.utc.to_s(:nsec)}", dev.cache_key
86
+ end
87
+
88
+ def test_cache_key_format_for_existing_record_with_updated_at_and_custom_cache_timestamp_format
89
+ dev = CachedDeveloper.first
90
+ assert_equal "cached_developers/#{dev.id}-#{dev.updated_at.utc.to_s(:number)}", dev.cache_key
91
+ end
92
+
93
+ def test_cache_key_changes_when_child_touched
94
+ owner = owners(:blackbeard)
95
+ pet = pets(:parrot)
96
+
97
+ owner.update_column :updated_at, Time.current
98
+ key = owner.cache_key
99
+
100
+ assert pet.touch
101
+ assert_not_equal key, owner.reload.cache_key
102
+ end
103
+
104
+ def test_cache_key_format_for_existing_record_with_nil_updated_timestamps
105
+ dev = Developer.first
106
+ dev.update_columns(updated_at: nil, updated_on: nil)
107
+ assert_match(/\/#{dev.id}$/, dev.cache_key)
108
+ end
109
+
110
+ def test_cache_key_for_updated_on
111
+ dev = Developer.first
112
+ dev.updated_at = nil
113
+ assert_equal "developers/#{dev.id}-#{dev.updated_on.utc.to_s(:nsec)}", dev.cache_key
114
+ end
115
+
116
+ def test_cache_key_for_newer_updated_at
117
+ dev = Developer.first
118
+ dev.updated_at += 3600
119
+ assert_equal "developers/#{dev.id}-#{dev.updated_at.utc.to_s(:nsec)}", dev.cache_key
120
+ end
121
+
122
+ def test_cache_key_for_newer_updated_on
123
+ dev = Developer.first
124
+ dev.updated_on += 3600
125
+ assert_equal "developers/#{dev.id}-#{dev.updated_on.utc.to_s(:nsec)}", dev.cache_key
126
+ end
127
+
128
+ def test_cache_key_format_is_precise_enough
129
+ dev = Developer.first
130
+ key = dev.cache_key
131
+ dev.touch
132
+ assert_not_equal key, dev.cache_key
133
+ end
134
+
135
+ def test_named_timestamps_for_cache_key
136
+ owner = owners(:blackbeard)
137
+ assert_equal "owners/#{owner.id}-#{owner.happy_at.utc.to_s(:nsec)}", owner.cache_key(:updated_at, :happy_at)
138
+ end
139
+ end