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
data/lib/mswin32/ibm_db.rb
CHANGED
@@ -1,91 +1,91 @@
|
|
1
|
-
needToDownloadedCLIPackage = false
|
2
|
-
IBM_DB_HOME = ENV['IBM_DB_HOME']
|
3
|
-
cliPackagePath = File.dirname(__FILE__) + '/../clidriver'
|
4
|
-
|
5
|
-
if ((IBM_DB_HOME == nil || IBM_DB_HOME == '') && (!Dir.exists?(cliPackagePath)))
|
6
|
-
needToDownloadedCLIPackage = true
|
7
|
-
end
|
8
|
-
|
9
|
-
def downloadCLIPackage(destination, link = nil)
|
10
|
-
if(link.nil?)
|
11
|
-
downloadLink = DOWNLOADLINK
|
12
|
-
else
|
13
|
-
downloadLink = link
|
14
|
-
end
|
15
|
-
|
16
|
-
uri = URI.parse(downloadLink)
|
17
|
-
|
18
|
-
filename = "#{destination}/clidriver.zip"
|
19
|
-
|
20
|
-
headers = { 'Accept-Encoding' => 'identity', }
|
21
|
-
|
22
|
-
request = Net::HTTP::Get.new(uri.request_uri, headers)
|
23
|
-
http = Net::HTTP.new(uri.host, uri.port)
|
24
|
-
response = http.request(request)
|
25
|
-
|
26
|
-
f = open(filename, 'wb')
|
27
|
-
f.write(response.body)
|
28
|
-
f.close()
|
29
|
-
|
30
|
-
filename
|
31
|
-
end
|
32
|
-
|
33
|
-
def unzipCLIPackage(archive, destination)
|
34
|
-
if (RUBY_PLATFORM =~ /mswin/ || RUBY_PLATFORM =~ /mingw/)
|
35
|
-
Archive::Zip.extract(archive, destination)
|
36
|
-
end
|
37
|
-
end
|
38
|
-
|
39
|
-
|
40
|
-
# Download CLI package
|
41
|
-
if(needToDownloadedCLIPackage == true)
|
42
|
-
require 'net/http'
|
43
|
-
require 'open-uri'
|
44
|
-
require 'rubygems/package'
|
45
|
-
require 'fileutils'
|
46
|
-
require 'archive/zip'
|
47
|
-
|
48
|
-
TAR_LONGLINK = '././@LongLink'
|
49
|
-
|
50
|
-
machine_bits = ['ibm'].pack('p').size * 8
|
51
|
-
|
52
|
-
is64Bit = true
|
53
|
-
|
54
|
-
if machine_bits == 64
|
55
|
-
is64Bit = true
|
56
|
-
else
|
57
|
-
is64Bit = false
|
58
|
-
end
|
59
|
-
|
60
|
-
if (RUBY_PLATFORM =~ /mswin/ || RUBY_PLATFORM =~ /mingw/)
|
61
|
-
if(is64Bit)
|
62
|
-
DOWNLOADLINK = "http://public.dhe.ibm.com/ibmdl/export/pub/software/data/db2/drivers/odbc_cli/ntx64_odbc_cli.zip"
|
63
|
-
else
|
64
|
-
DOWNLOADLINK = "http://public.dhe.ibm.com/ibmdl/export/pub/software/data/db2/drivers/odbc_cli/nt32_odbc_cli.zip"
|
65
|
-
end
|
66
|
-
end
|
67
|
-
|
68
|
-
destination = "#{File.expand_path(File.dirname(File.dirname(__FILE__)))}"
|
69
|
-
archive = downloadCLIPackage(destination)
|
70
|
-
unzipCLIPackage(archive,destination)
|
71
|
-
end
|
72
|
-
|
73
|
-
|
74
|
-
if(IBM_DB_HOME !=nil && IBM_DB_HOME != '')
|
75
|
-
bin_path = IBM_DB_HOME+'/bin'
|
76
|
-
ENV['PATH'] = ENV['PATH'] + ';.;' + bin_path
|
77
|
-
end
|
78
|
-
|
79
|
-
if (RUBY_PLATFORM =~ /mswin/ || RUBY_PLATFORM =~ /mingw/)
|
80
|
-
$LOAD_PATH.unshift("#{File.dirname(__FILE__)}")
|
81
|
-
ENV['PATH'] = ENV['PATH'] + ';.;' + File.expand_path(File.dirname(__FILE__) + '/../clidriver/bin')
|
82
|
-
end
|
83
|
-
|
84
|
-
|
85
|
-
#Check if we are on 64-bit or 32-bit ruby and load binary accordingly
|
86
|
-
machine_bits = ['ibm'].pack('p').size * 8
|
87
|
-
if machine_bits == 64
|
88
|
-
raise NotImplementedError, "ibm_db with Ruby 64-bit on Windows platform is not supported. Refer to README for more details"
|
89
|
-
else
|
90
|
-
require 'rb2x/i386/ibm_db.so'
|
1
|
+
needToDownloadedCLIPackage = false
|
2
|
+
IBM_DB_HOME = ENV['IBM_DB_HOME']
|
3
|
+
cliPackagePath = File.dirname(__FILE__) + '/../clidriver'
|
4
|
+
|
5
|
+
if ((IBM_DB_HOME == nil || IBM_DB_HOME == '') && (!Dir.exists?(cliPackagePath)))
|
6
|
+
needToDownloadedCLIPackage = true
|
7
|
+
end
|
8
|
+
|
9
|
+
def downloadCLIPackage(destination, link = nil)
|
10
|
+
if(link.nil?)
|
11
|
+
downloadLink = DOWNLOADLINK
|
12
|
+
else
|
13
|
+
downloadLink = link
|
14
|
+
end
|
15
|
+
|
16
|
+
uri = URI.parse(downloadLink)
|
17
|
+
|
18
|
+
filename = "#{destination}/clidriver.zip"
|
19
|
+
|
20
|
+
headers = { 'Accept-Encoding' => 'identity', }
|
21
|
+
|
22
|
+
request = Net::HTTP::Get.new(uri.request_uri, headers)
|
23
|
+
http = Net::HTTP.new(uri.host, uri.port)
|
24
|
+
response = http.request(request)
|
25
|
+
|
26
|
+
f = open(filename, 'wb')
|
27
|
+
f.write(response.body)
|
28
|
+
f.close()
|
29
|
+
|
30
|
+
filename
|
31
|
+
end
|
32
|
+
|
33
|
+
def unzipCLIPackage(archive, destination)
|
34
|
+
if (RUBY_PLATFORM =~ /mswin/ || RUBY_PLATFORM =~ /mingw/)
|
35
|
+
Archive::Zip.extract(archive, destination)
|
36
|
+
end
|
37
|
+
end
|
38
|
+
|
39
|
+
|
40
|
+
# Download CLI package
|
41
|
+
if(needToDownloadedCLIPackage == true)
|
42
|
+
require 'net/http'
|
43
|
+
require 'open-uri'
|
44
|
+
require 'rubygems/package'
|
45
|
+
require 'fileutils'
|
46
|
+
require 'archive/zip'
|
47
|
+
|
48
|
+
TAR_LONGLINK = '././@LongLink'
|
49
|
+
|
50
|
+
machine_bits = ['ibm'].pack('p').size * 8
|
51
|
+
|
52
|
+
is64Bit = true
|
53
|
+
|
54
|
+
if machine_bits == 64
|
55
|
+
is64Bit = true
|
56
|
+
else
|
57
|
+
is64Bit = false
|
58
|
+
end
|
59
|
+
|
60
|
+
if (RUBY_PLATFORM =~ /mswin/ || RUBY_PLATFORM =~ /mingw/)
|
61
|
+
if(is64Bit)
|
62
|
+
DOWNLOADLINK = "http://public.dhe.ibm.com/ibmdl/export/pub/software/data/db2/drivers/odbc_cli/ntx64_odbc_cli.zip"
|
63
|
+
else
|
64
|
+
DOWNLOADLINK = "http://public.dhe.ibm.com/ibmdl/export/pub/software/data/db2/drivers/odbc_cli/nt32_odbc_cli.zip"
|
65
|
+
end
|
66
|
+
end
|
67
|
+
|
68
|
+
destination = "#{File.expand_path(File.dirname(File.dirname(__FILE__)))}"
|
69
|
+
archive = downloadCLIPackage(destination)
|
70
|
+
unzipCLIPackage(archive,destination)
|
71
|
+
end
|
72
|
+
|
73
|
+
|
74
|
+
if(IBM_DB_HOME !=nil && IBM_DB_HOME != '')
|
75
|
+
bin_path = IBM_DB_HOME+'/bin'
|
76
|
+
ENV['PATH'] = ENV['PATH'] + ';.;' + bin_path
|
77
|
+
end
|
78
|
+
|
79
|
+
if (RUBY_PLATFORM =~ /mswin/ || RUBY_PLATFORM =~ /mingw/)
|
80
|
+
$LOAD_PATH.unshift("#{File.dirname(__FILE__)}")
|
81
|
+
ENV['PATH'] = ENV['PATH'] + ';.;' + File.expand_path(File.dirname(__FILE__) + '/../clidriver/bin')
|
82
|
+
end
|
83
|
+
|
84
|
+
|
85
|
+
#Check if we are on 64-bit or 32-bit ruby and load binary accordingly
|
86
|
+
machine_bits = ['ibm'].pack('p').size * 8
|
87
|
+
if machine_bits == 64
|
88
|
+
raise NotImplementedError, "ibm_db with Ruby 64-bit on Windows platform is not supported. Refer to README for more details"
|
89
|
+
else
|
90
|
+
require 'rb2x/i386/ibm_db.so'
|
91
91
|
end
|
Binary file
|
@@ -1,49 +1,49 @@
|
|
1
|
-
module ActiveRecord
|
2
|
-
module ConnectionHandling
|
3
|
-
def fake_connection(config)
|
4
|
-
ConnectionAdapters::FakeAdapter.new nil, logger
|
5
|
-
end
|
6
|
-
end
|
7
|
-
|
8
|
-
module ConnectionAdapters
|
9
|
-
class FakeAdapter < AbstractAdapter
|
10
|
-
attr_accessor :data_sources, :primary_keys
|
11
|
-
|
12
|
-
@columns = Hash.new { |h,k| h[k] = [] }
|
13
|
-
class << self
|
14
|
-
attr_reader :columns
|
15
|
-
end
|
16
|
-
|
17
|
-
def initialize(connection, logger)
|
18
|
-
super
|
19
|
-
@data_sources = []
|
20
|
-
@primary_keys = {}
|
21
|
-
@columns = self.class.columns
|
22
|
-
end
|
23
|
-
|
24
|
-
def primary_key(table)
|
25
|
-
@primary_keys[table] || "id"
|
26
|
-
end
|
27
|
-
|
28
|
-
def merge_column(table_name, name, sql_type = nil, options = {})
|
29
|
-
@columns[table_name] << ActiveRecord::ConnectionAdapters::Column.new(
|
30
|
-
name.to_s,
|
31
|
-
options[:default],
|
32
|
-
fetch_type_metadata(sql_type),
|
33
|
-
options[:null])
|
34
|
-
end
|
35
|
-
|
36
|
-
def columns(table_name)
|
37
|
-
@columns[table_name]
|
38
|
-
end
|
39
|
-
|
40
|
-
def data_source_exists?(*)
|
41
|
-
true
|
42
|
-
end
|
43
|
-
|
44
|
-
def active?
|
45
|
-
true
|
46
|
-
end
|
47
|
-
end
|
48
|
-
end
|
49
|
-
end
|
1
|
+
module ActiveRecord
|
2
|
+
module ConnectionHandling
|
3
|
+
def fake_connection(config)
|
4
|
+
ConnectionAdapters::FakeAdapter.new nil, logger
|
5
|
+
end
|
6
|
+
end
|
7
|
+
|
8
|
+
module ConnectionAdapters
|
9
|
+
class FakeAdapter < AbstractAdapter
|
10
|
+
attr_accessor :data_sources, :primary_keys
|
11
|
+
|
12
|
+
@columns = Hash.new { |h,k| h[k] = [] }
|
13
|
+
class << self
|
14
|
+
attr_reader :columns
|
15
|
+
end
|
16
|
+
|
17
|
+
def initialize(connection, logger)
|
18
|
+
super
|
19
|
+
@data_sources = []
|
20
|
+
@primary_keys = {}
|
21
|
+
@columns = self.class.columns
|
22
|
+
end
|
23
|
+
|
24
|
+
def primary_key(table)
|
25
|
+
@primary_keys[table] || "id"
|
26
|
+
end
|
27
|
+
|
28
|
+
def merge_column(table_name, name, sql_type = nil, options = {})
|
29
|
+
@columns[table_name] << ActiveRecord::ConnectionAdapters::Column.new(
|
30
|
+
name.to_s,
|
31
|
+
options[:default],
|
32
|
+
fetch_type_metadata(sql_type),
|
33
|
+
options[:null])
|
34
|
+
end
|
35
|
+
|
36
|
+
def columns(table_name)
|
37
|
+
@columns[table_name]
|
38
|
+
end
|
39
|
+
|
40
|
+
def data_source_exists?(*)
|
41
|
+
true
|
42
|
+
end
|
43
|
+
|
44
|
+
def active?
|
45
|
+
true
|
46
|
+
end
|
47
|
+
end
|
48
|
+
end
|
49
|
+
end
|
data/test/assets/example.log
CHANGED
@@ -1 +1 @@
|
|
1
|
-
# Logfile created on Wed Oct 31 16:05:13 +0000 2007 by logger.rb/1.5.2.9
|
1
|
+
# Logfile created on Wed Oct 31 16:05:13 +0000 2007 by logger.rb/1.5.2.9
|
data/test/assets/test.txt
CHANGED
@@ -1 +1 @@
|
|
1
|
-
%00
|
1
|
+
%00
|
data/test/cases/adapter_test.rb
CHANGED
@@ -1,351 +1,351 @@
|
|
1
|
-
require "cases/helper"
|
2
|
-
require "models/book"
|
3
|
-
require "models/post"
|
4
|
-
require "models/author"
|
5
|
-
require "models/event"
|
6
|
-
|
7
|
-
module ActiveRecord
|
8
|
-
class AdapterTest < ActiveRecord::TestCase
|
9
|
-
def setup
|
10
|
-
@connection = ActiveRecord::Base.connection
|
11
|
-
end
|
12
|
-
|
13
|
-
##
|
14
|
-
# PostgreSQL does not support null bytes in strings
|
15
|
-
unless current_adapter?(:PostgreSQLAdapter, :IBM_DBAdapter) ||
|
16
|
-
(current_adapter?(:SQLite3Adapter) && !ActiveRecord::Base.connection.prepared_statements)
|
17
|
-
def test_update_prepared_statement
|
18
|
-
b = Book.create(name: "my \x00 book")
|
19
|
-
b.reload
|
20
|
-
assert_equal "my \x00 book", b.name
|
21
|
-
b.update_attributes(name: "my other \x00 book")
|
22
|
-
b.reload
|
23
|
-
assert_equal "my other \x00 book", b.name
|
24
|
-
end
|
25
|
-
end
|
26
|
-
|
27
|
-
unless current_adapter?(:IBM_DBAdapter)
|
28
|
-
def test_create_record_with_pk_as_zero
|
29
|
-
Book.create(id: 0)
|
30
|
-
assert_equal 0, Book.find(0).id
|
31
|
-
assert_nothing_raised { Book.destroy(0) }
|
32
|
-
end
|
33
|
-
end
|
34
|
-
|
35
|
-
def test_tables
|
36
|
-
tables = nil
|
37
|
-
ActiveSupport::Deprecation.silence { tables = @connection.tables }
|
38
|
-
assert tables.include?("accounts")
|
39
|
-
assert tables.include?("authors")
|
40
|
-
assert tables.include?("tasks")
|
41
|
-
assert tables.include?("topics")
|
42
|
-
end
|
43
|
-
|
44
|
-
|
45
|
-
def test_table_exists?
|
46
|
-
ActiveSupport::Deprecation.silence do
|
47
|
-
assert @connection.table_exists?("accounts")
|
48
|
-
assert !@connection.table_exists?("nonexistingtable")
|
49
|
-
assert !@connection.table_exists?(nil)
|
50
|
-
end
|
51
|
-
end
|
52
|
-
|
53
|
-
def test_table_exists_checking_both_tables_and_views_is_deprecated
|
54
|
-
assert_deprecated { @connection.table_exists?("accounts") }
|
55
|
-
end
|
56
|
-
|
57
|
-
def test_data_sources
|
58
|
-
data_sources = @connection.data_sources
|
59
|
-
assert data_sources.include?("accounts")
|
60
|
-
assert data_sources.include?("authors")
|
61
|
-
assert data_sources.include?("tasks")
|
62
|
-
assert data_sources.include?("topics")
|
63
|
-
end
|
64
|
-
|
65
|
-
def test_data_source_exists?
|
66
|
-
assert @connection.data_source_exists?("accounts")
|
67
|
-
assert @connection.data_source_exists?(:accounts)
|
68
|
-
assert_not @connection.data_source_exists?("nonexistingtable")
|
69
|
-
assert_not @connection.data_source_exists?(nil)
|
70
|
-
end
|
71
|
-
|
72
|
-
def test_indexes
|
73
|
-
idx_name = "accounts_idx"
|
74
|
-
|
75
|
-
if @connection.respond_to?(:indexes)
|
76
|
-
indexes = @connection.indexes("accounts")
|
77
|
-
assert indexes.empty?
|
78
|
-
|
79
|
-
@connection.add_index :accounts, :firm_id, :name => idx_name
|
80
|
-
indexes = @connection.indexes("accounts")
|
81
|
-
assert_equal "accounts", indexes.first.table
|
82
|
-
assert_equal idx_name, indexes.first.name
|
83
|
-
assert !indexes.first.unique
|
84
|
-
assert_equal ["firm_id"], indexes.first.columns
|
85
|
-
else
|
86
|
-
warn "#{@connection.class} does not respond to #indexes"
|
87
|
-
end
|
88
|
-
|
89
|
-
ensure
|
90
|
-
@connection.remove_index(:accounts, :name => idx_name) rescue nil
|
91
|
-
end
|
92
|
-
|
93
|
-
unless current_adapter?(:IBM_DBAdapter)
|
94
|
-
def test_remove_index_when_name_and_wrong_column_name_specified
|
95
|
-
index_name = "accounts_idx"
|
96
|
-
|
97
|
-
@connection.add_index :accounts, :firm_id, :name => index_name
|
98
|
-
assert_raises ArgumentError do
|
99
|
-
@connection.remove_index :accounts, :name => index_name, :column => :wrong_column_name
|
100
|
-
end
|
101
|
-
ensure
|
102
|
-
@connection.remove_index(:accounts, :name => index_name)
|
103
|
-
end
|
104
|
-
end
|
105
|
-
|
106
|
-
def test_current_database
|
107
|
-
if @connection.respond_to?(:current_database)
|
108
|
-
assert_equal ARTest.connection_config['arunit']['database'], @connection.current_database
|
109
|
-
end
|
110
|
-
end
|
111
|
-
|
112
|
-
if current_adapter?(:Mysql2Adapter)
|
113
|
-
def test_charset
|
114
|
-
assert_not_nil @connection.charset
|
115
|
-
assert_not_equal 'character_set_database', @connection.charset
|
116
|
-
assert_equal @connection.show_variable('character_set_database'), @connection.charset
|
117
|
-
end
|
118
|
-
|
119
|
-
def test_collation
|
120
|
-
assert_not_nil @connection.collation
|
121
|
-
assert_not_equal 'collation_database', @connection.collation
|
122
|
-
assert_equal @connection.show_variable('collation_database'), @connection.collation
|
123
|
-
end
|
124
|
-
|
125
|
-
def test_show_nonexistent_variable_returns_nil
|
126
|
-
assert_nil @connection.show_variable('foo_bar_baz')
|
127
|
-
end
|
128
|
-
|
129
|
-
def test_not_specifying_database_name_for_cross_database_selects
|
130
|
-
begin
|
131
|
-
assert_nothing_raised do
|
132
|
-
ActiveRecord::Base.establish_connection(ActiveRecord::Base.configurations['arunit'].except(:database))
|
133
|
-
|
134
|
-
config = ARTest.connection_config
|
135
|
-
ActiveRecord::Base.connection.execute(
|
136
|
-
"SELECT #{config['arunit']['database']}.pirates.*, #{config['arunit2']['database']}.courses.* " \
|
137
|
-
"FROM #{config['arunit']['database']}.pirates, #{config['arunit2']['database']}.courses"
|
138
|
-
)
|
139
|
-
end
|
140
|
-
ensure
|
141
|
-
ActiveRecord::Base.establish_connection :arunit
|
142
|
-
end
|
143
|
-
end
|
144
|
-
end
|
145
|
-
|
146
|
-
def test_table_alias
|
147
|
-
def @connection.test_table_alias_length() 10; end
|
148
|
-
class << @connection
|
149
|
-
alias_method :old_table_alias_length, :table_alias_length
|
150
|
-
alias_method :table_alias_length, :test_table_alias_length
|
151
|
-
end
|
152
|
-
|
153
|
-
assert_equal 'posts', @connection.table_alias_for('posts')
|
154
|
-
assert_equal 'posts_comm', @connection.table_alias_for('posts_comments')
|
155
|
-
assert_equal 'dbo_posts', @connection.table_alias_for('dbo.posts')
|
156
|
-
|
157
|
-
class << @connection
|
158
|
-
remove_method :table_alias_length
|
159
|
-
alias_method :table_alias_length, :old_table_alias_length
|
160
|
-
end
|
161
|
-
end
|
162
|
-
|
163
|
-
# test resetting sequences in odd tables in PostgreSQL
|
164
|
-
if ActiveRecord::Base.connection.respond_to?(:reset_pk_sequence!)
|
165
|
-
require 'models/movie'
|
166
|
-
require 'models/subscriber'
|
167
|
-
|
168
|
-
def test_reset_empty_table_with_custom_pk
|
169
|
-
Movie.delete_all
|
170
|
-
Movie.connection.reset_pk_sequence! 'movies'
|
171
|
-
assert_equal 1, Movie.create(:name => 'fight club').id
|
172
|
-
end
|
173
|
-
|
174
|
-
def test_reset_table_with_non_integer_pk
|
175
|
-
Subscriber.delete_all
|
176
|
-
Subscriber.connection.reset_pk_sequence! 'subscribers'
|
177
|
-
sub = Subscriber.new(:name => 'robert drake')
|
178
|
-
sub.id = 'bob drake'
|
179
|
-
assert_nothing_raised { sub.save! }
|
180
|
-
end
|
181
|
-
end
|
182
|
-
|
183
|
-
unless current_adapter?(:IBM_DBAdapter)
|
184
|
-
def test_uniqueness_violations_are_translated_to_specific_exception
|
185
|
-
@connection.execute "INSERT INTO subscribers(nick) VALUES('me')"
|
186
|
-
error = assert_raises(ActiveRecord::RecordNotUnique) do
|
187
|
-
@connection.execute "INSERT INTO subscribers(nick) VALUES('me')"
|
188
|
-
end
|
189
|
-
|
190
|
-
assert_not_nil error.cause
|
191
|
-
end
|
192
|
-
end
|
193
|
-
|
194
|
-
unless current_adapter?(:SQLite3Adapter, :IBM_DBAdapter)
|
195
|
-
def test_foreign_key_violations_are_translated_to_specific_exception
|
196
|
-
error = assert_raises(ActiveRecord::InvalidForeignKey) do
|
197
|
-
# Oracle adapter uses prefetched primary key values from sequence and passes them to connection adapter insert method
|
198
|
-
if @connection.prefetch_primary_key?
|
199
|
-
id_value = @connection.next_sequence_value(@connection.default_sequence_name("fk_test_has_fk", "id"))
|
200
|
-
@connection.execute "INSERT INTO fk_test_has_fk (id, fk_id) VALUES (#{id_value},0)"
|
201
|
-
else
|
202
|
-
@connection.execute "INSERT INTO fk_test_has_fk (fk_id) VALUES (0)"
|
203
|
-
end
|
204
|
-
end
|
205
|
-
|
206
|
-
assert_not_nil error.cause
|
207
|
-
end
|
208
|
-
|
209
|
-
def test_foreign_key_violations_are_translated_to_specific_exception_with_validate_false
|
210
|
-
klass_has_fk = Class.new(ActiveRecord::Base) do
|
211
|
-
self.table_name = 'fk_test_has_fk'
|
212
|
-
end
|
213
|
-
|
214
|
-
error = assert_raises(ActiveRecord::InvalidForeignKey) do
|
215
|
-
has_fk = klass_has_fk.new
|
216
|
-
has_fk.fk_id = 1231231231
|
217
|
-
has_fk.save(validate: false)
|
218
|
-
end
|
219
|
-
|
220
|
-
assert_not_nil error.cause
|
221
|
-
end
|
222
|
-
|
223
|
-
def test_value_limit_violations_are_translated_to_specific_exception
|
224
|
-
error = assert_raises(ActiveRecord::ValueTooLong) do
|
225
|
-
Event.create(title: 'abcdefgh')
|
226
|
-
end
|
227
|
-
|
228
|
-
assert_not_nil error.cause
|
229
|
-
end
|
230
|
-
end
|
231
|
-
|
232
|
-
def test_disable_referential_integrity
|
233
|
-
assert_nothing_raised do
|
234
|
-
@connection.disable_referential_integrity do
|
235
|
-
# Oracle adapter uses prefetched primary key values from sequence and passes them to connection adapter insert method
|
236
|
-
if @connection.prefetch_primary_key?
|
237
|
-
id_value = @connection.next_sequence_value(@connection.default_sequence_name("fk_test_has_fk", "id"))
|
238
|
-
@connection.execute "INSERT INTO fk_test_has_fk (id, fk_id) VALUES (#{id_value},0)"
|
239
|
-
else
|
240
|
-
@connection.execute "INSERT INTO fk_test_has_fk (fk_id) VALUES (0)"
|
241
|
-
end
|
242
|
-
# should delete created record as otherwise disable_referential_integrity will try to enable constraints after executed block
|
243
|
-
# and will fail (at least on Oracle)
|
244
|
-
@connection.execute "DELETE FROM fk_test_has_fk"
|
245
|
-
end
|
246
|
-
end
|
247
|
-
end
|
248
|
-
|
249
|
-
def test_select_all_always_return_activerecord_result
|
250
|
-
result = @connection.select_all "SELECT * FROM posts"
|
251
|
-
assert result.is_a?(ActiveRecord::Result)
|
252
|
-
end
|
253
|
-
|
254
|
-
if ActiveRecord::Base.connection.prepared_statements
|
255
|
-
def test_select_all_with_legacy_binds
|
256
|
-
post = Post.create!(title: "foo", body: "bar")
|
257
|
-
expected = @connection.select_all("SELECT * FROM posts WHERE id = #{post.id}")
|
258
|
-
result = @connection.select_all("SELECT * FROM posts WHERE id = #{Arel::Nodes::BindParam.new.to_sql}", nil, [[nil, post.id]])
|
259
|
-
assert_equal expected.to_hash, result.to_hash
|
260
|
-
end
|
261
|
-
end
|
262
|
-
|
263
|
-
unless current_adapter?(:IBM_DBAdapter)
|
264
|
-
def test_select_methods_passing_a_association_relation
|
265
|
-
author = Author.create!(name: 'john')
|
266
|
-
Post.create!(author: author, title: 'foo', body: 'bar')
|
267
|
-
query = author.posts.where(title: 'foo').select(:title)
|
268
|
-
assert_equal({"title" => "foo"}, @connection.select_one(query.arel, nil, query.bound_attributes))
|
269
|
-
assert_equal({"title" => "foo"}, @connection.select_one(query))
|
270
|
-
assert @connection.select_all(query).is_a?(ActiveRecord::Result)
|
271
|
-
assert_equal "foo", @connection.select_value(query)
|
272
|
-
assert_equal ["foo"], @connection.select_values(query)
|
273
|
-
end
|
274
|
-
end
|
275
|
-
|
276
|
-
unless current_adapter?(:IBM_DBAdapter)
|
277
|
-
def test_select_methods_passing_a_relation
|
278
|
-
Post.create!(title: 'foo', body: 'bar')
|
279
|
-
query = Post.where(title: 'foo').select(:title)
|
280
|
-
assert_equal({"title" => "foo"}, @connection.select_one(query.arel, nil, query.bound_attributes))
|
281
|
-
assert_equal({"title" => "foo"}, @connection.select_one(query))
|
282
|
-
assert @connection.select_all(query).is_a?(ActiveRecord::Result)
|
283
|
-
assert_equal "foo", @connection.select_value(query)
|
284
|
-
assert_equal ["foo"], @connection.select_values(query)
|
285
|
-
end
|
286
|
-
end
|
287
|
-
|
288
|
-
test "type_to_sql returns a String for unmapped types" do
|
289
|
-
assert_equal "special_db_type", @connection.type_to_sql(:special_db_type)
|
290
|
-
end
|
291
|
-
|
292
|
-
unless current_adapter?(:PostgreSQLAdapter, :IBM_DBAdapter)
|
293
|
-
def test_log_invalid_encoding
|
294
|
-
error = assert_raise ActiveRecord::StatementInvalid do
|
295
|
-
@connection.send :log, "SELECT 'ы' FROM DUAL" do
|
296
|
-
raise 'ы'.force_encoding(Encoding::ASCII_8BIT)
|
297
|
-
end
|
298
|
-
end
|
299
|
-
|
300
|
-
assert_not_nil error.cause
|
301
|
-
end
|
302
|
-
end
|
303
|
-
|
304
|
-
if current_adapter?(:Mysql2Adapter, :SQLite3Adapter)
|
305
|
-
def test_tables_returning_both_tables_and_views_is_deprecated
|
306
|
-
assert_deprecated { @connection.tables }
|
307
|
-
end
|
308
|
-
end
|
309
|
-
|
310
|
-
def test_passing_arguments_to_tables_is_deprecated
|
311
|
-
assert_deprecated { @connection.tables(:books) }
|
312
|
-
end
|
313
|
-
end
|
314
|
-
|
315
|
-
class AdapterTestWithoutTransaction < ActiveRecord::TestCase
|
316
|
-
self.use_transactional_tests = false
|
317
|
-
|
318
|
-
class Klass < ActiveRecord::Base
|
319
|
-
end
|
320
|
-
|
321
|
-
def setup
|
322
|
-
Klass.establish_connection :arunit
|
323
|
-
@connection = Klass.connection
|
324
|
-
end
|
325
|
-
|
326
|
-
teardown do
|
327
|
-
Klass.remove_connection
|
328
|
-
end
|
329
|
-
|
330
|
-
unless current_adapter?(:IBM_DBAdapter)
|
331
|
-
unless in_memory_db?
|
332
|
-
test "transaction state is reset after a reconnect" do
|
333
|
-
@connection.begin_transaction
|
334
|
-
assert @connection.transaction_open?
|
335
|
-
@connection.reconnect!
|
336
|
-
assert !@connection.transaction_open?
|
337
|
-
end
|
338
|
-
|
339
|
-
test "transaction state is reset after a disconnect" do
|
340
|
-
@connection.begin_transaction
|
341
|
-
assert @connection.transaction_open?
|
342
|
-
@connection.disconnect!
|
343
|
-
assert !@connection.transaction_open?
|
344
|
-
end
|
345
|
-
end
|
346
|
-
end
|
347
|
-
|
348
|
-
end
|
349
|
-
|
350
|
-
|
351
|
-
end
|
1
|
+
require "cases/helper"
|
2
|
+
require "models/book"
|
3
|
+
require "models/post"
|
4
|
+
require "models/author"
|
5
|
+
require "models/event"
|
6
|
+
|
7
|
+
module ActiveRecord
|
8
|
+
class AdapterTest < ActiveRecord::TestCase
|
9
|
+
def setup
|
10
|
+
@connection = ActiveRecord::Base.connection
|
11
|
+
end
|
12
|
+
|
13
|
+
##
|
14
|
+
# PostgreSQL does not support null bytes in strings
|
15
|
+
unless current_adapter?(:PostgreSQLAdapter, :IBM_DBAdapter) ||
|
16
|
+
(current_adapter?(:SQLite3Adapter) && !ActiveRecord::Base.connection.prepared_statements)
|
17
|
+
def test_update_prepared_statement
|
18
|
+
b = Book.create(name: "my \x00 book")
|
19
|
+
b.reload
|
20
|
+
assert_equal "my \x00 book", b.name
|
21
|
+
b.update_attributes(name: "my other \x00 book")
|
22
|
+
b.reload
|
23
|
+
assert_equal "my other \x00 book", b.name
|
24
|
+
end
|
25
|
+
end
|
26
|
+
|
27
|
+
unless current_adapter?(:IBM_DBAdapter)
|
28
|
+
def test_create_record_with_pk_as_zero
|
29
|
+
Book.create(id: 0)
|
30
|
+
assert_equal 0, Book.find(0).id
|
31
|
+
assert_nothing_raised { Book.destroy(0) }
|
32
|
+
end
|
33
|
+
end
|
34
|
+
|
35
|
+
def test_tables
|
36
|
+
tables = nil
|
37
|
+
ActiveSupport::Deprecation.silence { tables = @connection.tables }
|
38
|
+
assert tables.include?("accounts")
|
39
|
+
assert tables.include?("authors")
|
40
|
+
assert tables.include?("tasks")
|
41
|
+
assert tables.include?("topics")
|
42
|
+
end
|
43
|
+
|
44
|
+
|
45
|
+
def test_table_exists?
|
46
|
+
ActiveSupport::Deprecation.silence do
|
47
|
+
assert @connection.table_exists?("accounts")
|
48
|
+
assert !@connection.table_exists?("nonexistingtable")
|
49
|
+
assert !@connection.table_exists?(nil)
|
50
|
+
end
|
51
|
+
end
|
52
|
+
|
53
|
+
def test_table_exists_checking_both_tables_and_views_is_deprecated
|
54
|
+
assert_deprecated { @connection.table_exists?("accounts") }
|
55
|
+
end
|
56
|
+
|
57
|
+
def test_data_sources
|
58
|
+
data_sources = @connection.data_sources
|
59
|
+
assert data_sources.include?("accounts")
|
60
|
+
assert data_sources.include?("authors")
|
61
|
+
assert data_sources.include?("tasks")
|
62
|
+
assert data_sources.include?("topics")
|
63
|
+
end
|
64
|
+
|
65
|
+
def test_data_source_exists?
|
66
|
+
assert @connection.data_source_exists?("accounts")
|
67
|
+
assert @connection.data_source_exists?(:accounts)
|
68
|
+
assert_not @connection.data_source_exists?("nonexistingtable")
|
69
|
+
assert_not @connection.data_source_exists?(nil)
|
70
|
+
end
|
71
|
+
|
72
|
+
def test_indexes
|
73
|
+
idx_name = "accounts_idx"
|
74
|
+
|
75
|
+
if @connection.respond_to?(:indexes)
|
76
|
+
indexes = @connection.indexes("accounts")
|
77
|
+
assert indexes.empty?
|
78
|
+
|
79
|
+
@connection.add_index :accounts, :firm_id, :name => idx_name
|
80
|
+
indexes = @connection.indexes("accounts")
|
81
|
+
assert_equal "accounts", indexes.first.table
|
82
|
+
assert_equal idx_name, indexes.first.name
|
83
|
+
assert !indexes.first.unique
|
84
|
+
assert_equal ["firm_id"], indexes.first.columns
|
85
|
+
else
|
86
|
+
warn "#{@connection.class} does not respond to #indexes"
|
87
|
+
end
|
88
|
+
|
89
|
+
ensure
|
90
|
+
@connection.remove_index(:accounts, :name => idx_name) rescue nil
|
91
|
+
end
|
92
|
+
|
93
|
+
unless current_adapter?(:IBM_DBAdapter)
|
94
|
+
def test_remove_index_when_name_and_wrong_column_name_specified
|
95
|
+
index_name = "accounts_idx"
|
96
|
+
|
97
|
+
@connection.add_index :accounts, :firm_id, :name => index_name
|
98
|
+
assert_raises ArgumentError do
|
99
|
+
@connection.remove_index :accounts, :name => index_name, :column => :wrong_column_name
|
100
|
+
end
|
101
|
+
ensure
|
102
|
+
@connection.remove_index(:accounts, :name => index_name)
|
103
|
+
end
|
104
|
+
end
|
105
|
+
|
106
|
+
def test_current_database
|
107
|
+
if @connection.respond_to?(:current_database)
|
108
|
+
assert_equal ARTest.connection_config['arunit']['database'], @connection.current_database
|
109
|
+
end
|
110
|
+
end
|
111
|
+
|
112
|
+
if current_adapter?(:Mysql2Adapter)
|
113
|
+
def test_charset
|
114
|
+
assert_not_nil @connection.charset
|
115
|
+
assert_not_equal 'character_set_database', @connection.charset
|
116
|
+
assert_equal @connection.show_variable('character_set_database'), @connection.charset
|
117
|
+
end
|
118
|
+
|
119
|
+
def test_collation
|
120
|
+
assert_not_nil @connection.collation
|
121
|
+
assert_not_equal 'collation_database', @connection.collation
|
122
|
+
assert_equal @connection.show_variable('collation_database'), @connection.collation
|
123
|
+
end
|
124
|
+
|
125
|
+
def test_show_nonexistent_variable_returns_nil
|
126
|
+
assert_nil @connection.show_variable('foo_bar_baz')
|
127
|
+
end
|
128
|
+
|
129
|
+
def test_not_specifying_database_name_for_cross_database_selects
|
130
|
+
begin
|
131
|
+
assert_nothing_raised do
|
132
|
+
ActiveRecord::Base.establish_connection(ActiveRecord::Base.configurations['arunit'].except(:database))
|
133
|
+
|
134
|
+
config = ARTest.connection_config
|
135
|
+
ActiveRecord::Base.connection.execute(
|
136
|
+
"SELECT #{config['arunit']['database']}.pirates.*, #{config['arunit2']['database']}.courses.* " \
|
137
|
+
"FROM #{config['arunit']['database']}.pirates, #{config['arunit2']['database']}.courses"
|
138
|
+
)
|
139
|
+
end
|
140
|
+
ensure
|
141
|
+
ActiveRecord::Base.establish_connection :arunit
|
142
|
+
end
|
143
|
+
end
|
144
|
+
end
|
145
|
+
|
146
|
+
def test_table_alias
|
147
|
+
def @connection.test_table_alias_length() 10; end
|
148
|
+
class << @connection
|
149
|
+
alias_method :old_table_alias_length, :table_alias_length
|
150
|
+
alias_method :table_alias_length, :test_table_alias_length
|
151
|
+
end
|
152
|
+
|
153
|
+
assert_equal 'posts', @connection.table_alias_for('posts')
|
154
|
+
assert_equal 'posts_comm', @connection.table_alias_for('posts_comments')
|
155
|
+
assert_equal 'dbo_posts', @connection.table_alias_for('dbo.posts')
|
156
|
+
|
157
|
+
class << @connection
|
158
|
+
remove_method :table_alias_length
|
159
|
+
alias_method :table_alias_length, :old_table_alias_length
|
160
|
+
end
|
161
|
+
end
|
162
|
+
|
163
|
+
# test resetting sequences in odd tables in PostgreSQL
|
164
|
+
if ActiveRecord::Base.connection.respond_to?(:reset_pk_sequence!)
|
165
|
+
require 'models/movie'
|
166
|
+
require 'models/subscriber'
|
167
|
+
|
168
|
+
def test_reset_empty_table_with_custom_pk
|
169
|
+
Movie.delete_all
|
170
|
+
Movie.connection.reset_pk_sequence! 'movies'
|
171
|
+
assert_equal 1, Movie.create(:name => 'fight club').id
|
172
|
+
end
|
173
|
+
|
174
|
+
def test_reset_table_with_non_integer_pk
|
175
|
+
Subscriber.delete_all
|
176
|
+
Subscriber.connection.reset_pk_sequence! 'subscribers'
|
177
|
+
sub = Subscriber.new(:name => 'robert drake')
|
178
|
+
sub.id = 'bob drake'
|
179
|
+
assert_nothing_raised { sub.save! }
|
180
|
+
end
|
181
|
+
end
|
182
|
+
|
183
|
+
unless current_adapter?(:IBM_DBAdapter)
|
184
|
+
def test_uniqueness_violations_are_translated_to_specific_exception
|
185
|
+
@connection.execute "INSERT INTO subscribers(nick) VALUES('me')"
|
186
|
+
error = assert_raises(ActiveRecord::RecordNotUnique) do
|
187
|
+
@connection.execute "INSERT INTO subscribers(nick) VALUES('me')"
|
188
|
+
end
|
189
|
+
|
190
|
+
assert_not_nil error.cause
|
191
|
+
end
|
192
|
+
end
|
193
|
+
|
194
|
+
unless current_adapter?(:SQLite3Adapter, :IBM_DBAdapter)
|
195
|
+
def test_foreign_key_violations_are_translated_to_specific_exception
|
196
|
+
error = assert_raises(ActiveRecord::InvalidForeignKey) do
|
197
|
+
# Oracle adapter uses prefetched primary key values from sequence and passes them to connection adapter insert method
|
198
|
+
if @connection.prefetch_primary_key?
|
199
|
+
id_value = @connection.next_sequence_value(@connection.default_sequence_name("fk_test_has_fk", "id"))
|
200
|
+
@connection.execute "INSERT INTO fk_test_has_fk (id, fk_id) VALUES (#{id_value},0)"
|
201
|
+
else
|
202
|
+
@connection.execute "INSERT INTO fk_test_has_fk (fk_id) VALUES (0)"
|
203
|
+
end
|
204
|
+
end
|
205
|
+
|
206
|
+
assert_not_nil error.cause
|
207
|
+
end
|
208
|
+
|
209
|
+
def test_foreign_key_violations_are_translated_to_specific_exception_with_validate_false
|
210
|
+
klass_has_fk = Class.new(ActiveRecord::Base) do
|
211
|
+
self.table_name = 'fk_test_has_fk'
|
212
|
+
end
|
213
|
+
|
214
|
+
error = assert_raises(ActiveRecord::InvalidForeignKey) do
|
215
|
+
has_fk = klass_has_fk.new
|
216
|
+
has_fk.fk_id = 1231231231
|
217
|
+
has_fk.save(validate: false)
|
218
|
+
end
|
219
|
+
|
220
|
+
assert_not_nil error.cause
|
221
|
+
end
|
222
|
+
|
223
|
+
def test_value_limit_violations_are_translated_to_specific_exception
|
224
|
+
error = assert_raises(ActiveRecord::ValueTooLong) do
|
225
|
+
Event.create(title: 'abcdefgh')
|
226
|
+
end
|
227
|
+
|
228
|
+
assert_not_nil error.cause
|
229
|
+
end
|
230
|
+
end
|
231
|
+
|
232
|
+
def test_disable_referential_integrity
|
233
|
+
assert_nothing_raised do
|
234
|
+
@connection.disable_referential_integrity do
|
235
|
+
# Oracle adapter uses prefetched primary key values from sequence and passes them to connection adapter insert method
|
236
|
+
if @connection.prefetch_primary_key?
|
237
|
+
id_value = @connection.next_sequence_value(@connection.default_sequence_name("fk_test_has_fk", "id"))
|
238
|
+
@connection.execute "INSERT INTO fk_test_has_fk (id, fk_id) VALUES (#{id_value},0)"
|
239
|
+
else
|
240
|
+
@connection.execute "INSERT INTO fk_test_has_fk (fk_id) VALUES (0)"
|
241
|
+
end
|
242
|
+
# should delete created record as otherwise disable_referential_integrity will try to enable constraints after executed block
|
243
|
+
# and will fail (at least on Oracle)
|
244
|
+
@connection.execute "DELETE FROM fk_test_has_fk"
|
245
|
+
end
|
246
|
+
end
|
247
|
+
end
|
248
|
+
|
249
|
+
def test_select_all_always_return_activerecord_result
|
250
|
+
result = @connection.select_all "SELECT * FROM posts"
|
251
|
+
assert result.is_a?(ActiveRecord::Result)
|
252
|
+
end
|
253
|
+
|
254
|
+
if ActiveRecord::Base.connection.prepared_statements
|
255
|
+
def test_select_all_with_legacy_binds
|
256
|
+
post = Post.create!(title: "foo", body: "bar")
|
257
|
+
expected = @connection.select_all("SELECT * FROM posts WHERE id = #{post.id}")
|
258
|
+
result = @connection.select_all("SELECT * FROM posts WHERE id = #{Arel::Nodes::BindParam.new.to_sql}", nil, [[nil, post.id]])
|
259
|
+
assert_equal expected.to_hash, result.to_hash
|
260
|
+
end
|
261
|
+
end
|
262
|
+
|
263
|
+
unless current_adapter?(:IBM_DBAdapter)
|
264
|
+
def test_select_methods_passing_a_association_relation
|
265
|
+
author = Author.create!(name: 'john')
|
266
|
+
Post.create!(author: author, title: 'foo', body: 'bar')
|
267
|
+
query = author.posts.where(title: 'foo').select(:title)
|
268
|
+
assert_equal({"title" => "foo"}, @connection.select_one(query.arel, nil, query.bound_attributes))
|
269
|
+
assert_equal({"title" => "foo"}, @connection.select_one(query))
|
270
|
+
assert @connection.select_all(query).is_a?(ActiveRecord::Result)
|
271
|
+
assert_equal "foo", @connection.select_value(query)
|
272
|
+
assert_equal ["foo"], @connection.select_values(query)
|
273
|
+
end
|
274
|
+
end
|
275
|
+
|
276
|
+
unless current_adapter?(:IBM_DBAdapter)
|
277
|
+
def test_select_methods_passing_a_relation
|
278
|
+
Post.create!(title: 'foo', body: 'bar')
|
279
|
+
query = Post.where(title: 'foo').select(:title)
|
280
|
+
assert_equal({"title" => "foo"}, @connection.select_one(query.arel, nil, query.bound_attributes))
|
281
|
+
assert_equal({"title" => "foo"}, @connection.select_one(query))
|
282
|
+
assert @connection.select_all(query).is_a?(ActiveRecord::Result)
|
283
|
+
assert_equal "foo", @connection.select_value(query)
|
284
|
+
assert_equal ["foo"], @connection.select_values(query)
|
285
|
+
end
|
286
|
+
end
|
287
|
+
|
288
|
+
test "type_to_sql returns a String for unmapped types" do
|
289
|
+
assert_equal "special_db_type", @connection.type_to_sql(:special_db_type)
|
290
|
+
end
|
291
|
+
|
292
|
+
unless current_adapter?(:PostgreSQLAdapter, :IBM_DBAdapter)
|
293
|
+
def test_log_invalid_encoding
|
294
|
+
error = assert_raise ActiveRecord::StatementInvalid do
|
295
|
+
@connection.send :log, "SELECT 'ы' FROM DUAL" do
|
296
|
+
raise 'ы'.force_encoding(Encoding::ASCII_8BIT)
|
297
|
+
end
|
298
|
+
end
|
299
|
+
|
300
|
+
assert_not_nil error.cause
|
301
|
+
end
|
302
|
+
end
|
303
|
+
|
304
|
+
if current_adapter?(:Mysql2Adapter, :SQLite3Adapter)
|
305
|
+
def test_tables_returning_both_tables_and_views_is_deprecated
|
306
|
+
assert_deprecated { @connection.tables }
|
307
|
+
end
|
308
|
+
end
|
309
|
+
|
310
|
+
def test_passing_arguments_to_tables_is_deprecated
|
311
|
+
assert_deprecated { @connection.tables(:books) }
|
312
|
+
end
|
313
|
+
end
|
314
|
+
|
315
|
+
class AdapterTestWithoutTransaction < ActiveRecord::TestCase
|
316
|
+
self.use_transactional_tests = false
|
317
|
+
|
318
|
+
class Klass < ActiveRecord::Base
|
319
|
+
end
|
320
|
+
|
321
|
+
def setup
|
322
|
+
Klass.establish_connection :arunit
|
323
|
+
@connection = Klass.connection
|
324
|
+
end
|
325
|
+
|
326
|
+
teardown do
|
327
|
+
Klass.remove_connection
|
328
|
+
end
|
329
|
+
|
330
|
+
unless current_adapter?(:IBM_DBAdapter)
|
331
|
+
unless in_memory_db?
|
332
|
+
test "transaction state is reset after a reconnect" do
|
333
|
+
@connection.begin_transaction
|
334
|
+
assert @connection.transaction_open?
|
335
|
+
@connection.reconnect!
|
336
|
+
assert !@connection.transaction_open?
|
337
|
+
end
|
338
|
+
|
339
|
+
test "transaction state is reset after a disconnect" do
|
340
|
+
@connection.begin_transaction
|
341
|
+
assert @connection.transaction_open?
|
342
|
+
@connection.disconnect!
|
343
|
+
assert !@connection.transaction_open?
|
344
|
+
end
|
345
|
+
end
|
346
|
+
end
|
347
|
+
|
348
|
+
end
|
349
|
+
|
350
|
+
|
351
|
+
end
|