ibm_db 4.0.0-x86-mingw32 → 5.0.2-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.
- checksums.yaml +5 -5
- data/MANIFEST +14 -14
- data/README +208 -208
- data/ext/Makefile +269 -0
- data/ext/Makefile.nt32 +181 -181
- data/ext/Makefile.nt32.191 +212 -212
- data/ext/extconf.rb +322 -291
- data/ext/gil_release_version +3 -0
- data/ext/ibm_db.c +11879 -11887
- data/ext/mkmf.log +110 -0
- data/ext/ruby_ibm_db.h +241 -241
- data/ext/ruby_ibm_db_cli.c +866 -866
- data/ext/ruby_ibm_db_cli.h +500 -500
- data/ext/unicode_support_version +3 -0
- data/init.rb +41 -41
- data/lib/IBM_DB.rb +27 -27
- data/lib/active_record/connection_adapters/ibm_db_adapter.rb +3533 -3452
- data/lib/active_record/connection_adapters/ibmdb_adapter.rb +5 -5
- data/lib/active_record/vendor/db2-i5-zOS.yaml +328 -328
- data/lib/mswin32/ibm_db.rb +90 -90
- data/lib/mswin32/rb2x/i386/ibm_db.so +0 -0
- data/test/active_record/connection_adapters/fake_adapter.rb +49 -49
- data/test/assets/example.log +1 -1
- data/test/assets/test.txt +1 -1
- data/test/cases/adapter_test.rb +351 -351
- data/test/cases/adapters/mysql2/active_schema_test.rb +193 -193
- data/test/cases/adapters/mysql2/bind_parameter_test.rb +50 -50
- data/test/cases/adapters/mysql2/boolean_test.rb +100 -100
- data/test/cases/adapters/mysql2/case_sensitivity_test.rb +63 -63
- data/test/cases/adapters/mysql2/charset_collation_test.rb +54 -54
- data/test/cases/adapters/mysql2/connection_test.rb +210 -210
- data/test/cases/adapters/mysql2/datetime_precision_quoting_test.rb +45 -45
- data/test/cases/adapters/mysql2/enum_test.rb +26 -26
- data/test/cases/adapters/mysql2/explain_test.rb +21 -21
- data/test/cases/adapters/mysql2/json_test.rb +195 -195
- data/test/cases/adapters/mysql2/mysql2_adapter_test.rb +83 -83
- data/test/cases/adapters/mysql2/reserved_word_test.rb +152 -152
- data/test/cases/adapters/mysql2/schema_migrations_test.rb +59 -59
- data/test/cases/adapters/mysql2/schema_test.rb +126 -126
- data/test/cases/adapters/mysql2/sp_test.rb +36 -36
- data/test/cases/adapters/mysql2/sql_types_test.rb +14 -14
- data/test/cases/adapters/mysql2/table_options_test.rb +42 -42
- data/test/cases/adapters/mysql2/unsigned_type_test.rb +66 -66
- data/test/cases/adapters/postgresql/active_schema_test.rb +98 -98
- data/test/cases/adapters/postgresql/array_test.rb +339 -339
- data/test/cases/adapters/postgresql/bit_string_test.rb +82 -82
- data/test/cases/adapters/postgresql/bytea_test.rb +134 -134
- data/test/cases/adapters/postgresql/case_insensitive_test.rb +26 -26
- data/test/cases/adapters/postgresql/change_schema_test.rb +38 -38
- data/test/cases/adapters/postgresql/cidr_test.rb +25 -25
- data/test/cases/adapters/postgresql/citext_test.rb +78 -78
- data/test/cases/adapters/postgresql/collation_test.rb +53 -53
- data/test/cases/adapters/postgresql/composite_test.rb +132 -132
- data/test/cases/adapters/postgresql/connection_test.rb +257 -257
- data/test/cases/adapters/postgresql/datatype_test.rb +92 -92
- data/test/cases/adapters/postgresql/domain_test.rb +47 -47
- data/test/cases/adapters/postgresql/enum_test.rb +91 -91
- data/test/cases/adapters/postgresql/explain_test.rb +20 -20
- data/test/cases/adapters/postgresql/extension_migration_test.rb +63 -63
- data/test/cases/adapters/postgresql/full_text_test.rb +44 -44
- data/test/cases/adapters/postgresql/geometric_test.rb +378 -378
- data/test/cases/adapters/postgresql/hstore_test.rb +382 -382
- data/test/cases/adapters/postgresql/infinity_test.rb +69 -69
- data/test/cases/adapters/postgresql/integer_test.rb +25 -25
- data/test/cases/adapters/postgresql/json_test.rb +237 -237
- data/test/cases/adapters/postgresql/ltree_test.rb +53 -53
- data/test/cases/adapters/postgresql/money_test.rb +96 -96
- data/test/cases/adapters/postgresql/network_test.rb +94 -94
- data/test/cases/adapters/postgresql/numbers_test.rb +49 -49
- data/test/cases/adapters/postgresql/postgresql_adapter_test.rb +405 -405
- data/test/cases/adapters/postgresql/prepared_statements_test.rb +22 -22
- data/test/cases/adapters/postgresql/quoting_test.rb +44 -44
- data/test/cases/adapters/postgresql/range_test.rb +343 -343
- data/test/cases/adapters/postgresql/referential_integrity_test.rb +111 -111
- data/test/cases/adapters/postgresql/rename_table_test.rb +34 -34
- data/test/cases/adapters/postgresql/schema_authorization_test.rb +119 -119
- data/test/cases/adapters/postgresql/schema_test.rb +597 -597
- data/test/cases/adapters/postgresql/serial_test.rb +154 -154
- data/test/cases/adapters/postgresql/statement_pool_test.rb +41 -41
- data/test/cases/adapters/postgresql/timestamp_test.rb +90 -90
- data/test/cases/adapters/postgresql/type_lookup_test.rb +33 -33
- data/test/cases/adapters/postgresql/utils_test.rb +62 -62
- data/test/cases/adapters/postgresql/uuid_test.rb +294 -294
- data/test/cases/adapters/postgresql/xml_test.rb +54 -54
- data/test/cases/adapters/sqlite3/collation_test.rb +53 -53
- data/test/cases/adapters/sqlite3/copy_table_test.rb +98 -98
- data/test/cases/adapters/sqlite3/explain_test.rb +21 -21
- data/test/cases/adapters/sqlite3/quoting_test.rb +101 -101
- data/test/cases/adapters/sqlite3/sqlite3_adapter_test.rb +441 -441
- data/test/cases/adapters/sqlite3/sqlite3_create_folder_test.rb +24 -24
- data/test/cases/adapters/sqlite3/statement_pool_test.rb +20 -20
- data/test/cases/aggregations_test.rb +168 -168
- data/test/cases/ar_schema_test.rb +146 -146
- data/test/cases/associations/association_scope_test.rb +16 -16
- data/test/cases/associations/belongs_to_associations_test.rb +1141 -1141
- data/test/cases/associations/bidirectional_destroy_dependencies_test.rb +41 -41
- data/test/cases/associations/callbacks_test.rb +190 -190
- data/test/cases/associations/cascaded_eager_loading_test.rb +188 -188
- data/test/cases/associations/eager_load_includes_full_sti_class_test.rb +36 -36
- data/test/cases/associations/eager_load_nested_include_test.rb +126 -126
- data/test/cases/associations/eager_singularization_test.rb +148 -148
- data/test/cases/associations/eager_test.rb +1514 -1514
- data/test/cases/associations/extension_test.rb +87 -87
- data/test/cases/associations/has_and_belongs_to_many_associations_test.rb +1004 -1004
- data/test/cases/associations/has_many_associations_test.rb +2501 -2501
- data/test/cases/associations/has_many_through_associations_test.rb +1271 -1271
- data/test/cases/associations/has_one_associations_test.rb +707 -707
- data/test/cases/associations/has_one_through_associations_test.rb +383 -383
- data/test/cases/associations/inner_join_association_test.rb +139 -139
- data/test/cases/associations/inverse_associations_test.rb +733 -733
- data/test/cases/associations/join_model_test.rb +777 -777
- data/test/cases/associations/left_outer_join_association_test.rb +88 -88
- data/test/cases/associations/nested_through_associations_test.rb +579 -579
- data/test/cases/associations/required_test.rb +102 -102
- data/test/cases/associations_test.rb +385 -385
- data/test/cases/attribute_decorators_test.rb +126 -125
- data/test/cases/attribute_methods/read_test.rb +60 -60
- data/test/cases/attribute_methods_test.rb +1009 -1009
- data/test/cases/attribute_set_test.rb +270 -270
- data/test/cases/attribute_test.rb +246 -246
- data/test/cases/attributes_test.rb +253 -253
- data/test/cases/autosave_association_test.rb +1708 -1708
- data/test/cases/base_test.rb +1713 -1713
- data/test/cases/batches_test.rb +489 -489
- data/test/cases/binary_test.rb +44 -44
- data/test/cases/bind_parameter_test.rb +110 -110
- data/test/cases/cache_key_test.rb +26 -25
- data/test/cases/calculations_test.rb +798 -798
- data/test/cases/callbacks_test.rb +636 -636
- data/test/cases/clone_test.rb +40 -40
- data/test/cases/coders/json_test.rb +15 -15
- data/test/cases/coders/yaml_column_test.rb +63 -63
- data/test/cases/collection_cache_key_test.rb +115 -115
- data/test/cases/column_alias_test.rb +17 -17
- data/test/cases/column_definition_test.rb +92 -92
- data/test/cases/comment_test.rb +145 -143
- data/test/cases/connection_adapters/adapter_leasing_test.rb +56 -56
- data/test/cases/connection_adapters/connection_handler_test.rb +160 -160
- data/test/cases/connection_adapters/connection_specification_test.rb +12 -12
- data/test/cases/connection_adapters/merge_and_resolve_default_url_config_test.rb +255 -255
- data/test/cases/connection_adapters/mysql_type_lookup_test.rb +69 -69
- data/test/cases/connection_adapters/quoting_test.rb +13 -13
- data/test/cases/connection_adapters/schema_cache_test.rb +61 -61
- data/test/cases/connection_adapters/type_lookup_test.rb +118 -118
- data/test/cases/connection_management_test.rb +112 -112
- data/test/cases/connection_pool_test.rb +521 -521
- data/test/cases/connection_specification/resolver_test.rb +131 -131
- data/test/cases/core_test.rb +112 -112
- data/test/cases/counter_cache_test.rb +214 -214
- data/test/cases/custom_locking_test.rb +17 -17
- data/test/cases/database_statements_test.rb +34 -34
- data/test/cases/date_test.rb +44 -44
- data/test/cases/date_time_precision_test.rb +107 -106
- data/test/cases/date_time_test.rb +61 -61
- data/test/cases/defaults_test.rb +219 -218
- data/test/cases/dirty_test.rb +763 -763
- data/test/cases/disconnected_test.rb +30 -30
- data/test/cases/dup_test.rb +157 -157
- data/test/cases/enum_test.rb +444 -444
- data/test/cases/errors_test.rb +16 -16
- data/test/cases/explain_subscriber_test.rb +64 -64
- data/test/cases/explain_test.rb +87 -87
- data/test/cases/finder_respond_to_test.rb +60 -60
- data/test/cases/finder_test.rb +1294 -1294
- data/test/cases/fixture_set/file_test.rb +156 -156
- data/test/cases/fixtures_test.rb +988 -988
- data/test/cases/forbidden_attributes_protection_test.rb +165 -165
- data/test/cases/habtm_destroy_order_test.rb +61 -61
- data/test/cases/helper.rb +204 -204
- data/test/cases/hot_compatibility_test.rb +142 -142
- data/test/cases/i18n_test.rb +45 -45
- data/test/cases/inheritance_test.rb +606 -606
- data/test/cases/integration_test.rb +155 -155
- data/test/cases/invalid_connection_test.rb +24 -24
- data/test/cases/invertible_migration_test.rb +387 -387
- data/test/cases/json_serialization_test.rb +311 -311
- data/test/cases/locking_test.rb +493 -493
- data/test/cases/log_subscriber_test.rb +225 -225
- data/test/cases/migration/change_schema_test.rb +458 -458
- data/test/cases/migration/change_table_test.rb +256 -256
- data/test/cases/migration/column_attributes_test.rb +176 -176
- data/test/cases/migration/column_positioning_test.rb +56 -56
- data/test/cases/migration/columns_test.rb +310 -310
- data/test/cases/migration/command_recorder_test.rb +350 -350
- data/test/cases/migration/compatibility_test.rb +118 -118
- data/test/cases/migration/create_join_table_test.rb +157 -157
- data/test/cases/migration/foreign_key_test.rb +362 -360
- data/test/cases/migration/helper.rb +39 -39
- data/test/cases/migration/index_test.rb +218 -218
- data/test/cases/migration/logger_test.rb +36 -36
- data/test/cases/migration/pending_migrations_test.rb +52 -52
- data/test/cases/migration/references_foreign_key_test.rb +221 -216
- data/test/cases/migration/references_index_test.rb +101 -101
- data/test/cases/migration/references_statements_test.rb +136 -136
- data/test/cases/migration/rename_table_test.rb +93 -93
- data/test/cases/migration_test.rb +1157 -1157
- data/test/cases/migrator_test.rb +471 -470
- data/test/cases/mixin_test.rb +68 -68
- data/test/cases/modules_test.rb +172 -172
- data/test/cases/multiparameter_attributes_test.rb +372 -372
- data/test/cases/multiple_db_test.rb +122 -122
- data/test/cases/nested_attributes_test.rb +1098 -1098
- data/test/cases/nested_attributes_with_callbacks_test.rb +144 -144
- data/test/cases/persistence_test.rb +1001 -1001
- data/test/cases/pooled_connections_test.rb +81 -81
- data/test/cases/primary_keys_test.rb +376 -376
- data/test/cases/query_cache_test.rb +446 -446
- data/test/cases/quoting_test.rb +202 -202
- data/test/cases/readonly_test.rb +119 -119
- data/test/cases/reaper_test.rb +85 -85
- data/test/cases/reflection_test.rb +509 -509
- data/test/cases/relation/delegation_test.rb +63 -63
- data/test/cases/relation/merging_test.rb +157 -157
- data/test/cases/relation/mutation_test.rb +183 -183
- data/test/cases/relation/or_test.rb +92 -92
- data/test/cases/relation/predicate_builder_test.rb +16 -16
- data/test/cases/relation/record_fetch_warning_test.rb +40 -40
- data/test/cases/relation/where_chain_test.rb +105 -105
- data/test/cases/relation/where_clause_test.rb +182 -182
- data/test/cases/relation/where_test.rb +322 -322
- data/test/cases/relation_test.rb +328 -328
- data/test/cases/relations_test.rb +2026 -2026
- data/test/cases/reload_models_test.rb +22 -22
- data/test/cases/result_test.rb +90 -90
- data/test/cases/sanitize_test.rb +176 -176
- data/test/cases/schema_dumper_test.rb +457 -457
- data/test/cases/schema_loading_test.rb +52 -52
- data/test/cases/scoping/default_scoping_test.rb +528 -528
- data/test/cases/scoping/named_scoping_test.rb +561 -561
- data/test/cases/scoping/relation_scoping_test.rb +400 -400
- data/test/cases/secure_token_test.rb +32 -32
- data/test/cases/serialization_test.rb +104 -104
- data/test/cases/serialized_attribute_test.rb +364 -364
- data/test/cases/statement_cache_test.rb +136 -136
- data/test/cases/store_test.rb +195 -195
- data/test/cases/suppressor_test.rb +63 -63
- data/test/cases/tasks/database_tasks_test.rb +462 -462
- data/test/cases/tasks/mysql_rake_test.rb +345 -345
- data/test/cases/tasks/postgresql_rake_test.rb +304 -304
- data/test/cases/tasks/sqlite_rake_test.rb +220 -220
- data/test/cases/test_case.rb +131 -131
- data/test/cases/test_fixtures_test.rb +36 -36
- data/test/cases/time_precision_test.rb +103 -102
- data/test/cases/timestamp_test.rb +501 -501
- data/test/cases/touch_later_test.rb +121 -121
- data/test/cases/transaction_callbacks_test.rb +518 -518
- data/test/cases/transaction_isolation_test.rb +106 -106
- data/test/cases/transactions_test.rb +835 -834
- data/test/cases/type/adapter_specific_registry_test.rb +133 -133
- data/test/cases/type/date_time_test.rb +14 -14
- data/test/cases/type/integer_test.rb +27 -27
- data/test/cases/type/string_test.rb +22 -22
- data/test/cases/type/type_map_test.rb +177 -177
- data/test/cases/type_test.rb +39 -39
- data/test/cases/types_test.rb +24 -24
- data/test/cases/unconnected_test.rb +33 -33
- data/test/cases/validations/absence_validation_test.rb +73 -73
- data/test/cases/validations/association_validation_test.rb +97 -97
- data/test/cases/validations/i18n_generate_message_validation_test.rb +84 -84
- data/test/cases/validations/i18n_validation_test.rb +86 -86
- data/test/cases/validations/length_validation_test.rb +79 -79
- data/test/cases/validations/presence_validation_test.rb +103 -103
- data/test/cases/validations/uniqueness_validation_test.rb +548 -548
- data/test/cases/validations_repair_helper.rb +19 -19
- data/test/cases/validations_test.rb +194 -194
- data/test/cases/view_test.rb +216 -216
- data/test/cases/yaml_serialization_test.rb +121 -121
- data/test/config.example.yml +97 -97
- data/test/config.rb +5 -5
- data/test/connections/native_ibm_db/connection.rb +44 -0
- data/test/fixtures/accounts.yml +29 -29
- data/test/fixtures/admin/accounts.yml +2 -2
- data/test/fixtures/admin/users.yml +10 -10
- data/test/fixtures/author_addresses.yml +17 -17
- data/test/fixtures/author_favorites.yml +3 -3
- data/test/fixtures/authors.yml +23 -23
- data/test/fixtures/bad_posts.yml +9 -9
- data/test/fixtures/binaries.yml +133 -133
- data/test/fixtures/books.yml +31 -31
- data/test/fixtures/bulbs.yml +5 -5
- data/test/fixtures/cars.yml +9 -9
- data/test/fixtures/categories.yml +19 -19
- data/test/fixtures/categories/special_categories.yml +9 -9
- data/test/fixtures/categories/subsubdir/arbitrary_filename.yml +4 -4
- data/test/fixtures/categories_ordered.yml +7 -7
- data/test/fixtures/categories_posts.yml +31 -31
- data/test/fixtures/categorizations.yml +23 -23
- data/test/fixtures/clubs.yml +8 -8
- data/test/fixtures/collections.yml +3 -3
- data/test/fixtures/colleges.yml +3 -3
- data/test/fixtures/comments.yml +65 -65
- data/test/fixtures/companies.yml +67 -67
- data/test/fixtures/computers.yml +10 -10
- data/test/fixtures/content.yml +3 -3
- data/test/fixtures/content_positions.yml +3 -3
- data/test/fixtures/courses.yml +8 -8
- data/test/fixtures/customers.yml +25 -25
- data/test/fixtures/dashboards.yml +6 -6
- data/test/fixtures/dead_parrots.yml +5 -5
- data/test/fixtures/developers.yml +22 -22
- data/test/fixtures/developers_projects.yml +16 -16
- data/test/fixtures/dog_lovers.yml +7 -7
- data/test/fixtures/dogs.yml +4 -4
- data/test/fixtures/doubloons.yml +3 -3
- data/test/fixtures/edges.yml +5 -5
- data/test/fixtures/entrants.yml +14 -14
- data/test/fixtures/essays.yml +6 -6
- data/test/fixtures/faces.yml +11 -11
- data/test/fixtures/fk_test_has_fk.yml +3 -3
- data/test/fixtures/fk_test_has_pk.yml +1 -1
- data/test/fixtures/friendships.yml +4 -4
- data/test/fixtures/funny_jokes.yml +10 -10
- data/test/fixtures/interests.yml +33 -33
- data/test/fixtures/items.yml +3 -3
- data/test/fixtures/jobs.yml +7 -7
- data/test/fixtures/legacy_things.yml +3 -3
- data/test/fixtures/live_parrots.yml +4 -4
- data/test/fixtures/mateys.yml +4 -4
- data/test/fixtures/member_details.yml +8 -8
- data/test/fixtures/member_types.yml +6 -6
- data/test/fixtures/members.yml +11 -11
- data/test/fixtures/memberships.yml +34 -34
- data/test/fixtures/men.yml +5 -5
- data/test/fixtures/minimalistics.yml +2 -2
- data/test/fixtures/minivans.yml +5 -5
- data/test/fixtures/mixed_case_monkeys.yml +6 -6
- data/test/fixtures/mixins.yml +29 -29
- data/test/fixtures/movies.yml +7 -7
- data/test/fixtures/naked/yml/accounts.yml +1 -1
- data/test/fixtures/naked/yml/companies.yml +1 -1
- data/test/fixtures/naked/yml/courses.yml +1 -1
- data/test/fixtures/naked/yml/parrots.yml +2 -2
- data/test/fixtures/naked/yml/trees.yml +3 -3
- data/test/fixtures/nodes.yml +29 -29
- data/test/fixtures/organizations.yml +5 -5
- data/test/fixtures/other_comments.yml +6 -6
- data/test/fixtures/other_dogs.yml +2 -2
- data/test/fixtures/other_posts.yml +7 -7
- data/test/fixtures/other_topics.yml +42 -42
- data/test/fixtures/owners.yml +9 -9
- data/test/fixtures/parrots.yml +27 -27
- data/test/fixtures/parrots_pirates.yml +7 -7
- data/test/fixtures/people.yml +24 -24
- data/test/fixtures/peoples_treasures.yml +3 -3
- data/test/fixtures/pets.yml +19 -19
- data/test/fixtures/pirates.yml +12 -15
- data/test/fixtures/posts.yml +80 -80
- data/test/fixtures/price_estimates.yml +16 -16
- data/test/fixtures/products.yml +4 -4
- data/test/fixtures/projects.yml +7 -7
- data/test/fixtures/ratings.yml +14 -14
- data/test/fixtures/readers.yml +11 -11
- data/test/fixtures/references.yml +17 -17
- data/test/fixtures/reserved_words/distinct.yml +5 -5
- data/test/fixtures/reserved_words/distinct_select.yml +11 -11
- data/test/fixtures/reserved_words/group.yml +14 -14
- data/test/fixtures/reserved_words/select.yml +8 -8
- data/test/fixtures/reserved_words/values.yml +7 -7
- data/test/fixtures/ships.yml +6 -6
- data/test/fixtures/speedometers.yml +8 -8
- data/test/fixtures/sponsors.yml +12 -12
- data/test/fixtures/string_key_objects.yml +7 -7
- data/test/fixtures/subscribers.yml +10 -10
- data/test/fixtures/subscriptions.yml +12 -12
- data/test/fixtures/taggings.yml +78 -78
- data/test/fixtures/tags.yml +11 -11
- data/test/fixtures/tasks.yml +7 -7
- data/test/fixtures/teapots.yml +3 -3
- data/test/fixtures/to_be_linked/accounts.yml +2 -2
- data/test/fixtures/to_be_linked/users.yml +10 -10
- data/test/fixtures/topics.yml +49 -49
- data/test/fixtures/toys.yml +14 -14
- data/test/fixtures/traffic_lights.yml +9 -9
- data/test/fixtures/treasures.yml +10 -10
- data/test/fixtures/trees.yml +3 -3
- data/test/fixtures/uuid_children.yml +3 -3
- data/test/fixtures/uuid_parents.yml +2 -2
- data/test/fixtures/variants.yml +4 -4
- data/test/fixtures/vegetables.yml +19 -19
- data/test/fixtures/vertices.yml +3 -3
- data/test/fixtures/warehouse_things.yml +2 -2
- data/test/fixtures/zines.yml +5 -5
- data/test/migrations/10_urban/9_add_expressions.rb +11 -11
- data/test/migrations/decimal/1_give_me_big_numbers.rb +15 -15
- data/test/migrations/magic/1_currencies_have_symbols.rb +12 -12
- data/test/migrations/missing/1000_people_have_middle_names.rb +9 -9
- data/test/migrations/missing/1_people_have_last_names.rb +9 -9
- data/test/migrations/missing/3_we_need_reminders.rb +12 -12
- data/test/migrations/missing/4_innocent_jointable.rb +12 -12
- data/test/migrations/rename/1_we_need_things.rb +11 -11
- data/test/migrations/rename/2_rename_things.rb +9 -9
- data/test/migrations/to_copy/1_people_have_hobbies.rb +9 -9
- data/test/migrations/to_copy/2_people_have_descriptions.rb +9 -9
- data/test/migrations/to_copy2/1_create_articles.rb +7 -7
- data/test/migrations/to_copy2/2_create_comments.rb +7 -7
- data/test/migrations/to_copy_with_name_collision/1_people_have_hobbies.rb +9 -9
- data/test/migrations/to_copy_with_timestamps/20090101010101_people_have_hobbies.rb +9 -9
- data/test/migrations/to_copy_with_timestamps/20090101010202_people_have_descriptions.rb +9 -9
- data/test/migrations/to_copy_with_timestamps2/20090101010101_create_articles.rb +7 -7
- data/test/migrations/to_copy_with_timestamps2/20090101010202_create_comments.rb +7 -7
- data/test/migrations/valid/1_valid_people_have_last_names.rb +9 -9
- data/test/migrations/valid/2_we_need_reminders.rb +12 -12
- data/test/migrations/valid/3_innocent_jointable.rb +12 -12
- data/test/migrations/valid_with_subdirectories/1_valid_people_have_last_names.rb +9 -9
- data/test/migrations/valid_with_subdirectories/sub/2_we_need_reminders.rb +12 -12
- data/test/migrations/valid_with_subdirectories/sub1/3_innocent_jointable.rb +12 -12
- data/test/migrations/valid_with_timestamps/20100101010101_valid_with_timestamps_people_have_last_names.rb +9 -9
- data/test/migrations/valid_with_timestamps/20100201010101_valid_with_timestamps_we_need_reminders.rb +12 -12
- data/test/migrations/valid_with_timestamps/20100301010101_valid_with_timestamps_innocent_jointable.rb +12 -12
- data/test/migrations/version_check/20131219224947_migration_version_check.rb +8 -8
- data/test/models/admin.rb +5 -5
- data/test/models/admin/account.rb +3 -3
- data/test/models/admin/user.rb +40 -40
- data/test/models/aircraft.rb +5 -5
- data/test/models/arunit2_model.rb +3 -3
- data/test/models/author.rb +209 -209
- data/test/models/auto_id.rb +4 -4
- data/test/models/autoloadable/extra_firm.rb +2 -2
- data/test/models/binary.rb +2 -2
- data/test/models/bird.rb +12 -12
- data/test/models/book.rb +23 -23
- data/test/models/boolean.rb +2 -2
- data/test/models/bulb.rb +52 -52
- data/test/models/cake_designer.rb +3 -3
- data/test/models/car.rb +29 -29
- data/test/models/carrier.rb +2 -2
- data/test/models/cat.rb +10 -10
- data/test/models/categorization.rb +19 -19
- data/test/models/category.rb +35 -35
- data/test/models/chef.rb +8 -8
- data/test/models/citation.rb +3 -3
- data/test/models/club.rb +25 -25
- data/test/models/college.rb +10 -10
- data/test/models/column.rb +3 -3
- data/test/models/column_name.rb +3 -3
- data/test/models/comment.rb +76 -76
- data/test/models/company.rb +230 -230
- data/test/models/company_in_module.rb +98 -98
- data/test/models/computer.rb +3 -3
- data/test/models/contact.rb +41 -41
- data/test/models/content.rb +40 -40
- data/test/models/contract.rb +20 -20
- data/test/models/country.rb +7 -7
- data/test/models/course.rb +6 -6
- data/test/models/customer.rb +83 -83
- data/test/models/customer_carrier.rb +14 -14
- data/test/models/dashboard.rb +3 -3
- data/test/models/default.rb +2 -2
- data/test/models/department.rb +4 -4
- data/test/models/developer.rb +274 -274
- data/test/models/dog.rb +5 -5
- data/test/models/dog_lover.rb +5 -5
- data/test/models/doubloon.rb +12 -12
- data/test/models/drink_designer.rb +3 -3
- data/test/models/edge.rb +5 -5
- data/test/models/electron.rb +5 -5
- data/test/models/engine.rb +4 -4
- data/test/models/entrant.rb +3 -3
- data/test/models/essay.rb +5 -5
- data/test/models/event.rb +3 -3
- data/test/models/eye.rb +37 -37
- data/test/models/face.rb +9 -9
- data/test/models/friendship.rb +6 -6
- data/test/models/guid.rb +2 -2
- data/test/models/guitar.rb +4 -4
- data/test/models/hotel.rb +11 -11
- data/test/models/image.rb +3 -3
- data/test/models/interest.rb +5 -5
- data/test/models/invoice.rb +4 -4
- data/test/models/item.rb +7 -7
- data/test/models/job.rb +7 -7
- data/test/models/joke.rb +7 -7
- data/test/models/keyboard.rb +3 -3
- data/test/models/legacy_thing.rb +3 -3
- data/test/models/lesson.rb +11 -11
- data/test/models/line_item.rb +3 -3
- data/test/models/liquid.rb +4 -4
- data/test/models/man.rb +11 -11
- data/test/models/matey.rb +4 -4
- data/test/models/member.rb +42 -42
- data/test/models/member_detail.rb +8 -8
- data/test/models/member_type.rb +3 -3
- data/test/models/membership.rb +35 -35
- data/test/models/mentor.rb +2 -2
- data/test/models/minimalistic.rb +2 -2
- data/test/models/minivan.rb +9 -9
- data/test/models/mixed_case_monkey.rb +3 -3
- data/test/models/mocktail_designer.rb +2 -2
- data/test/models/molecule.rb +6 -6
- data/test/models/movie.rb +5 -5
- data/test/models/node.rb +5 -5
- data/test/models/non_primary_key.rb +2 -2
- data/test/models/notification.rb +3 -3
- data/test/models/order.rb +4 -4
- data/test/models/organization.rb +14 -14
- data/test/models/other_dog.rb +5 -5
- data/test/models/owner.rb +37 -37
- data/test/models/parrot.rb +28 -28
- data/test/models/person.rb +142 -142
- data/test/models/personal_legacy_thing.rb +4 -4
- data/test/models/pet.rb +18 -18
- data/test/models/pet_treasure.rb +6 -6
- data/test/models/pirate.rb +92 -92
- data/test/models/possession.rb +3 -3
- data/test/models/post.rb +273 -273
- data/test/models/price_estimate.rb +4 -4
- data/test/models/professor.rb +5 -5
- data/test/models/project.rb +40 -40
- data/test/models/publisher.rb +2 -2
- data/test/models/publisher/article.rb +4 -4
- data/test/models/publisher/magazine.rb +3 -3
- data/test/models/rating.rb +4 -4
- data/test/models/reader.rb +23 -23
- data/test/models/recipe.rb +3 -3
- data/test/models/record.rb +2 -2
- data/test/models/reference.rb +22 -22
- data/test/models/reply.rb +61 -61
- data/test/models/ship.rb +39 -39
- data/test/models/ship_part.rb +8 -8
- data/test/models/shop.rb +17 -17
- data/test/models/shop_account.rb +6 -6
- data/test/models/speedometer.rb +6 -6
- data/test/models/sponsor.rb +7 -7
- data/test/models/string_key_object.rb +3 -3
- data/test/models/student.rb +4 -4
- data/test/models/subject.rb +16 -16
- data/test/models/subscriber.rb +8 -8
- data/test/models/subscription.rb +4 -4
- data/test/models/tag.rb +13 -13
- data/test/models/tagging.rb +13 -13
- data/test/models/task.rb +5 -5
- data/test/models/topic.rb +118 -118
- data/test/models/toy.rb +6 -6
- data/test/models/traffic_light.rb +4 -4
- data/test/models/treasure.rb +14 -14
- data/test/models/treaty.rb +7 -7
- data/test/models/tree.rb +3 -3
- data/test/models/tuning_peg.rb +4 -4
- data/test/models/tyre.rb +11 -11
- data/test/models/user.rb +14 -14
- data/test/models/uuid_child.rb +3 -3
- data/test/models/uuid_item.rb +6 -6
- data/test/models/uuid_parent.rb +3 -3
- data/test/models/vegetables.rb +24 -24
- data/test/models/vehicle.rb +6 -6
- data/test/models/vertex.rb +9 -9
- data/test/models/warehouse_thing.rb +5 -5
- data/test/models/wheel.rb +3 -3
- data/test/models/without_table.rb +3 -3
- data/test/models/zine.rb +3 -3
- data/test/schema/i5/ibm_db_specific_schema.rb +137 -0
- data/test/schema/ids/ibm_db_specific_schema.rb +140 -0
- data/test/schema/luw/ibm_db_specific_schema.rb +137 -0
- data/test/schema/mysql2_specific_schema.rb +68 -68
- data/test/schema/oracle_specific_schema.rb +40 -40
- data/test/schema/postgresql_specific_schema.rb +114 -114
- data/test/schema/schema.rb +1057 -1057
- data/test/schema/schema.rb.original +1057 -1057
- data/test/schema/sqlite_specific_schema.rb +18 -18
- data/test/schema/zOS/ibm_db_specific_schema.rb +208 -0
- data/test/support/config.rb +43 -43
- data/test/support/connection.rb +23 -23
- data/test/support/connection_helper.rb +14 -14
- data/test/support/ddl_helper.rb +8 -8
- data/test/support/schema_dumping_helper.rb +20 -20
- data/test/support/yaml_compatibility_fixtures/rails_4_1.yml +22 -22
- data/test/support/yaml_compatibility_fixtures/rails_4_2_0.yml +182 -182
- metadata +24 -13
- data/test/fixtures/author_addresses.original +0 -11
- data/test/fixtures/authors.original +0 -17
@@ -1,36 +1,36 @@
|
|
1
|
-
require 'cases/helper'
|
2
|
-
|
3
|
-
class TestFixturesTest < ActiveRecord::TestCase
|
4
|
-
setup do
|
5
|
-
@klass = Class.new
|
6
|
-
@klass.send(:include, ActiveRecord::TestFixtures)
|
7
|
-
end
|
8
|
-
|
9
|
-
def test_deprecated_use_transactional_fixtures=
|
10
|
-
assert_deprecated 'use use_transactional_tests= instead' do
|
11
|
-
@klass.use_transactional_fixtures = true
|
12
|
-
end
|
13
|
-
end
|
14
|
-
|
15
|
-
def test_use_transactional_tests_prefers_use_transactional_fixtures
|
16
|
-
ActiveSupport::Deprecation.silence do
|
17
|
-
@klass.use_transactional_fixtures = false
|
18
|
-
end
|
19
|
-
|
20
|
-
assert_equal false, @klass.use_transactional_tests
|
21
|
-
end
|
22
|
-
|
23
|
-
def test_use_transactional_tests_defaults_to_true
|
24
|
-
ActiveSupport::Deprecation.silence do
|
25
|
-
@klass.use_transactional_fixtures = nil
|
26
|
-
end
|
27
|
-
|
28
|
-
assert_equal true, @klass.use_transactional_tests
|
29
|
-
end
|
30
|
-
|
31
|
-
def test_use_transactional_tests_can_be_overridden
|
32
|
-
@klass.use_transactional_tests = "foobar"
|
33
|
-
|
34
|
-
assert_equal "foobar", @klass.use_transactional_tests
|
35
|
-
end
|
36
|
-
end
|
1
|
+
require 'cases/helper'
|
2
|
+
|
3
|
+
class TestFixturesTest < ActiveRecord::TestCase
|
4
|
+
setup do
|
5
|
+
@klass = Class.new
|
6
|
+
@klass.send(:include, ActiveRecord::TestFixtures)
|
7
|
+
end
|
8
|
+
|
9
|
+
def test_deprecated_use_transactional_fixtures=
|
10
|
+
assert_deprecated 'use use_transactional_tests= instead' do
|
11
|
+
@klass.use_transactional_fixtures = true
|
12
|
+
end
|
13
|
+
end
|
14
|
+
|
15
|
+
def test_use_transactional_tests_prefers_use_transactional_fixtures
|
16
|
+
ActiveSupport::Deprecation.silence do
|
17
|
+
@klass.use_transactional_fixtures = false
|
18
|
+
end
|
19
|
+
|
20
|
+
assert_equal false, @klass.use_transactional_tests
|
21
|
+
end
|
22
|
+
|
23
|
+
def test_use_transactional_tests_defaults_to_true
|
24
|
+
ActiveSupport::Deprecation.silence do
|
25
|
+
@klass.use_transactional_fixtures = nil
|
26
|
+
end
|
27
|
+
|
28
|
+
assert_equal true, @klass.use_transactional_tests
|
29
|
+
end
|
30
|
+
|
31
|
+
def test_use_transactional_tests_can_be_overridden
|
32
|
+
@klass.use_transactional_tests = "foobar"
|
33
|
+
|
34
|
+
assert_equal "foobar", @klass.use_transactional_tests
|
35
|
+
end
|
36
|
+
end
|
@@ -1,102 +1,103 @@
|
|
1
|
-
require 'cases/helper'
|
2
|
-
require 'support/schema_dumping_helper'
|
3
|
-
|
4
|
-
if subsecond_precision_supported?
|
5
|
-
class TimePrecisionTest < ActiveRecord::TestCase
|
6
|
-
include SchemaDumpingHelper
|
7
|
-
self.use_transactional_tests = false
|
8
|
-
|
9
|
-
class Foo < ActiveRecord::Base; end
|
10
|
-
|
11
|
-
setup do
|
12
|
-
@connection = ActiveRecord::Base.connection
|
13
|
-
Foo.reset_column_information
|
14
|
-
end
|
15
|
-
|
16
|
-
teardown do
|
17
|
-
@connection.drop_table :foos
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
@connection.
|
23
|
-
@connection.add_column :foos, :
|
24
|
-
|
25
|
-
assert_equal
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
@connection.
|
31
|
-
@connection.add_column :foos, :
|
32
|
-
|
33
|
-
|
34
|
-
|
35
|
-
|
36
|
-
|
37
|
-
assert_equal
|
38
|
-
|
39
|
-
|
40
|
-
foo.
|
41
|
-
|
42
|
-
|
43
|
-
assert_equal
|
44
|
-
|
45
|
-
|
46
|
-
|
47
|
-
|
48
|
-
|
49
|
-
t.time :
|
50
|
-
|
51
|
-
|
52
|
-
assert_nil Foo.columns_hash['
|
53
|
-
|
54
|
-
|
55
|
-
|
56
|
-
|
57
|
-
|
58
|
-
|
59
|
-
t.time :
|
60
|
-
|
61
|
-
|
62
|
-
|
63
|
-
|
64
|
-
|
65
|
-
|
66
|
-
|
67
|
-
t.time :
|
68
|
-
|
69
|
-
|
70
|
-
|
71
|
-
|
72
|
-
|
73
|
-
assert_equal
|
74
|
-
assert_equal time.to_s, foo.
|
75
|
-
assert_equal
|
76
|
-
assert_equal
|
77
|
-
|
78
|
-
|
79
|
-
|
80
|
-
|
81
|
-
|
82
|
-
t.time :
|
83
|
-
|
84
|
-
|
85
|
-
|
86
|
-
assert_match %r{t\.time\s+"
|
87
|
-
|
88
|
-
|
89
|
-
|
90
|
-
|
91
|
-
|
92
|
-
|
93
|
-
t.time :
|
94
|
-
|
95
|
-
|
96
|
-
|
97
|
-
assert_match %r{t\.time\s+"
|
98
|
-
|
99
|
-
|
100
|
-
|
101
|
-
|
102
|
-
end
|
1
|
+
require 'cases/helper'
|
2
|
+
require 'support/schema_dumping_helper'
|
3
|
+
|
4
|
+
if subsecond_precision_supported?
|
5
|
+
class TimePrecisionTest < ActiveRecord::TestCase
|
6
|
+
include SchemaDumpingHelper
|
7
|
+
self.use_transactional_tests = false
|
8
|
+
|
9
|
+
class Foo < ActiveRecord::Base; end
|
10
|
+
|
11
|
+
setup do
|
12
|
+
@connection = ActiveRecord::Base.connection
|
13
|
+
Foo.reset_column_information
|
14
|
+
end
|
15
|
+
|
16
|
+
teardown do
|
17
|
+
@connection.drop_table :foos
|
18
|
+
#, if_exists: true
|
19
|
+
end
|
20
|
+
|
21
|
+
def test_time_data_type_with_precision
|
22
|
+
@connection.create_table(:foos, force: true)
|
23
|
+
@connection.add_column :foos, :start, :time, precision: 3
|
24
|
+
@connection.add_column :foos, :finish, :time, precision: 6
|
25
|
+
assert_equal 3, Foo.columns_hash['start'].precision
|
26
|
+
assert_equal 6, Foo.columns_hash['finish'].precision
|
27
|
+
end
|
28
|
+
|
29
|
+
def test_time_precision_is_truncated_on_assignment
|
30
|
+
@connection.create_table(:foos, force: true)
|
31
|
+
@connection.add_column :foos, :start, :time, precision: 0
|
32
|
+
@connection.add_column :foos, :finish, :time, precision: 6
|
33
|
+
|
34
|
+
time = ::Time.now.change(nsec: 123456789)
|
35
|
+
foo = Foo.new(start: time, finish: time)
|
36
|
+
|
37
|
+
assert_equal 0, foo.start.nsec
|
38
|
+
assert_equal 123456000, foo.finish.nsec
|
39
|
+
|
40
|
+
foo.save!
|
41
|
+
foo.reload
|
42
|
+
|
43
|
+
assert_equal 0, foo.start.nsec
|
44
|
+
assert_equal 123456000, foo.finish.nsec
|
45
|
+
end
|
46
|
+
|
47
|
+
def test_passing_precision_to_time_does_not_set_limit
|
48
|
+
@connection.create_table(:foos, force: true) do |t|
|
49
|
+
t.time :start, precision: 3
|
50
|
+
t.time :finish, precision: 6
|
51
|
+
end
|
52
|
+
assert_nil Foo.columns_hash['start'].limit
|
53
|
+
assert_nil Foo.columns_hash['finish'].limit
|
54
|
+
end
|
55
|
+
|
56
|
+
def test_invalid_time_precision_raises_error
|
57
|
+
assert_raises ActiveRecord::ActiveRecordError do
|
58
|
+
@connection.create_table(:foos, force: true) do |t|
|
59
|
+
t.time :start, precision: 7
|
60
|
+
t.time :finish, precision: 7
|
61
|
+
end
|
62
|
+
end
|
63
|
+
end
|
64
|
+
|
65
|
+
def test_formatting_time_according_to_precision
|
66
|
+
@connection.create_table(:foos, force: true) do |t|
|
67
|
+
t.time :start, precision: 0
|
68
|
+
t.time :finish, precision: 4
|
69
|
+
end
|
70
|
+
time = ::Time.utc(2000, 1, 1, 12, 30, 0, 999999)
|
71
|
+
Foo.create!(start: time, finish: time)
|
72
|
+
assert foo = Foo.find_by(start: time)
|
73
|
+
assert_equal 1, Foo.where(finish: time).count
|
74
|
+
assert_equal time.to_s, foo.start.to_s
|
75
|
+
assert_equal time.to_s, foo.finish.to_s
|
76
|
+
assert_equal 000000, foo.start.usec
|
77
|
+
assert_equal 999900, foo.finish.usec
|
78
|
+
end
|
79
|
+
|
80
|
+
def test_schema_dump_includes_time_precision
|
81
|
+
@connection.create_table(:foos, force: true) do |t|
|
82
|
+
t.time :start, precision: 4
|
83
|
+
t.time :finish, precision: 6
|
84
|
+
end
|
85
|
+
output = dump_table_schema("foos")
|
86
|
+
assert_match %r{t\.time\s+"start",\s+precision: 4$}, output
|
87
|
+
assert_match %r{t\.time\s+"finish",\s+precision: 6$}, output
|
88
|
+
end
|
89
|
+
|
90
|
+
if current_adapter?(:PostgreSQLAdapter, :SQLServerAdapter)
|
91
|
+
def test_time_precision_with_zero_should_be_dumped
|
92
|
+
@connection.create_table(:foos, force: true) do |t|
|
93
|
+
t.time :start, precision: 0
|
94
|
+
t.time :finish, precision: 0
|
95
|
+
end
|
96
|
+
output = dump_table_schema("foos")
|
97
|
+
assert_match %r{t\.time\s+"start",\s+precision: 0$}, output
|
98
|
+
assert_match %r{t\.time\s+"finish",\s+precision: 0$}, output
|
99
|
+
end
|
100
|
+
end
|
101
|
+
|
102
|
+
end
|
103
|
+
end
|
@@ -1,501 +1,501 @@
|
|
1
|
-
require 'cases/helper'
|
2
|
-
require 'support/ddl_helper'
|
3
|
-
require 'models/developer'
|
4
|
-
require 'models/computer'
|
5
|
-
require 'models/owner'
|
6
|
-
require 'models/pet'
|
7
|
-
require 'models/toy'
|
8
|
-
require 'models/car'
|
9
|
-
require 'models/task'
|
10
|
-
|
11
|
-
class TimestampTest < ActiveRecord::TestCase
|
12
|
-
fixtures :developers, :owners, :pets, :toys, :cars, :tasks
|
13
|
-
|
14
|
-
def setup
|
15
|
-
@developer = Developer.first
|
16
|
-
@owner = Owner.first
|
17
|
-
@developer.update_columns(updated_at: Time.now.prev_month)
|
18
|
-
@previously_updated_at = @developer.updated_at
|
19
|
-
end
|
20
|
-
|
21
|
-
def test_saving_a_changed_record_updates_its_timestamp
|
22
|
-
@developer.name = "Jack Bauer"
|
23
|
-
@developer.save!
|
24
|
-
|
25
|
-
assert_not_equal @previously_updated_at, @developer.updated_at
|
26
|
-
end
|
27
|
-
|
28
|
-
def test_saving_a_unchanged_record_doesnt_update_its_timestamp
|
29
|
-
@developer.save!
|
30
|
-
|
31
|
-
assert_equal @previously_updated_at, @developer.updated_at
|
32
|
-
end
|
33
|
-
|
34
|
-
def test_touching_a_record_updates_its_timestamp
|
35
|
-
previous_salary = @developer.salary
|
36
|
-
@developer.salary = previous_salary + 10000
|
37
|
-
@developer.touch
|
38
|
-
|
39
|
-
assert_not_equal @previously_updated_at, @developer.updated_at
|
40
|
-
assert_equal previous_salary + 10000, @developer.salary
|
41
|
-
assert @developer.salary_changed?, 'developer salary should have changed'
|
42
|
-
assert @developer.changed?, 'developer should be marked as changed'
|
43
|
-
@developer.reload
|
44
|
-
assert_equal previous_salary, @developer.salary
|
45
|
-
end
|
46
|
-
|
47
|
-
def test_touching_a_record_with_default_scope_that_excludes_it_updates_its_timestamp
|
48
|
-
developer = @developer.becomes(DeveloperCalledJamis)
|
49
|
-
|
50
|
-
developer.touch
|
51
|
-
assert_not_equal @previously_updated_at, developer.updated_at
|
52
|
-
developer.reload
|
53
|
-
assert_not_equal @previously_updated_at, developer.updated_at
|
54
|
-
end
|
55
|
-
|
56
|
-
def test_saving_when_record_timestamps_is_false_doesnt_update_its_timestamp
|
57
|
-
Developer.record_timestamps = false
|
58
|
-
@developer.name = "John Smith"
|
59
|
-
@developer.save!
|
60
|
-
|
61
|
-
assert_equal @previously_updated_at, @developer.updated_at
|
62
|
-
ensure
|
63
|
-
Developer.record_timestamps = true
|
64
|
-
end
|
65
|
-
|
66
|
-
def test_saving_when_instance_record_timestamps_is_false_doesnt_update_its_timestamp
|
67
|
-
@developer.record_timestamps = false
|
68
|
-
assert Developer.record_timestamps
|
69
|
-
|
70
|
-
@developer.name = "John Smith"
|
71
|
-
@developer.save!
|
72
|
-
|
73
|
-
assert_equal @previously_updated_at, @developer.updated_at
|
74
|
-
end
|
75
|
-
|
76
|
-
def test_touching_updates_timestamp_with_given_time
|
77
|
-
previously_updated_at = @developer.updated_at
|
78
|
-
new_time = Time.utc(2015, 2, 16, 0, 0, 0)
|
79
|
-
@developer.touch(time: new_time)
|
80
|
-
|
81
|
-
assert_not_equal previously_updated_at, @developer.updated_at
|
82
|
-
assert_equal new_time, @developer.updated_at
|
83
|
-
end
|
84
|
-
|
85
|
-
def test_touching_an_attribute_updates_timestamp
|
86
|
-
previously_created_at = @developer.created_at
|
87
|
-
travel(1.second) do
|
88
|
-
@developer.touch(:created_at)
|
89
|
-
end
|
90
|
-
|
91
|
-
assert !@developer.created_at_changed? , 'created_at should not be changed'
|
92
|
-
assert !@developer.changed?, 'record should not be changed'
|
93
|
-
assert_not_equal previously_created_at, @developer.created_at
|
94
|
-
assert_not_equal @previously_updated_at, @developer.updated_at
|
95
|
-
end
|
96
|
-
|
97
|
-
def test_touching_an_attribute_updates_it
|
98
|
-
task = Task.first
|
99
|
-
previous_value = task.ending
|
100
|
-
task.touch(:ending)
|
101
|
-
|
102
|
-
now = Time.now.change(usec: 0)
|
103
|
-
|
104
|
-
assert_not_equal previous_value, task.ending
|
105
|
-
assert_in_delta now, task.ending, 1
|
106
|
-
end
|
107
|
-
|
108
|
-
def test_touching_an_attribute_updates_timestamp_with_given_time
|
109
|
-
previously_updated_at = @developer.updated_at
|
110
|
-
previously_created_at = @developer.created_at
|
111
|
-
new_time = Time.utc(2015, 2, 16, 4, 54, 0)
|
112
|
-
@developer.touch(:created_at, time: new_time)
|
113
|
-
|
114
|
-
assert_not_equal previously_created_at, @developer.created_at
|
115
|
-
assert_not_equal previously_updated_at, @developer.updated_at
|
116
|
-
assert_equal new_time, @developer.created_at
|
117
|
-
assert_equal new_time, @developer.updated_at
|
118
|
-
end
|
119
|
-
|
120
|
-
def test_touching_many_attributes_updates_them
|
121
|
-
task = Task.first
|
122
|
-
previous_starting = task.starting
|
123
|
-
previous_ending = task.ending
|
124
|
-
task.touch(:starting, :ending)
|
125
|
-
|
126
|
-
now = Time.now.change(usec: 0)
|
127
|
-
|
128
|
-
assert_not_equal previous_starting, task.starting
|
129
|
-
assert_not_equal previous_ending, task.ending
|
130
|
-
assert_in_delta now, task.starting, 1
|
131
|
-
assert_in_delta now, task.ending, 1
|
132
|
-
end
|
133
|
-
|
134
|
-
def test_touching_a_record_without_timestamps_is_unexceptional
|
135
|
-
assert_nothing_raised { Car.first.touch }
|
136
|
-
end
|
137
|
-
|
138
|
-
def test_touching_a_no_touching_object
|
139
|
-
Developer.no_touching do
|
140
|
-
assert @developer.no_touching?
|
141
|
-
assert !@owner.no_touching?
|
142
|
-
@developer.touch
|
143
|
-
end
|
144
|
-
|
145
|
-
assert !@developer.no_touching?
|
146
|
-
assert !@owner.no_touching?
|
147
|
-
assert_equal @previously_updated_at, @developer.updated_at
|
148
|
-
end
|
149
|
-
|
150
|
-
def test_touching_related_objects
|
151
|
-
@owner = Owner.first
|
152
|
-
@previously_updated_at = @owner.updated_at
|
153
|
-
|
154
|
-
Owner.no_touching do
|
155
|
-
@owner.pets.first.touch
|
156
|
-
end
|
157
|
-
|
158
|
-
assert_equal @previously_updated_at, @owner.updated_at
|
159
|
-
end
|
160
|
-
|
161
|
-
def test_global_no_touching
|
162
|
-
ActiveRecord::Base.no_touching do
|
163
|
-
assert @developer.no_touching?
|
164
|
-
assert @owner.no_touching?
|
165
|
-
@developer.touch
|
166
|
-
end
|
167
|
-
|
168
|
-
assert !@developer.no_touching?
|
169
|
-
assert !@owner.no_touching?
|
170
|
-
assert_equal @previously_updated_at, @developer.updated_at
|
171
|
-
end
|
172
|
-
|
173
|
-
def test_no_touching_threadsafe
|
174
|
-
Thread.new do
|
175
|
-
Developer.no_touching do
|
176
|
-
assert @developer.no_touching?
|
177
|
-
|
178
|
-
sleep(1)
|
179
|
-
end
|
180
|
-
end
|
181
|
-
|
182
|
-
assert !@developer.no_touching?
|
183
|
-
end
|
184
|
-
|
185
|
-
def test_no_touching_with_callbacks
|
186
|
-
klass = Class.new(ActiveRecord::Base) do
|
187
|
-
self.table_name = "developers"
|
188
|
-
|
189
|
-
attr_accessor :after_touch_called
|
190
|
-
|
191
|
-
after_touch do |user|
|
192
|
-
user.after_touch_called = true
|
193
|
-
end
|
194
|
-
end
|
195
|
-
|
196
|
-
developer = klass.first
|
197
|
-
|
198
|
-
klass.no_touching do
|
199
|
-
developer.touch
|
200
|
-
assert_not developer.after_touch_called
|
201
|
-
end
|
202
|
-
end
|
203
|
-
|
204
|
-
def test_saving_a_record_with_a_belongs_to_that_specifies_touching_the_parent_should_update_the_parent_updated_at
|
205
|
-
pet = Pet.first
|
206
|
-
owner = pet.owner
|
207
|
-
previously_owner_updated_at = owner.updated_at
|
208
|
-
|
209
|
-
travel(1.second) do
|
210
|
-
pet.name = "Fluffy the Third"
|
211
|
-
pet.save
|
212
|
-
end
|
213
|
-
|
214
|
-
assert_not_equal previously_owner_updated_at, pet.owner.updated_at
|
215
|
-
end
|
216
|
-
|
217
|
-
def test_destroying_a_record_with_a_belongs_to_that_specifies_touching_the_parent_should_update_the_parent_updated_at
|
218
|
-
pet = Pet.first
|
219
|
-
owner = pet.owner
|
220
|
-
previously_owner_updated_at = owner.updated_at
|
221
|
-
|
222
|
-
travel(1.second) do
|
223
|
-
pet.destroy
|
224
|
-
end
|
225
|
-
|
226
|
-
assert_not_equal previously_owner_updated_at, pet.owner.updated_at
|
227
|
-
end
|
228
|
-
|
229
|
-
def test_saving_a_new_record_belonging_to_invalid_parent_with_touch_should_not_raise_exception
|
230
|
-
klass = Class.new(Owner) do
|
231
|
-
def self.name; 'Owner'; end
|
232
|
-
validate { errors.add(:base, :invalid) }
|
233
|
-
end
|
234
|
-
|
235
|
-
pet = Pet.new(owner: klass.new)
|
236
|
-
pet.save!
|
237
|
-
|
238
|
-
assert pet.owner.new_record?
|
239
|
-
end
|
240
|
-
|
241
|
-
def test_saving_a_record_with_a_belongs_to_that_specifies_touching_a_specific_attribute_the_parent_should_update_that_attribute
|
242
|
-
klass = Class.new(ActiveRecord::Base) do
|
243
|
-
def self.name; 'Pet'; end
|
244
|
-
belongs_to :owner, :touch => :happy_at
|
245
|
-
end
|
246
|
-
|
247
|
-
pet = klass.first
|
248
|
-
owner = pet.owner
|
249
|
-
previously_owner_happy_at = owner.happy_at
|
250
|
-
|
251
|
-
pet.name = "Fluffy the Third"
|
252
|
-
pet.save
|
253
|
-
|
254
|
-
assert_not_equal previously_owner_happy_at, pet.owner.happy_at
|
255
|
-
end
|
256
|
-
|
257
|
-
def test_touching_a_record_with_a_belongs_to_that_uses_a_counter_cache_should_update_the_parent
|
258
|
-
klass = Class.new(ActiveRecord::Base) do
|
259
|
-
def self.name; 'Pet'; end
|
260
|
-
belongs_to :owner, :counter_cache => :use_count, :touch => true
|
261
|
-
end
|
262
|
-
|
263
|
-
pet = klass.first
|
264
|
-
owner = pet.owner
|
265
|
-
owner.update_columns(happy_at: 3.days.ago)
|
266
|
-
previously_owner_updated_at = owner.updated_at
|
267
|
-
|
268
|
-
travel(1.second) do
|
269
|
-
pet.name = "I'm a parrot"
|
270
|
-
pet.save
|
271
|
-
end
|
272
|
-
|
273
|
-
assert_not_equal previously_owner_updated_at, pet.owner.updated_at
|
274
|
-
end
|
275
|
-
|
276
|
-
def test_touching_a_record_touches_parent_record_and_grandparent_record
|
277
|
-
klass = Class.new(ActiveRecord::Base) do
|
278
|
-
def self.name; 'Toy'; end
|
279
|
-
belongs_to :pet, :touch => true
|
280
|
-
end
|
281
|
-
|
282
|
-
toy = klass.first
|
283
|
-
pet = toy.pet
|
284
|
-
owner = pet.owner
|
285
|
-
time = 3.days.ago
|
286
|
-
|
287
|
-
owner.update_columns(updated_at: time)
|
288
|
-
toy.touch
|
289
|
-
owner.reload
|
290
|
-
|
291
|
-
assert_not_equal time, owner.updated_at
|
292
|
-
end
|
293
|
-
|
294
|
-
def test_touching_a_record_touches_polymorphic_record
|
295
|
-
klass = Class.new(ActiveRecord::Base) do
|
296
|
-
def self.name; 'Toy'; end
|
297
|
-
end
|
298
|
-
|
299
|
-
wheel_klass = Class.new(ActiveRecord::Base) do
|
300
|
-
def self.name; 'Wheel'; end
|
301
|
-
belongs_to :wheelable, :polymorphic => true, :touch => true
|
302
|
-
end
|
303
|
-
|
304
|
-
toy = klass.first
|
305
|
-
time = 3.days.ago
|
306
|
-
toy.update_columns(updated_at: time)
|
307
|
-
|
308
|
-
wheel = wheel_klass.new
|
309
|
-
wheel.wheelable = toy
|
310
|
-
wheel.save
|
311
|
-
wheel.touch
|
312
|
-
|
313
|
-
assert_not_equal time, toy.updated_at
|
314
|
-
end
|
315
|
-
|
316
|
-
def test_changing_parent_of_a_record_touches_both_new_and_old_parent_record
|
317
|
-
klass = Class.new(ActiveRecord::Base) do
|
318
|
-
def self.name; 'Toy'; end
|
319
|
-
belongs_to :pet, touch: true
|
320
|
-
end
|
321
|
-
|
322
|
-
toy1 = klass.find(1)
|
323
|
-
old_pet = toy1.pet
|
324
|
-
|
325
|
-
toy2 = klass.find(2)
|
326
|
-
new_pet = toy2.pet
|
327
|
-
time = 3.days.ago.at_beginning_of_hour
|
328
|
-
|
329
|
-
old_pet.update_columns(updated_at: time)
|
330
|
-
new_pet.update_columns(updated_at: time)
|
331
|
-
|
332
|
-
toy1.pet = new_pet
|
333
|
-
toy1.save!
|
334
|
-
|
335
|
-
old_pet.reload
|
336
|
-
new_pet.reload
|
337
|
-
|
338
|
-
assert_not_equal time, new_pet.updated_at
|
339
|
-
assert_not_equal time, old_pet.updated_at
|
340
|
-
end
|
341
|
-
|
342
|
-
def test_changing_parent_of_a_record_touches_both_new_and_old_polymorphic_parent_record_changes_within_same_class
|
343
|
-
car_class = Class.new(ActiveRecord::Base) do
|
344
|
-
def self.name; 'Car'; end
|
345
|
-
end
|
346
|
-
|
347
|
-
wheel_class = Class.new(ActiveRecord::Base) do
|
348
|
-
def self.name; 'Wheel'; end
|
349
|
-
belongs_to :wheelable, :polymorphic => true, :touch => true
|
350
|
-
end
|
351
|
-
|
352
|
-
car1 = car_class.find(1)
|
353
|
-
car2 = car_class.find(2)
|
354
|
-
|
355
|
-
wheel = wheel_class.create!(wheelable: car1)
|
356
|
-
|
357
|
-
time = 3.days.ago.at_beginning_of_hour
|
358
|
-
|
359
|
-
car1.update_columns(updated_at: time)
|
360
|
-
car2.update_columns(updated_at: time)
|
361
|
-
|
362
|
-
wheel.wheelable = car2
|
363
|
-
wheel.save!
|
364
|
-
|
365
|
-
assert_not_equal time, car1.reload.updated_at
|
366
|
-
assert_not_equal time, car2.reload.updated_at
|
367
|
-
end
|
368
|
-
|
369
|
-
def test_changing_parent_of_a_record_touches_both_new_and_old_polymorphic_parent_record_changes_with_other_class
|
370
|
-
car_class = Class.new(ActiveRecord::Base) do
|
371
|
-
def self.name; 'Car'; end
|
372
|
-
end
|
373
|
-
|
374
|
-
toy_class = Class.new(ActiveRecord::Base) do
|
375
|
-
def self.name; 'Toy'; end
|
376
|
-
end
|
377
|
-
|
378
|
-
wheel_class = Class.new(ActiveRecord::Base) do
|
379
|
-
def self.name; 'Wheel'; end
|
380
|
-
belongs_to :wheelable, :polymorphic => true, :touch => true
|
381
|
-
end
|
382
|
-
|
383
|
-
car = car_class.find(1)
|
384
|
-
toy = toy_class.find(3)
|
385
|
-
|
386
|
-
wheel = wheel_class.create!(wheelable: car)
|
387
|
-
|
388
|
-
time = 3.days.ago.at_beginning_of_hour
|
389
|
-
|
390
|
-
car.update_columns(updated_at: time)
|
391
|
-
toy.update_columns(updated_at: time)
|
392
|
-
|
393
|
-
wheel.wheelable = toy
|
394
|
-
wheel.save!
|
395
|
-
|
396
|
-
assert_not_equal time, car.reload.updated_at
|
397
|
-
assert_not_equal time, toy.reload.updated_at
|
398
|
-
end
|
399
|
-
|
400
|
-
def test_clearing_association_touches_the_old_record
|
401
|
-
klass = Class.new(ActiveRecord::Base) do
|
402
|
-
def self.name; 'Toy'; end
|
403
|
-
belongs_to :pet, touch: true
|
404
|
-
end
|
405
|
-
|
406
|
-
toy = klass.find(1)
|
407
|
-
pet = toy.pet
|
408
|
-
time = 3.days.ago.at_beginning_of_hour
|
409
|
-
|
410
|
-
pet.update_columns(updated_at: time)
|
411
|
-
|
412
|
-
toy.pet = nil
|
413
|
-
toy.save!
|
414
|
-
|
415
|
-
pet.reload
|
416
|
-
|
417
|
-
assert_not_equal time, pet.updated_at
|
418
|
-
end
|
419
|
-
|
420
|
-
def test_timestamp_column_values_are_present_in_the_callbacks
|
421
|
-
klass = Class.new(ActiveRecord::Base) do
|
422
|
-
self.table_name = 'people'
|
423
|
-
|
424
|
-
before_create do
|
425
|
-
self.born_at = self.created_at
|
426
|
-
end
|
427
|
-
end
|
428
|
-
|
429
|
-
person = klass.create first_name: 'David'
|
430
|
-
assert_not_equal person.born_at, nil
|
431
|
-
end
|
432
|
-
|
433
|
-
def test_timestamp_attributes_for_create
|
434
|
-
toy = Toy.first
|
435
|
-
assert_equal [:created_at, :created_on], toy.send(:timestamp_attributes_for_create)
|
436
|
-
end
|
437
|
-
|
438
|
-
def test_timestamp_attributes_for_update
|
439
|
-
toy = Toy.first
|
440
|
-
assert_equal [:updated_at, :updated_on], toy.send(:timestamp_attributes_for_update)
|
441
|
-
end
|
442
|
-
|
443
|
-
def test_all_timestamp_attributes
|
444
|
-
toy = Toy.first
|
445
|
-
assert_equal [:created_at, :created_on, :updated_at, :updated_on], toy.send(:all_timestamp_attributes)
|
446
|
-
end
|
447
|
-
|
448
|
-
def test_timestamp_attributes_for_create_in_model
|
449
|
-
toy = Toy.first
|
450
|
-
assert_equal [:created_at], toy.send(:timestamp_attributes_for_create_in_model)
|
451
|
-
end
|
452
|
-
|
453
|
-
def test_timestamp_attributes_for_update_in_model
|
454
|
-
toy = Toy.first
|
455
|
-
assert_equal [:updated_at], toy.send(:timestamp_attributes_for_update_in_model)
|
456
|
-
end
|
457
|
-
|
458
|
-
def test_all_timestamp_attributes_in_model
|
459
|
-
toy = Toy.first
|
460
|
-
assert_equal [:created_at, :updated_at], toy.send(:all_timestamp_attributes_in_model)
|
461
|
-
end
|
462
|
-
|
463
|
-
def test_index_is_created_for_both_timestamps
|
464
|
-
ActiveRecord::Base.connection.create_table(:foos, force: true) do |t|
|
465
|
-
t.timestamps(:foos, null: true, index: true)
|
466
|
-
end
|
467
|
-
|
468
|
-
indexes = ActiveRecord::Base.connection.indexes('foos')
|
469
|
-
assert_equal ['created_at', 'updated_at'], indexes.flat_map(&:columns).sort
|
470
|
-
ensure
|
471
|
-
ActiveRecord::Base.connection.drop_table(:foos)
|
472
|
-
end
|
473
|
-
end
|
474
|
-
|
475
|
-
class TimestampsWithoutTransactionTest < ActiveRecord::TestCase
|
476
|
-
include DdlHelper
|
477
|
-
self.use_transactional_tests = false
|
478
|
-
|
479
|
-
class TimestampAttributePost < ActiveRecord::Base
|
480
|
-
attr_accessor :created_at, :updated_at
|
481
|
-
end
|
482
|
-
|
483
|
-
def test_do_not_write_timestamps_on_save_if_they_are_not_attributes
|
484
|
-
if current_adapter?(:IBM_DBAdapter)
|
485
|
-
ActiveRecord::Base.connection.create_table :timestamp_attribute_posts, force: true, id: false do |t|
|
486
|
-
t.primary_key :id
|
487
|
-
end
|
488
|
-
post = TimestampAttributePost.new(id: 1)
|
489
|
-
post.save! # should not try to assign and persist created_at, updated_at
|
490
|
-
assert_nil post.created_at
|
491
|
-
assert_nil post.updated_at
|
492
|
-
else
|
493
|
-
with_example_table ActiveRecord::Base.connection, "timestamp_attribute_posts", "id integer primary key" do
|
494
|
-
post = TimestampAttributePost.new(id: 1)
|
495
|
-
post.save! # should not try to assign and persist created_at, updated_at
|
496
|
-
assert_nil post.created_at
|
497
|
-
assert_nil post.updated_at
|
498
|
-
end
|
499
|
-
end
|
500
|
-
end
|
501
|
-
end
|
1
|
+
require 'cases/helper'
|
2
|
+
require 'support/ddl_helper'
|
3
|
+
require 'models/developer'
|
4
|
+
require 'models/computer'
|
5
|
+
require 'models/owner'
|
6
|
+
require 'models/pet'
|
7
|
+
require 'models/toy'
|
8
|
+
require 'models/car'
|
9
|
+
require 'models/task'
|
10
|
+
|
11
|
+
class TimestampTest < ActiveRecord::TestCase
|
12
|
+
fixtures :developers, :owners, :pets, :toys, :cars, :tasks
|
13
|
+
|
14
|
+
def setup
|
15
|
+
@developer = Developer.first
|
16
|
+
@owner = Owner.first
|
17
|
+
@developer.update_columns(updated_at: Time.now.prev_month)
|
18
|
+
@previously_updated_at = @developer.updated_at
|
19
|
+
end
|
20
|
+
|
21
|
+
def test_saving_a_changed_record_updates_its_timestamp
|
22
|
+
@developer.name = "Jack Bauer"
|
23
|
+
@developer.save!
|
24
|
+
|
25
|
+
assert_not_equal @previously_updated_at, @developer.updated_at
|
26
|
+
end
|
27
|
+
|
28
|
+
def test_saving_a_unchanged_record_doesnt_update_its_timestamp
|
29
|
+
@developer.save!
|
30
|
+
|
31
|
+
assert_equal @previously_updated_at, @developer.updated_at
|
32
|
+
end
|
33
|
+
|
34
|
+
def test_touching_a_record_updates_its_timestamp
|
35
|
+
previous_salary = @developer.salary
|
36
|
+
@developer.salary = previous_salary + 10000
|
37
|
+
@developer.touch
|
38
|
+
|
39
|
+
assert_not_equal @previously_updated_at, @developer.updated_at
|
40
|
+
assert_equal previous_salary + 10000, @developer.salary
|
41
|
+
assert @developer.salary_changed?, 'developer salary should have changed'
|
42
|
+
assert @developer.changed?, 'developer should be marked as changed'
|
43
|
+
@developer.reload
|
44
|
+
assert_equal previous_salary, @developer.salary
|
45
|
+
end
|
46
|
+
|
47
|
+
def test_touching_a_record_with_default_scope_that_excludes_it_updates_its_timestamp
|
48
|
+
developer = @developer.becomes(DeveloperCalledJamis)
|
49
|
+
|
50
|
+
developer.touch
|
51
|
+
assert_not_equal @previously_updated_at, developer.updated_at
|
52
|
+
developer.reload
|
53
|
+
assert_not_equal @previously_updated_at, developer.updated_at
|
54
|
+
end
|
55
|
+
|
56
|
+
def test_saving_when_record_timestamps_is_false_doesnt_update_its_timestamp
|
57
|
+
Developer.record_timestamps = false
|
58
|
+
@developer.name = "John Smith"
|
59
|
+
@developer.save!
|
60
|
+
|
61
|
+
assert_equal @previously_updated_at, @developer.updated_at
|
62
|
+
ensure
|
63
|
+
Developer.record_timestamps = true
|
64
|
+
end
|
65
|
+
|
66
|
+
def test_saving_when_instance_record_timestamps_is_false_doesnt_update_its_timestamp
|
67
|
+
@developer.record_timestamps = false
|
68
|
+
assert Developer.record_timestamps
|
69
|
+
|
70
|
+
@developer.name = "John Smith"
|
71
|
+
@developer.save!
|
72
|
+
|
73
|
+
assert_equal @previously_updated_at, @developer.updated_at
|
74
|
+
end
|
75
|
+
|
76
|
+
def test_touching_updates_timestamp_with_given_time
|
77
|
+
previously_updated_at = @developer.updated_at
|
78
|
+
new_time = Time.utc(2015, 2, 16, 0, 0, 0)
|
79
|
+
@developer.touch(time: new_time)
|
80
|
+
|
81
|
+
assert_not_equal previously_updated_at, @developer.updated_at
|
82
|
+
assert_equal new_time, @developer.updated_at
|
83
|
+
end
|
84
|
+
|
85
|
+
def test_touching_an_attribute_updates_timestamp
|
86
|
+
previously_created_at = @developer.created_at
|
87
|
+
travel(1.second) do
|
88
|
+
@developer.touch(:created_at)
|
89
|
+
end
|
90
|
+
|
91
|
+
assert !@developer.created_at_changed? , 'created_at should not be changed'
|
92
|
+
assert !@developer.changed?, 'record should not be changed'
|
93
|
+
assert_not_equal previously_created_at, @developer.created_at
|
94
|
+
assert_not_equal @previously_updated_at, @developer.updated_at
|
95
|
+
end
|
96
|
+
|
97
|
+
def test_touching_an_attribute_updates_it
|
98
|
+
task = Task.first
|
99
|
+
previous_value = task.ending
|
100
|
+
task.touch(:ending)
|
101
|
+
|
102
|
+
now = Time.now.change(usec: 0)
|
103
|
+
|
104
|
+
assert_not_equal previous_value, task.ending
|
105
|
+
assert_in_delta now, task.ending, 1
|
106
|
+
end
|
107
|
+
|
108
|
+
def test_touching_an_attribute_updates_timestamp_with_given_time
|
109
|
+
previously_updated_at = @developer.updated_at
|
110
|
+
previously_created_at = @developer.created_at
|
111
|
+
new_time = Time.utc(2015, 2, 16, 4, 54, 0)
|
112
|
+
@developer.touch(:created_at, time: new_time)
|
113
|
+
|
114
|
+
assert_not_equal previously_created_at, @developer.created_at
|
115
|
+
assert_not_equal previously_updated_at, @developer.updated_at
|
116
|
+
assert_equal new_time, @developer.created_at
|
117
|
+
assert_equal new_time, @developer.updated_at
|
118
|
+
end
|
119
|
+
|
120
|
+
def test_touching_many_attributes_updates_them
|
121
|
+
task = Task.first
|
122
|
+
previous_starting = task.starting
|
123
|
+
previous_ending = task.ending
|
124
|
+
task.touch(:starting, :ending)
|
125
|
+
|
126
|
+
now = Time.now.change(usec: 0)
|
127
|
+
|
128
|
+
assert_not_equal previous_starting, task.starting
|
129
|
+
assert_not_equal previous_ending, task.ending
|
130
|
+
assert_in_delta now, task.starting, 1
|
131
|
+
assert_in_delta now, task.ending, 1
|
132
|
+
end
|
133
|
+
|
134
|
+
def test_touching_a_record_without_timestamps_is_unexceptional
|
135
|
+
assert_nothing_raised { Car.first.touch }
|
136
|
+
end
|
137
|
+
|
138
|
+
def test_touching_a_no_touching_object
|
139
|
+
Developer.no_touching do
|
140
|
+
assert @developer.no_touching?
|
141
|
+
assert !@owner.no_touching?
|
142
|
+
@developer.touch
|
143
|
+
end
|
144
|
+
|
145
|
+
assert !@developer.no_touching?
|
146
|
+
assert !@owner.no_touching?
|
147
|
+
assert_equal @previously_updated_at, @developer.updated_at
|
148
|
+
end
|
149
|
+
|
150
|
+
def test_touching_related_objects
|
151
|
+
@owner = Owner.first
|
152
|
+
@previously_updated_at = @owner.updated_at
|
153
|
+
|
154
|
+
Owner.no_touching do
|
155
|
+
@owner.pets.first.touch
|
156
|
+
end
|
157
|
+
|
158
|
+
assert_equal @previously_updated_at, @owner.updated_at
|
159
|
+
end
|
160
|
+
|
161
|
+
def test_global_no_touching
|
162
|
+
ActiveRecord::Base.no_touching do
|
163
|
+
assert @developer.no_touching?
|
164
|
+
assert @owner.no_touching?
|
165
|
+
@developer.touch
|
166
|
+
end
|
167
|
+
|
168
|
+
assert !@developer.no_touching?
|
169
|
+
assert !@owner.no_touching?
|
170
|
+
assert_equal @previously_updated_at, @developer.updated_at
|
171
|
+
end
|
172
|
+
|
173
|
+
def test_no_touching_threadsafe
|
174
|
+
Thread.new do
|
175
|
+
Developer.no_touching do
|
176
|
+
assert @developer.no_touching?
|
177
|
+
|
178
|
+
sleep(1)
|
179
|
+
end
|
180
|
+
end
|
181
|
+
|
182
|
+
assert !@developer.no_touching?
|
183
|
+
end
|
184
|
+
|
185
|
+
def test_no_touching_with_callbacks
|
186
|
+
klass = Class.new(ActiveRecord::Base) do
|
187
|
+
self.table_name = "developers"
|
188
|
+
|
189
|
+
attr_accessor :after_touch_called
|
190
|
+
|
191
|
+
after_touch do |user|
|
192
|
+
user.after_touch_called = true
|
193
|
+
end
|
194
|
+
end
|
195
|
+
|
196
|
+
developer = klass.first
|
197
|
+
|
198
|
+
klass.no_touching do
|
199
|
+
developer.touch
|
200
|
+
assert_not developer.after_touch_called
|
201
|
+
end
|
202
|
+
end
|
203
|
+
|
204
|
+
def test_saving_a_record_with_a_belongs_to_that_specifies_touching_the_parent_should_update_the_parent_updated_at
|
205
|
+
pet = Pet.first
|
206
|
+
owner = pet.owner
|
207
|
+
previously_owner_updated_at = owner.updated_at
|
208
|
+
|
209
|
+
travel(1.second) do
|
210
|
+
pet.name = "Fluffy the Third"
|
211
|
+
pet.save
|
212
|
+
end
|
213
|
+
|
214
|
+
assert_not_equal previously_owner_updated_at, pet.owner.updated_at
|
215
|
+
end
|
216
|
+
|
217
|
+
def test_destroying_a_record_with_a_belongs_to_that_specifies_touching_the_parent_should_update_the_parent_updated_at
|
218
|
+
pet = Pet.first
|
219
|
+
owner = pet.owner
|
220
|
+
previously_owner_updated_at = owner.updated_at
|
221
|
+
|
222
|
+
travel(1.second) do
|
223
|
+
pet.destroy
|
224
|
+
end
|
225
|
+
|
226
|
+
assert_not_equal previously_owner_updated_at, pet.owner.updated_at
|
227
|
+
end
|
228
|
+
|
229
|
+
def test_saving_a_new_record_belonging_to_invalid_parent_with_touch_should_not_raise_exception
|
230
|
+
klass = Class.new(Owner) do
|
231
|
+
def self.name; 'Owner'; end
|
232
|
+
validate { errors.add(:base, :invalid) }
|
233
|
+
end
|
234
|
+
|
235
|
+
pet = Pet.new(owner: klass.new)
|
236
|
+
pet.save!
|
237
|
+
|
238
|
+
assert pet.owner.new_record?
|
239
|
+
end
|
240
|
+
|
241
|
+
def test_saving_a_record_with_a_belongs_to_that_specifies_touching_a_specific_attribute_the_parent_should_update_that_attribute
|
242
|
+
klass = Class.new(ActiveRecord::Base) do
|
243
|
+
def self.name; 'Pet'; end
|
244
|
+
belongs_to :owner, :touch => :happy_at
|
245
|
+
end
|
246
|
+
|
247
|
+
pet = klass.first
|
248
|
+
owner = pet.owner
|
249
|
+
previously_owner_happy_at = owner.happy_at
|
250
|
+
|
251
|
+
pet.name = "Fluffy the Third"
|
252
|
+
pet.save
|
253
|
+
|
254
|
+
assert_not_equal previously_owner_happy_at, pet.owner.happy_at
|
255
|
+
end
|
256
|
+
|
257
|
+
def test_touching_a_record_with_a_belongs_to_that_uses_a_counter_cache_should_update_the_parent
|
258
|
+
klass = Class.new(ActiveRecord::Base) do
|
259
|
+
def self.name; 'Pet'; end
|
260
|
+
belongs_to :owner, :counter_cache => :use_count, :touch => true
|
261
|
+
end
|
262
|
+
|
263
|
+
pet = klass.first
|
264
|
+
owner = pet.owner
|
265
|
+
owner.update_columns(happy_at: 3.days.ago)
|
266
|
+
previously_owner_updated_at = owner.updated_at
|
267
|
+
|
268
|
+
travel(1.second) do
|
269
|
+
pet.name = "I'm a parrot"
|
270
|
+
pet.save
|
271
|
+
end
|
272
|
+
|
273
|
+
assert_not_equal previously_owner_updated_at, pet.owner.updated_at
|
274
|
+
end
|
275
|
+
|
276
|
+
def test_touching_a_record_touches_parent_record_and_grandparent_record
|
277
|
+
klass = Class.new(ActiveRecord::Base) do
|
278
|
+
def self.name; 'Toy'; end
|
279
|
+
belongs_to :pet, :touch => true
|
280
|
+
end
|
281
|
+
|
282
|
+
toy = klass.first
|
283
|
+
pet = toy.pet
|
284
|
+
owner = pet.owner
|
285
|
+
time = 3.days.ago
|
286
|
+
|
287
|
+
owner.update_columns(updated_at: time)
|
288
|
+
toy.touch
|
289
|
+
owner.reload
|
290
|
+
|
291
|
+
assert_not_equal time, owner.updated_at
|
292
|
+
end
|
293
|
+
|
294
|
+
def test_touching_a_record_touches_polymorphic_record
|
295
|
+
klass = Class.new(ActiveRecord::Base) do
|
296
|
+
def self.name; 'Toy'; end
|
297
|
+
end
|
298
|
+
|
299
|
+
wheel_klass = Class.new(ActiveRecord::Base) do
|
300
|
+
def self.name; 'Wheel'; end
|
301
|
+
belongs_to :wheelable, :polymorphic => true, :touch => true
|
302
|
+
end
|
303
|
+
|
304
|
+
toy = klass.first
|
305
|
+
time = 3.days.ago
|
306
|
+
toy.update_columns(updated_at: time)
|
307
|
+
|
308
|
+
wheel = wheel_klass.new
|
309
|
+
wheel.wheelable = toy
|
310
|
+
wheel.save
|
311
|
+
wheel.touch
|
312
|
+
|
313
|
+
assert_not_equal time, toy.updated_at
|
314
|
+
end
|
315
|
+
|
316
|
+
def test_changing_parent_of_a_record_touches_both_new_and_old_parent_record
|
317
|
+
klass = Class.new(ActiveRecord::Base) do
|
318
|
+
def self.name; 'Toy'; end
|
319
|
+
belongs_to :pet, touch: true
|
320
|
+
end
|
321
|
+
|
322
|
+
toy1 = klass.find(1)
|
323
|
+
old_pet = toy1.pet
|
324
|
+
|
325
|
+
toy2 = klass.find(2)
|
326
|
+
new_pet = toy2.pet
|
327
|
+
time = 3.days.ago.at_beginning_of_hour
|
328
|
+
|
329
|
+
old_pet.update_columns(updated_at: time)
|
330
|
+
new_pet.update_columns(updated_at: time)
|
331
|
+
|
332
|
+
toy1.pet = new_pet
|
333
|
+
toy1.save!
|
334
|
+
|
335
|
+
old_pet.reload
|
336
|
+
new_pet.reload
|
337
|
+
|
338
|
+
assert_not_equal time, new_pet.updated_at
|
339
|
+
assert_not_equal time, old_pet.updated_at
|
340
|
+
end
|
341
|
+
|
342
|
+
def test_changing_parent_of_a_record_touches_both_new_and_old_polymorphic_parent_record_changes_within_same_class
|
343
|
+
car_class = Class.new(ActiveRecord::Base) do
|
344
|
+
def self.name; 'Car'; end
|
345
|
+
end
|
346
|
+
|
347
|
+
wheel_class = Class.new(ActiveRecord::Base) do
|
348
|
+
def self.name; 'Wheel'; end
|
349
|
+
belongs_to :wheelable, :polymorphic => true, :touch => true
|
350
|
+
end
|
351
|
+
|
352
|
+
car1 = car_class.find(1)
|
353
|
+
car2 = car_class.find(2)
|
354
|
+
|
355
|
+
wheel = wheel_class.create!(wheelable: car1)
|
356
|
+
|
357
|
+
time = 3.days.ago.at_beginning_of_hour
|
358
|
+
|
359
|
+
car1.update_columns(updated_at: time)
|
360
|
+
car2.update_columns(updated_at: time)
|
361
|
+
|
362
|
+
wheel.wheelable = car2
|
363
|
+
wheel.save!
|
364
|
+
|
365
|
+
assert_not_equal time, car1.reload.updated_at
|
366
|
+
assert_not_equal time, car2.reload.updated_at
|
367
|
+
end
|
368
|
+
|
369
|
+
def test_changing_parent_of_a_record_touches_both_new_and_old_polymorphic_parent_record_changes_with_other_class
|
370
|
+
car_class = Class.new(ActiveRecord::Base) do
|
371
|
+
def self.name; 'Car'; end
|
372
|
+
end
|
373
|
+
|
374
|
+
toy_class = Class.new(ActiveRecord::Base) do
|
375
|
+
def self.name; 'Toy'; end
|
376
|
+
end
|
377
|
+
|
378
|
+
wheel_class = Class.new(ActiveRecord::Base) do
|
379
|
+
def self.name; 'Wheel'; end
|
380
|
+
belongs_to :wheelable, :polymorphic => true, :touch => true
|
381
|
+
end
|
382
|
+
|
383
|
+
car = car_class.find(1)
|
384
|
+
toy = toy_class.find(3)
|
385
|
+
|
386
|
+
wheel = wheel_class.create!(wheelable: car)
|
387
|
+
|
388
|
+
time = 3.days.ago.at_beginning_of_hour
|
389
|
+
|
390
|
+
car.update_columns(updated_at: time)
|
391
|
+
toy.update_columns(updated_at: time)
|
392
|
+
|
393
|
+
wheel.wheelable = toy
|
394
|
+
wheel.save!
|
395
|
+
|
396
|
+
assert_not_equal time, car.reload.updated_at
|
397
|
+
assert_not_equal time, toy.reload.updated_at
|
398
|
+
end
|
399
|
+
|
400
|
+
def test_clearing_association_touches_the_old_record
|
401
|
+
klass = Class.new(ActiveRecord::Base) do
|
402
|
+
def self.name; 'Toy'; end
|
403
|
+
belongs_to :pet, touch: true
|
404
|
+
end
|
405
|
+
|
406
|
+
toy = klass.find(1)
|
407
|
+
pet = toy.pet
|
408
|
+
time = 3.days.ago.at_beginning_of_hour
|
409
|
+
|
410
|
+
pet.update_columns(updated_at: time)
|
411
|
+
|
412
|
+
toy.pet = nil
|
413
|
+
toy.save!
|
414
|
+
|
415
|
+
pet.reload
|
416
|
+
|
417
|
+
assert_not_equal time, pet.updated_at
|
418
|
+
end
|
419
|
+
|
420
|
+
def test_timestamp_column_values_are_present_in_the_callbacks
|
421
|
+
klass = Class.new(ActiveRecord::Base) do
|
422
|
+
self.table_name = 'people'
|
423
|
+
|
424
|
+
before_create do
|
425
|
+
self.born_at = self.created_at
|
426
|
+
end
|
427
|
+
end
|
428
|
+
|
429
|
+
person = klass.create first_name: 'David'
|
430
|
+
assert_not_equal person.born_at, nil
|
431
|
+
end
|
432
|
+
|
433
|
+
def test_timestamp_attributes_for_create
|
434
|
+
toy = Toy.first
|
435
|
+
assert_equal [:created_at, :created_on], toy.send(:timestamp_attributes_for_create)
|
436
|
+
end
|
437
|
+
|
438
|
+
def test_timestamp_attributes_for_update
|
439
|
+
toy = Toy.first
|
440
|
+
assert_equal [:updated_at, :updated_on], toy.send(:timestamp_attributes_for_update)
|
441
|
+
end
|
442
|
+
|
443
|
+
def test_all_timestamp_attributes
|
444
|
+
toy = Toy.first
|
445
|
+
assert_equal [:created_at, :created_on, :updated_at, :updated_on], toy.send(:all_timestamp_attributes)
|
446
|
+
end
|
447
|
+
|
448
|
+
def test_timestamp_attributes_for_create_in_model
|
449
|
+
toy = Toy.first
|
450
|
+
assert_equal [:created_at], toy.send(:timestamp_attributes_for_create_in_model)
|
451
|
+
end
|
452
|
+
|
453
|
+
def test_timestamp_attributes_for_update_in_model
|
454
|
+
toy = Toy.first
|
455
|
+
assert_equal [:updated_at], toy.send(:timestamp_attributes_for_update_in_model)
|
456
|
+
end
|
457
|
+
|
458
|
+
def test_all_timestamp_attributes_in_model
|
459
|
+
toy = Toy.first
|
460
|
+
assert_equal [:created_at, :updated_at], toy.send(:all_timestamp_attributes_in_model)
|
461
|
+
end
|
462
|
+
|
463
|
+
def test_index_is_created_for_both_timestamps
|
464
|
+
ActiveRecord::Base.connection.create_table(:foos, force: true) do |t|
|
465
|
+
t.timestamps(:foos, null: true, index: true)
|
466
|
+
end
|
467
|
+
|
468
|
+
indexes = ActiveRecord::Base.connection.indexes('foos')
|
469
|
+
assert_equal ['created_at', 'updated_at'], indexes.flat_map(&:columns).sort
|
470
|
+
ensure
|
471
|
+
ActiveRecord::Base.connection.drop_table(:foos)
|
472
|
+
end
|
473
|
+
end
|
474
|
+
|
475
|
+
class TimestampsWithoutTransactionTest < ActiveRecord::TestCase
|
476
|
+
include DdlHelper
|
477
|
+
self.use_transactional_tests = false
|
478
|
+
|
479
|
+
class TimestampAttributePost < ActiveRecord::Base
|
480
|
+
attr_accessor :created_at, :updated_at
|
481
|
+
end
|
482
|
+
|
483
|
+
def test_do_not_write_timestamps_on_save_if_they_are_not_attributes
|
484
|
+
if current_adapter?(:IBM_DBAdapter)
|
485
|
+
ActiveRecord::Base.connection.create_table :timestamp_attribute_posts, force: true, id: false do |t|
|
486
|
+
t.primary_key :id
|
487
|
+
end
|
488
|
+
post = TimestampAttributePost.new(id: 1)
|
489
|
+
post.save! # should not try to assign and persist created_at, updated_at
|
490
|
+
assert_nil post.created_at
|
491
|
+
assert_nil post.updated_at
|
492
|
+
else
|
493
|
+
with_example_table ActiveRecord::Base.connection, "timestamp_attribute_posts", "id integer primary key" do
|
494
|
+
post = TimestampAttributePost.new(id: 1)
|
495
|
+
post.save! # should not try to assign and persist created_at, updated_at
|
496
|
+
assert_nil post.created_at
|
497
|
+
assert_nil post.updated_at
|
498
|
+
end
|
499
|
+
end
|
500
|
+
end
|
501
|
+
end
|