activerecord 4.2.11.2 → 6.0.0
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.
Potentially problematic release.
This version of activerecord might be problematic. Click here for more details.
- checksums.yaml +4 -4
- data/CHANGELOG.md +613 -1638
- data/MIT-LICENSE +4 -2
- data/README.rdoc +13 -12
- data/examples/performance.rb +33 -32
- data/examples/simple.rb +5 -4
- data/lib/active_record.rb +41 -22
- data/lib/active_record/aggregations.rb +267 -251
- data/lib/active_record/association_relation.rb +11 -6
- data/lib/active_record/associations.rb +1737 -1597
- data/lib/active_record/associations/alias_tracker.rb +29 -35
- data/lib/active_record/associations/association.rb +125 -58
- data/lib/active_record/associations/association_scope.rb +103 -132
- data/lib/active_record/associations/belongs_to_association.rb +65 -60
- data/lib/active_record/associations/belongs_to_polymorphic_association.rb +8 -12
- data/lib/active_record/associations/builder/association.rb +27 -40
- data/lib/active_record/associations/builder/belongs_to.rb +69 -55
- data/lib/active_record/associations/builder/collection_association.rb +10 -33
- data/lib/active_record/associations/builder/has_and_belongs_to_many.rb +52 -66
- data/lib/active_record/associations/builder/has_many.rb +8 -4
- data/lib/active_record/associations/builder/has_one.rb +46 -5
- data/lib/active_record/associations/builder/singular_association.rb +16 -10
- data/lib/active_record/associations/collection_association.rb +131 -287
- data/lib/active_record/associations/collection_proxy.rb +241 -146
- data/lib/active_record/associations/foreign_association.rb +10 -1
- data/lib/active_record/associations/has_many_association.rb +34 -97
- data/lib/active_record/associations/has_many_through_association.rb +60 -87
- data/lib/active_record/associations/has_one_association.rb +61 -49
- data/lib/active_record/associations/has_one_through_association.rb +20 -11
- data/lib/active_record/associations/join_dependency.rb +137 -167
- data/lib/active_record/associations/join_dependency/join_association.rb +38 -86
- data/lib/active_record/associations/join_dependency/join_base.rb +10 -9
- data/lib/active_record/associations/join_dependency/join_part.rb +14 -14
- data/lib/active_record/associations/preloader.rb +90 -92
- data/lib/active_record/associations/preloader/association.rb +90 -123
- data/lib/active_record/associations/preloader/through_association.rb +85 -65
- data/lib/active_record/associations/singular_association.rb +18 -39
- data/lib/active_record/associations/through_association.rb +38 -18
- data/lib/active_record/attribute_assignment.rb +56 -183
- data/lib/active_record/attribute_decorators.rb +39 -15
- data/lib/active_record/attribute_methods.rb +120 -135
- data/lib/active_record/attribute_methods/before_type_cast.rb +13 -8
- data/lib/active_record/attribute_methods/dirty.rb +174 -144
- data/lib/active_record/attribute_methods/primary_key.rb +91 -83
- data/lib/active_record/attribute_methods/query.rb +6 -5
- data/lib/active_record/attribute_methods/read.rb +20 -76
- data/lib/active_record/attribute_methods/serialization.rb +40 -20
- data/lib/active_record/attribute_methods/time_zone_conversion.rb +58 -36
- data/lib/active_record/attribute_methods/write.rb +32 -54
- data/lib/active_record/attributes.rb +214 -82
- data/lib/active_record/autosave_association.rb +91 -37
- data/lib/active_record/base.rb +57 -45
- data/lib/active_record/callbacks.rb +100 -74
- data/lib/active_record/coders/json.rb +3 -1
- data/lib/active_record/coders/yaml_column.rb +24 -12
- data/lib/active_record/connection_adapters/abstract/connection_pool.rb +796 -296
- data/lib/active_record/connection_adapters/abstract/database_limits.rb +26 -8
- data/lib/active_record/connection_adapters/abstract/database_statements.rb +234 -115
- data/lib/active_record/connection_adapters/abstract/query_cache.rb +82 -23
- data/lib/active_record/connection_adapters/abstract/quoting.rb +170 -53
- data/lib/active_record/connection_adapters/abstract/savepoints.rb +5 -3
- data/lib/active_record/connection_adapters/abstract/schema_creation.rb +74 -46
- data/lib/active_record/connection_adapters/abstract/schema_definitions.rb +356 -227
- data/lib/active_record/connection_adapters/abstract/schema_dumper.rb +79 -36
- data/lib/active_record/connection_adapters/abstract/schema_statements.rb +664 -243
- data/lib/active_record/connection_adapters/abstract/transaction.rb +191 -83
- data/lib/active_record/connection_adapters/abstract_adapter.rb +460 -204
- data/lib/active_record/connection_adapters/abstract_mysql_adapter.rb +510 -635
- data/lib/active_record/connection_adapters/column.rb +56 -43
- data/lib/active_record/connection_adapters/connection_specification.rb +174 -152
- data/lib/active_record/connection_adapters/determine_if_preparable_visitor.rb +29 -0
- data/lib/active_record/connection_adapters/mysql/column.rb +27 -0
- data/lib/active_record/connection_adapters/mysql/database_statements.rb +200 -0
- data/lib/active_record/connection_adapters/mysql/explain_pretty_printer.rb +72 -0
- data/lib/active_record/connection_adapters/mysql/quoting.rb +81 -0
- data/lib/active_record/connection_adapters/mysql/schema_creation.rb +72 -0
- data/lib/active_record/connection_adapters/mysql/schema_definitions.rb +95 -0
- data/lib/active_record/connection_adapters/mysql/schema_dumper.rb +88 -0
- data/lib/active_record/connection_adapters/mysql/schema_statements.rb +264 -0
- data/lib/active_record/connection_adapters/mysql/type_metadata.rb +31 -0
- data/lib/active_record/connection_adapters/mysql2_adapter.rb +58 -180
- data/lib/active_record/connection_adapters/postgresql/column.rb +21 -11
- data/lib/active_record/connection_adapters/postgresql/database_statements.rb +64 -114
- data/lib/active_record/connection_adapters/postgresql/explain_pretty_printer.rb +44 -0
- data/lib/active_record/connection_adapters/postgresql/oid.rb +23 -25
- data/lib/active_record/connection_adapters/postgresql/oid/array.rb +50 -58
- data/lib/active_record/connection_adapters/postgresql/oid/bit.rb +9 -8
- data/lib/active_record/connection_adapters/postgresql/oid/bit_varying.rb +2 -0
- data/lib/active_record/connection_adapters/postgresql/oid/bytea.rb +4 -2
- data/lib/active_record/connection_adapters/postgresql/oid/cidr.rb +5 -1
- data/lib/active_record/connection_adapters/postgresql/oid/date.rb +13 -1
- data/lib/active_record/connection_adapters/postgresql/oid/date_time.rb +9 -22
- data/lib/active_record/connection_adapters/postgresql/oid/decimal.rb +3 -1
- data/lib/active_record/connection_adapters/postgresql/oid/enum.rb +5 -3
- data/lib/active_record/connection_adapters/postgresql/oid/hstore.rb +31 -19
- data/lib/active_record/connection_adapters/postgresql/oid/inet.rb +2 -0
- data/lib/active_record/connection_adapters/postgresql/oid/jsonb.rb +3 -11
- data/lib/active_record/connection_adapters/postgresql/oid/legacy_point.rb +45 -0
- data/lib/active_record/connection_adapters/postgresql/oid/money.rb +7 -9
- data/lib/active_record/connection_adapters/postgresql/oid/{integer.rb → oid.rb} +6 -2
- data/lib/active_record/connection_adapters/postgresql/oid/point.rb +33 -11
- data/lib/active_record/connection_adapters/postgresql/oid/range.rb +52 -34
- data/lib/active_record/connection_adapters/postgresql/oid/specialized_string.rb +4 -5
- data/lib/active_record/connection_adapters/postgresql/oid/type_map_initializer.rb +58 -54
- data/lib/active_record/connection_adapters/postgresql/oid/uuid.rb +10 -5
- data/lib/active_record/connection_adapters/postgresql/oid/vector.rb +3 -1
- data/lib/active_record/connection_adapters/postgresql/oid/xml.rb +3 -1
- data/lib/active_record/connection_adapters/postgresql/quoting.rb +144 -47
- data/lib/active_record/connection_adapters/postgresql/referential_integrity.rb +27 -14
- data/lib/active_record/connection_adapters/postgresql/schema_creation.rb +76 -0
- data/lib/active_record/connection_adapters/postgresql/schema_definitions.rb +178 -108
- data/lib/active_record/connection_adapters/postgresql/schema_dumper.rb +50 -0
- data/lib/active_record/connection_adapters/postgresql/schema_statements.rb +470 -290
- data/lib/active_record/connection_adapters/postgresql/type_metadata.rb +36 -0
- data/lib/active_record/connection_adapters/postgresql/utils.rb +12 -8
- data/lib/active_record/connection_adapters/postgresql_adapter.rb +551 -356
- data/lib/active_record/connection_adapters/schema_cache.rb +72 -25
- data/lib/active_record/connection_adapters/sql_type_metadata.rb +37 -0
- data/lib/active_record/connection_adapters/sqlite3/database_statements.rb +118 -0
- data/lib/active_record/connection_adapters/sqlite3/explain_pretty_printer.rb +21 -0
- data/lib/active_record/connection_adapters/sqlite3/quoting.rb +103 -0
- data/lib/active_record/connection_adapters/sqlite3/schema_creation.rb +17 -0
- data/lib/active_record/connection_adapters/sqlite3/schema_definitions.rb +19 -0
- data/lib/active_record/connection_adapters/sqlite3/schema_dumper.rb +18 -0
- data/lib/active_record/connection_adapters/sqlite3/schema_statements.rb +137 -0
- data/lib/active_record/connection_adapters/sqlite3_adapter.rb +290 -345
- data/lib/active_record/connection_adapters/statement_pool.rb +34 -13
- data/lib/active_record/connection_handling.rb +176 -41
- data/lib/active_record/core.rb +251 -231
- data/lib/active_record/counter_cache.rb +67 -49
- data/lib/active_record/database_configurations.rb +233 -0
- data/lib/active_record/database_configurations/database_config.rb +37 -0
- data/lib/active_record/database_configurations/hash_config.rb +50 -0
- data/lib/active_record/database_configurations/url_config.rb +79 -0
- data/lib/active_record/define_callbacks.rb +22 -0
- data/lib/active_record/dynamic_matchers.rb +87 -105
- data/lib/active_record/enum.rb +163 -86
- data/lib/active_record/errors.rb +188 -53
- data/lib/active_record/explain.rb +23 -11
- data/lib/active_record/explain_registry.rb +4 -2
- data/lib/active_record/explain_subscriber.rb +10 -5
- data/lib/active_record/fixture_set/file.rb +35 -9
- data/lib/active_record/fixture_set/model_metadata.rb +33 -0
- data/lib/active_record/fixture_set/render_context.rb +17 -0
- data/lib/active_record/fixture_set/table_row.rb +153 -0
- data/lib/active_record/fixture_set/table_rows.rb +47 -0
- data/lib/active_record/fixtures.rb +228 -499
- data/lib/active_record/gem_version.rb +6 -4
- data/lib/active_record/inheritance.rb +158 -112
- data/lib/active_record/insert_all.rb +179 -0
- data/lib/active_record/integration.rb +123 -29
- data/lib/active_record/internal_metadata.rb +53 -0
- data/lib/active_record/legacy_yaml_adapter.rb +21 -3
- data/lib/active_record/locale/en.yml +3 -2
- data/lib/active_record/locking/optimistic.rb +87 -96
- data/lib/active_record/locking/pessimistic.rb +18 -6
- data/lib/active_record/log_subscriber.rb +76 -33
- data/lib/active_record/middleware/database_selector.rb +75 -0
- data/lib/active_record/middleware/database_selector/resolver.rb +92 -0
- data/lib/active_record/middleware/database_selector/resolver/session.rb +45 -0
- data/lib/active_record/migration.rb +621 -303
- data/lib/active_record/migration/command_recorder.rb +177 -90
- data/lib/active_record/migration/compatibility.rb +244 -0
- data/lib/active_record/migration/join_table.rb +8 -6
- data/lib/active_record/model_schema.rb +312 -112
- data/lib/active_record/nested_attributes.rb +264 -222
- data/lib/active_record/no_touching.rb +14 -1
- data/lib/active_record/null_relation.rb +24 -37
- data/lib/active_record/persistence.rb +557 -125
- data/lib/active_record/query_cache.rb +19 -23
- data/lib/active_record/querying.rb +43 -29
- data/lib/active_record/railtie.rb +143 -44
- data/lib/active_record/railties/collection_cache_association_loading.rb +34 -0
- data/lib/active_record/railties/console_sandbox.rb +2 -0
- data/lib/active_record/railties/controller_runtime.rb +34 -33
- data/lib/active_record/railties/databases.rake +328 -185
- data/lib/active_record/readonly_attributes.rb +5 -4
- data/lib/active_record/reflection.rb +428 -279
- data/lib/active_record/relation.rb +518 -341
- data/lib/active_record/relation/batches.rb +207 -55
- data/lib/active_record/relation/batches/batch_enumerator.rb +69 -0
- data/lib/active_record/relation/calculations.rb +267 -253
- data/lib/active_record/relation/delegation.rb +70 -80
- data/lib/active_record/relation/finder_methods.rb +277 -241
- data/lib/active_record/relation/from_clause.rb +26 -0
- data/lib/active_record/relation/merger.rb +78 -87
- data/lib/active_record/relation/predicate_builder.rb +114 -119
- data/lib/active_record/relation/predicate_builder/array_handler.rb +27 -26
- data/lib/active_record/relation/predicate_builder/association_query_value.rb +43 -0
- data/lib/active_record/relation/predicate_builder/base_handler.rb +18 -0
- data/lib/active_record/relation/predicate_builder/basic_object_handler.rb +19 -0
- data/lib/active_record/relation/predicate_builder/polymorphic_array_value.rb +53 -0
- data/lib/active_record/relation/predicate_builder/range_handler.rb +22 -0
- data/lib/active_record/relation/predicate_builder/relation_handler.rb +7 -1
- data/lib/active_record/relation/query_attribute.rb +50 -0
- data/lib/active_record/relation/query_methods.rb +575 -394
- data/lib/active_record/relation/record_fetch_warning.rb +51 -0
- data/lib/active_record/relation/spawn_methods.rb +11 -13
- data/lib/active_record/relation/where_clause.rb +190 -0
- data/lib/active_record/relation/where_clause_factory.rb +33 -0
- data/lib/active_record/result.rb +79 -42
- data/lib/active_record/runtime_registry.rb +6 -4
- data/lib/active_record/sanitization.rb +144 -121
- data/lib/active_record/schema.rb +21 -24
- data/lib/active_record/schema_dumper.rb +112 -93
- data/lib/active_record/schema_migration.rb +24 -17
- data/lib/active_record/scoping.rb +45 -26
- data/lib/active_record/scoping/default.rb +101 -85
- data/lib/active_record/scoping/named.rb +86 -33
- data/lib/active_record/secure_token.rb +40 -0
- data/lib/active_record/serialization.rb +5 -5
- data/lib/active_record/statement_cache.rb +73 -36
- data/lib/active_record/store.rb +127 -42
- data/lib/active_record/suppressor.rb +61 -0
- data/lib/active_record/table_metadata.rb +75 -0
- data/lib/active_record/tasks/database_tasks.rb +307 -100
- data/lib/active_record/tasks/mysql_database_tasks.rb +55 -99
- data/lib/active_record/tasks/postgresql_database_tasks.rb +81 -41
- data/lib/active_record/tasks/sqlite_database_tasks.rb +38 -16
- data/lib/active_record/test_databases.rb +23 -0
- data/lib/active_record/test_fixtures.rb +224 -0
- data/lib/active_record/timestamp.rb +86 -40
- data/lib/active_record/touch_later.rb +66 -0
- data/lib/active_record/transactions.rb +216 -150
- data/lib/active_record/translation.rb +3 -1
- data/lib/active_record/type.rb +78 -23
- data/lib/active_record/type/adapter_specific_registry.rb +129 -0
- data/lib/active_record/type/date.rb +4 -45
- data/lib/active_record/type/date_time.rb +4 -49
- data/lib/active_record/type/decimal_without_scale.rb +6 -2
- data/lib/active_record/type/hash_lookup_type_map.rb +5 -3
- data/lib/active_record/type/internal/timezone.rb +17 -0
- data/lib/active_record/type/json.rb +30 -0
- data/lib/active_record/type/serialized.rb +24 -15
- data/lib/active_record/type/text.rb +2 -2
- data/lib/active_record/type/time.rb +11 -16
- data/lib/active_record/type/type_map.rb +15 -17
- data/lib/active_record/type/unsigned_integer.rb +9 -7
- data/lib/active_record/type_caster.rb +9 -0
- data/lib/active_record/type_caster/connection.rb +34 -0
- data/lib/active_record/type_caster/map.rb +20 -0
- data/lib/active_record/validations.rb +39 -35
- data/lib/active_record/validations/absence.rb +25 -0
- data/lib/active_record/validations/associated.rb +13 -4
- data/lib/active_record/validations/length.rb +26 -0
- data/lib/active_record/validations/presence.rb +14 -13
- data/lib/active_record/validations/uniqueness.rb +42 -55
- data/lib/active_record/version.rb +3 -1
- data/lib/arel.rb +51 -0
- data/lib/arel/alias_predication.rb +9 -0
- data/lib/arel/attributes.rb +22 -0
- data/lib/arel/attributes/attribute.rb +37 -0
- data/lib/arel/collectors/bind.rb +24 -0
- data/lib/arel/collectors/composite.rb +31 -0
- data/lib/arel/collectors/plain_string.rb +20 -0
- data/lib/arel/collectors/sql_string.rb +20 -0
- data/lib/arel/collectors/substitute_binds.rb +28 -0
- data/lib/arel/crud.rb +42 -0
- data/lib/arel/delete_manager.rb +18 -0
- data/lib/arel/errors.rb +9 -0
- data/lib/arel/expressions.rb +29 -0
- data/lib/arel/factory_methods.rb +49 -0
- data/lib/arel/insert_manager.rb +49 -0
- data/lib/arel/math.rb +45 -0
- data/lib/arel/nodes.rb +68 -0
- data/lib/arel/nodes/and.rb +32 -0
- data/lib/arel/nodes/ascending.rb +23 -0
- data/lib/arel/nodes/binary.rb +52 -0
- data/lib/arel/nodes/bind_param.rb +36 -0
- data/lib/arel/nodes/case.rb +55 -0
- data/lib/arel/nodes/casted.rb +50 -0
- data/lib/arel/nodes/comment.rb +29 -0
- data/lib/arel/nodes/count.rb +12 -0
- data/lib/arel/nodes/delete_statement.rb +45 -0
- data/lib/arel/nodes/descending.rb +23 -0
- data/lib/arel/nodes/equality.rb +18 -0
- data/lib/arel/nodes/extract.rb +24 -0
- data/lib/arel/nodes/false.rb +16 -0
- data/lib/arel/nodes/full_outer_join.rb +8 -0
- data/lib/arel/nodes/function.rb +44 -0
- data/lib/arel/nodes/grouping.rb +8 -0
- data/lib/arel/nodes/in.rb +8 -0
- data/lib/arel/nodes/infix_operation.rb +80 -0
- data/lib/arel/nodes/inner_join.rb +8 -0
- data/lib/arel/nodes/insert_statement.rb +37 -0
- data/lib/arel/nodes/join_source.rb +20 -0
- data/lib/arel/nodes/matches.rb +18 -0
- data/lib/arel/nodes/named_function.rb +23 -0
- data/lib/arel/nodes/node.rb +50 -0
- data/lib/arel/nodes/node_expression.rb +13 -0
- data/lib/arel/nodes/outer_join.rb +8 -0
- data/lib/arel/nodes/over.rb +15 -0
- data/lib/arel/nodes/regexp.rb +16 -0
- data/lib/arel/nodes/right_outer_join.rb +8 -0
- data/lib/arel/nodes/select_core.rb +67 -0
- data/lib/arel/nodes/select_statement.rb +41 -0
- data/lib/arel/nodes/sql_literal.rb +16 -0
- data/lib/arel/nodes/string_join.rb +11 -0
- data/lib/arel/nodes/table_alias.rb +27 -0
- data/lib/arel/nodes/terminal.rb +16 -0
- data/lib/arel/nodes/true.rb +16 -0
- data/lib/arel/nodes/unary.rb +45 -0
- data/lib/arel/nodes/unary_operation.rb +20 -0
- data/lib/arel/nodes/unqualified_column.rb +22 -0
- data/lib/arel/nodes/update_statement.rb +41 -0
- data/lib/arel/nodes/values_list.rb +9 -0
- data/lib/arel/nodes/window.rb +126 -0
- data/lib/arel/nodes/with.rb +11 -0
- data/lib/arel/order_predications.rb +13 -0
- data/lib/arel/predications.rb +257 -0
- data/lib/arel/select_manager.rb +271 -0
- data/lib/arel/table.rb +110 -0
- data/lib/arel/tree_manager.rb +72 -0
- data/lib/arel/update_manager.rb +34 -0
- data/lib/arel/visitors.rb +20 -0
- data/lib/arel/visitors/depth_first.rb +204 -0
- data/lib/arel/visitors/dot.rb +297 -0
- data/lib/arel/visitors/ibm_db.rb +34 -0
- data/lib/arel/visitors/informix.rb +62 -0
- data/lib/arel/visitors/mssql.rb +157 -0
- data/lib/arel/visitors/mysql.rb +83 -0
- data/lib/arel/visitors/oracle.rb +159 -0
- data/lib/arel/visitors/oracle12.rb +66 -0
- data/lib/arel/visitors/postgresql.rb +110 -0
- data/lib/arel/visitors/sqlite.rb +39 -0
- data/lib/arel/visitors/to_sql.rb +889 -0
- data/lib/arel/visitors/visitor.rb +46 -0
- data/lib/arel/visitors/where_sql.rb +23 -0
- data/lib/arel/window_predications.rb +9 -0
- data/lib/rails/generators/active_record.rb +7 -5
- data/lib/rails/generators/active_record/application_record/application_record_generator.rb +27 -0
- data/lib/rails/generators/active_record/application_record/templates/application_record.rb.tt +5 -0
- data/lib/rails/generators/active_record/migration.rb +31 -1
- data/lib/rails/generators/active_record/migration/migration_generator.rb +42 -37
- data/lib/rails/generators/active_record/migration/templates/create_table_migration.rb.tt +24 -0
- data/lib/rails/generators/active_record/migration/templates/{migration.rb → migration.rb.tt} +11 -2
- data/lib/rails/generators/active_record/model/model_generator.rb +19 -22
- data/lib/rails/generators/active_record/model/templates/model.rb.tt +22 -0
- data/lib/rails/generators/active_record/model/templates/{module.rb → module.rb.tt} +0 -0
- metadata +164 -59
- data/lib/active_record/associations/preloader/belongs_to.rb +0 -17
- data/lib/active_record/associations/preloader/collection_association.rb +0 -24
- data/lib/active_record/associations/preloader/has_many.rb +0 -17
- data/lib/active_record/associations/preloader/has_many_through.rb +0 -19
- data/lib/active_record/associations/preloader/has_one.rb +0 -23
- data/lib/active_record/associations/preloader/has_one_through.rb +0 -9
- data/lib/active_record/associations/preloader/singular_association.rb +0 -21
- data/lib/active_record/attribute.rb +0 -163
- data/lib/active_record/attribute_set.rb +0 -81
- data/lib/active_record/attribute_set/builder.rb +0 -106
- data/lib/active_record/connection_adapters/mysql_adapter.rb +0 -498
- data/lib/active_record/connection_adapters/postgresql/array_parser.rb +0 -93
- data/lib/active_record/connection_adapters/postgresql/oid/float.rb +0 -21
- data/lib/active_record/connection_adapters/postgresql/oid/infinity.rb +0 -13
- data/lib/active_record/connection_adapters/postgresql/oid/json.rb +0 -35
- data/lib/active_record/connection_adapters/postgresql/oid/time.rb +0 -11
- data/lib/active_record/railties/jdbcmysql_error.rb +0 -16
- data/lib/active_record/serializers/xml_serializer.rb +0 -193
- data/lib/active_record/type/big_integer.rb +0 -13
- data/lib/active_record/type/binary.rb +0 -50
- data/lib/active_record/type/boolean.rb +0 -31
- data/lib/active_record/type/decimal.rb +0 -64
- data/lib/active_record/type/decorator.rb +0 -14
- data/lib/active_record/type/float.rb +0 -19
- data/lib/active_record/type/integer.rb +0 -59
- data/lib/active_record/type/mutable.rb +0 -16
- data/lib/active_record/type/numeric.rb +0 -36
- data/lib/active_record/type/string.rb +0 -40
- data/lib/active_record/type/time_value.rb +0 -38
- data/lib/active_record/type/value.rb +0 -110
- data/lib/rails/generators/active_record/migration/templates/create_table_migration.rb +0 -19
- data/lib/rails/generators/active_record/model/templates/model.rb +0 -10
@@ -1,9 +1,9 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
1
3
|
module ActiveRecord
|
2
4
|
module Tasks # :nodoc:
|
3
5
|
class MySQLDatabaseTasks # :nodoc:
|
4
|
-
|
5
|
-
DEFAULT_COLLATION = ENV['COLLATION'] || 'utf8_unicode_ci'
|
6
|
-
ACCESS_DENIED_ERROR = 1045
|
6
|
+
ER_DB_CREATE_EXISTS = 1007
|
7
7
|
|
8
8
|
delegate :connection, :establish_connection, to: ActiveRecord::Base
|
9
9
|
|
@@ -13,38 +13,24 @@ module ActiveRecord
|
|
13
13
|
|
14
14
|
def create
|
15
15
|
establish_connection configuration_without_database
|
16
|
-
connection.create_database configuration[
|
16
|
+
connection.create_database configuration["database"], creation_options
|
17
17
|
establish_connection configuration
|
18
18
|
rescue ActiveRecord::StatementInvalid => error
|
19
|
-
if
|
19
|
+
if connection.error_number(error.cause) == ER_DB_CREATE_EXISTS
|
20
20
|
raise DatabaseAlreadyExists
|
21
21
|
else
|
22
22
|
raise
|
23
23
|
end
|
24
|
-
rescue error_class => error
|
25
|
-
if error.respond_to?(:errno) && error.errno == ACCESS_DENIED_ERROR
|
26
|
-
$stdout.print error.error
|
27
|
-
establish_connection root_configuration_without_database
|
28
|
-
connection.create_database configuration['database'], creation_options
|
29
|
-
if configuration['username'] != 'root'
|
30
|
-
connection.execute grant_statement.gsub(/\s+/, ' ').strip
|
31
|
-
end
|
32
|
-
establish_connection configuration
|
33
|
-
else
|
34
|
-
$stderr.puts error.inspect
|
35
|
-
$stderr.puts "Couldn't create database for #{configuration.inspect}, #{creation_options.inspect}"
|
36
|
-
$stderr.puts "(If you set the charset manually, make sure you have a matching collation)" if configuration['encoding']
|
37
|
-
end
|
38
24
|
end
|
39
25
|
|
40
26
|
def drop
|
41
27
|
establish_connection configuration
|
42
|
-
connection.drop_database configuration[
|
28
|
+
connection.drop_database configuration["database"]
|
43
29
|
end
|
44
30
|
|
45
31
|
def purge
|
46
32
|
establish_connection configuration
|
47
|
-
connection.recreate_database configuration[
|
33
|
+
connection.recreate_database configuration["database"], creation_options
|
48
34
|
end
|
49
35
|
|
50
36
|
def charset
|
@@ -55,105 +41,75 @@ module ActiveRecord
|
|
55
41
|
connection.collation
|
56
42
|
end
|
57
43
|
|
58
|
-
def structure_dump(filename)
|
44
|
+
def structure_dump(filename, extra_flags)
|
59
45
|
args = prepare_command_options
|
60
46
|
args.concat(["--result-file", "#{filename}"])
|
61
47
|
args.concat(["--no-data"])
|
48
|
+
args.concat(["--routines"])
|
49
|
+
args.concat(["--skip-comments"])
|
50
|
+
|
51
|
+
ignore_tables = ActiveRecord::SchemaDumper.ignore_tables
|
52
|
+
if ignore_tables.any?
|
53
|
+
args += ignore_tables.map { |table| "--ignore-table=#{configuration['database']}.#{table}" }
|
54
|
+
end
|
55
|
+
|
62
56
|
args.concat(["#{configuration['database']}"])
|
57
|
+
args.unshift(*extra_flags) if extra_flags
|
63
58
|
|
64
|
-
run_cmd(
|
59
|
+
run_cmd("mysqldump", args, "dumping")
|
65
60
|
end
|
66
61
|
|
67
|
-
def structure_load(filename)
|
62
|
+
def structure_load(filename, extra_flags)
|
68
63
|
args = prepare_command_options
|
69
|
-
args.concat([
|
64
|
+
args.concat(["--execute", %{SET FOREIGN_KEY_CHECKS = 0; SOURCE #{filename}; SET FOREIGN_KEY_CHECKS = 1}])
|
70
65
|
args.concat(["--database", "#{configuration['database']}"])
|
66
|
+
args.unshift(*extra_flags) if extra_flags
|
71
67
|
|
72
|
-
run_cmd(
|
68
|
+
run_cmd("mysql", args, "loading")
|
73
69
|
end
|
74
70
|
|
75
71
|
private
|
76
72
|
|
77
|
-
|
78
|
-
@configuration
|
79
|
-
end
|
80
|
-
|
81
|
-
def configuration_without_database
|
82
|
-
configuration.merge('database' => nil)
|
83
|
-
end
|
84
|
-
|
85
|
-
def creation_options
|
86
|
-
Hash.new.tap do |options|
|
87
|
-
options[:charset] = configuration['encoding'] if configuration.include? 'encoding'
|
88
|
-
options[:collation] = configuration['collation'] if configuration.include? 'collation'
|
73
|
+
attr_reader :configuration
|
89
74
|
|
90
|
-
|
91
|
-
|
92
|
-
|
93
|
-
# Set default collation only when charset is also default.
|
94
|
-
options[:collation] ||= DEFAULT_COLLATION if options[:charset] == DEFAULT_CHARSET
|
75
|
+
def configuration_without_database
|
76
|
+
configuration.merge("database" => nil)
|
95
77
|
end
|
96
|
-
end
|
97
78
|
|
98
|
-
|
99
|
-
|
100
|
-
|
101
|
-
|
102
|
-
|
103
|
-
Mysql2::Error
|
104
|
-
elsif defined?(Mysql)
|
105
|
-
Mysql::Error
|
106
|
-
else
|
107
|
-
StandardError
|
79
|
+
def creation_options
|
80
|
+
Hash.new.tap do |options|
|
81
|
+
options[:charset] = configuration["encoding"] if configuration.include? "encoding"
|
82
|
+
options[:collation] = configuration["collation"] if configuration.include? "collation"
|
83
|
+
end
|
108
84
|
end
|
109
|
-
end
|
110
|
-
|
111
|
-
def grant_statement
|
112
|
-
<<-SQL
|
113
|
-
GRANT ALL PRIVILEGES ON #{configuration['database']}.*
|
114
|
-
TO '#{configuration['username']}'@'localhost'
|
115
|
-
IDENTIFIED BY '#{configuration['password']}' WITH GRANT OPTION;
|
116
|
-
SQL
|
117
|
-
end
|
118
|
-
|
119
|
-
def root_configuration_without_database
|
120
|
-
configuration_without_database.merge(
|
121
|
-
'username' => 'root',
|
122
|
-
'password' => root_password
|
123
|
-
)
|
124
|
-
end
|
125
|
-
|
126
|
-
def root_password
|
127
|
-
$stdout.print "Please provide the root password for your MySQL installation\n>"
|
128
|
-
$stdin.gets.strip
|
129
|
-
end
|
130
85
|
|
131
|
-
|
132
|
-
|
133
|
-
|
134
|
-
|
135
|
-
|
136
|
-
|
137
|
-
|
138
|
-
|
139
|
-
|
140
|
-
|
141
|
-
|
142
|
-
|
143
|
-
|
144
|
-
|
145
|
-
|
86
|
+
def prepare_command_options
|
87
|
+
args = {
|
88
|
+
"host" => "--host",
|
89
|
+
"port" => "--port",
|
90
|
+
"socket" => "--socket",
|
91
|
+
"username" => "--user",
|
92
|
+
"password" => "--password",
|
93
|
+
"encoding" => "--default-character-set",
|
94
|
+
"sslca" => "--ssl-ca",
|
95
|
+
"sslcert" => "--ssl-cert",
|
96
|
+
"sslcapath" => "--ssl-capath",
|
97
|
+
"sslcipher" => "--ssl-cipher",
|
98
|
+
"sslkey" => "--ssl-key"
|
99
|
+
}.map { |opt, arg| "#{arg}=#{configuration[opt]}" if configuration[opt] }.compact
|
100
|
+
|
101
|
+
args
|
102
|
+
end
|
146
103
|
|
147
|
-
|
148
|
-
|
149
|
-
|
104
|
+
def run_cmd(cmd, args, action)
|
105
|
+
fail run_cmd_error(cmd, args, action) unless Kernel.system(cmd, *args)
|
106
|
+
end
|
150
107
|
|
151
|
-
|
152
|
-
|
153
|
-
|
154
|
-
|
155
|
-
|
156
|
-
end
|
108
|
+
def run_cmd_error(cmd, args, action)
|
109
|
+
msg = +"failed to execute: `#{cmd}`\n"
|
110
|
+
msg << "Please check the output above for any errors and make sure that `#{cmd}` is installed in your PATH and has proper permissions.\n\n"
|
111
|
+
msg
|
112
|
+
end
|
157
113
|
end
|
158
114
|
end
|
159
115
|
end
|
@@ -1,7 +1,13 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
require "tempfile"
|
4
|
+
|
1
5
|
module ActiveRecord
|
2
6
|
module Tasks # :nodoc:
|
3
7
|
class PostgreSQLDatabaseTasks # :nodoc:
|
4
|
-
DEFAULT_ENCODING = ENV[
|
8
|
+
DEFAULT_ENCODING = ENV["CHARSET"] || "utf8"
|
9
|
+
ON_ERROR_STOP_1 = "ON_ERROR_STOP=1"
|
10
|
+
SQL_COMMENT_BEGIN = "--"
|
5
11
|
|
6
12
|
delegate :connection, :establish_connection, :clear_active_connections!,
|
7
13
|
to: ActiveRecord::Base
|
@@ -12,11 +18,11 @@ module ActiveRecord
|
|
12
18
|
|
13
19
|
def create(master_established = false)
|
14
20
|
establish_master_connection unless master_established
|
15
|
-
connection.create_database configuration[
|
16
|
-
configuration.merge(
|
21
|
+
connection.create_database configuration["database"],
|
22
|
+
configuration.merge("encoding" => encoding)
|
17
23
|
establish_connection configuration
|
18
24
|
rescue ActiveRecord::StatementInvalid => error
|
19
|
-
if
|
25
|
+
if error.cause.is_a?(PG::DuplicateDatabase)
|
20
26
|
raise DatabaseAlreadyExists
|
21
27
|
else
|
22
28
|
raise
|
@@ -25,7 +31,7 @@ module ActiveRecord
|
|
25
31
|
|
26
32
|
def drop
|
27
33
|
establish_master_connection
|
28
|
-
connection.drop_database configuration[
|
34
|
+
connection.drop_database configuration["database"]
|
29
35
|
end
|
30
36
|
|
31
37
|
def charset
|
@@ -42,60 +48,94 @@ module ActiveRecord
|
|
42
48
|
create true
|
43
49
|
end
|
44
50
|
|
45
|
-
def structure_dump(filename)
|
51
|
+
def structure_dump(filename, extra_flags)
|
46
52
|
set_psql_env
|
47
|
-
|
48
|
-
search_path =
|
53
|
+
|
54
|
+
search_path = \
|
55
|
+
case ActiveRecord::Base.dump_schemas
|
56
|
+
when :schema_search_path
|
57
|
+
configuration["schema_search_path"]
|
58
|
+
when :all
|
59
|
+
nil
|
60
|
+
when String
|
61
|
+
ActiveRecord::Base.dump_schemas
|
62
|
+
end
|
63
|
+
|
64
|
+
args = ["-s", "-x", "-O", "-f", filename]
|
65
|
+
args.concat(Array(extra_flags)) if extra_flags
|
49
66
|
unless search_path.blank?
|
50
|
-
args += search_path.split(
|
67
|
+
args += search_path.split(",").map do |part|
|
51
68
|
"--schema=#{part.strip}"
|
52
69
|
end
|
53
70
|
end
|
54
|
-
|
55
|
-
|
71
|
+
|
72
|
+
ignore_tables = ActiveRecord::SchemaDumper.ignore_tables
|
73
|
+
if ignore_tables.any?
|
74
|
+
args += ignore_tables.flat_map { |table| ["-T", table] }
|
75
|
+
end
|
76
|
+
|
77
|
+
args << configuration["database"]
|
78
|
+
run_cmd("pg_dump", args, "dumping")
|
79
|
+
remove_sql_header_comments(filename)
|
56
80
|
File.open(filename, "a") { |f| f << "SET search_path TO #{connection.schema_search_path};\n\n" }
|
57
81
|
end
|
58
82
|
|
59
|
-
def structure_load(filename)
|
83
|
+
def structure_load(filename, extra_flags)
|
60
84
|
set_psql_env
|
61
|
-
args = [
|
62
|
-
|
85
|
+
args = ["-v", ON_ERROR_STOP_1, "-q", "-X", "-f", filename]
|
86
|
+
args.concat(Array(extra_flags)) if extra_flags
|
87
|
+
args << configuration["database"]
|
88
|
+
run_cmd("psql", args, "loading")
|
63
89
|
end
|
64
90
|
|
65
91
|
private
|
66
92
|
|
67
|
-
|
68
|
-
@configuration
|
69
|
-
end
|
93
|
+
attr_reader :configuration
|
70
94
|
|
71
|
-
|
72
|
-
|
73
|
-
|
95
|
+
def encoding
|
96
|
+
configuration["encoding"] || DEFAULT_ENCODING
|
97
|
+
end
|
74
98
|
|
75
|
-
|
76
|
-
|
77
|
-
|
78
|
-
|
79
|
-
|
80
|
-
|
99
|
+
def establish_master_connection
|
100
|
+
establish_connection configuration.merge(
|
101
|
+
"database" => "postgres",
|
102
|
+
"schema_search_path" => "public"
|
103
|
+
)
|
104
|
+
end
|
81
105
|
|
82
|
-
|
83
|
-
|
84
|
-
|
85
|
-
|
86
|
-
|
87
|
-
|
106
|
+
def set_psql_env
|
107
|
+
ENV["PGHOST"] = configuration["host"] if configuration["host"]
|
108
|
+
ENV["PGPORT"] = configuration["port"].to_s if configuration["port"]
|
109
|
+
ENV["PGPASSWORD"] = configuration["password"].to_s if configuration["password"]
|
110
|
+
ENV["PGUSER"] = configuration["username"].to_s if configuration["username"]
|
111
|
+
end
|
88
112
|
|
89
|
-
|
90
|
-
|
91
|
-
|
113
|
+
def run_cmd(cmd, args, action)
|
114
|
+
fail run_cmd_error(cmd, args, action) unless Kernel.system(cmd, *args)
|
115
|
+
end
|
92
116
|
|
93
|
-
|
94
|
-
|
95
|
-
|
96
|
-
|
97
|
-
|
98
|
-
|
117
|
+
def run_cmd_error(cmd, args, action)
|
118
|
+
msg = +"failed to execute:\n"
|
119
|
+
msg << "#{cmd} #{args.join(' ')}\n\n"
|
120
|
+
msg << "Please check the output above for any errors and make sure that `#{cmd}` is installed in your PATH and has proper permissions.\n\n"
|
121
|
+
msg
|
122
|
+
end
|
123
|
+
|
124
|
+
def remove_sql_header_comments(filename)
|
125
|
+
removing_comments = true
|
126
|
+
tempfile = Tempfile.open("uncommented_structure.sql")
|
127
|
+
begin
|
128
|
+
File.foreach(filename) do |line|
|
129
|
+
unless removing_comments && (line.start_with?(SQL_COMMENT_BEGIN) || line.blank?)
|
130
|
+
tempfile << line
|
131
|
+
removing_comments = false
|
132
|
+
end
|
133
|
+
end
|
134
|
+
ensure
|
135
|
+
tempfile.close
|
136
|
+
end
|
137
|
+
FileUtils.cp(tempfile.path, filename)
|
138
|
+
end
|
99
139
|
end
|
100
140
|
end
|
101
141
|
end
|
@@ -1,3 +1,5 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
1
3
|
module ActiveRecord
|
2
4
|
module Tasks # :nodoc:
|
3
5
|
class SQLiteDatabaseTasks # :nodoc:
|
@@ -8,22 +10,26 @@ module ActiveRecord
|
|
8
10
|
end
|
9
11
|
|
10
12
|
def create
|
11
|
-
raise DatabaseAlreadyExists if File.exist?(configuration[
|
13
|
+
raise DatabaseAlreadyExists if File.exist?(configuration["database"])
|
12
14
|
|
13
15
|
establish_connection configuration
|
14
16
|
connection
|
15
17
|
end
|
16
18
|
|
17
19
|
def drop
|
18
|
-
require
|
19
|
-
path = Pathname.new configuration[
|
20
|
+
require "pathname"
|
21
|
+
path = Pathname.new configuration["database"]
|
20
22
|
file = path.absolute? ? path.to_s : File.join(root, path)
|
21
23
|
|
22
|
-
FileUtils.rm(file)
|
24
|
+
FileUtils.rm(file)
|
25
|
+
rescue Errno::ENOENT => error
|
26
|
+
raise NoDatabaseError.new(error.message)
|
23
27
|
end
|
24
28
|
|
25
29
|
def purge
|
26
30
|
drop
|
31
|
+
rescue NoDatabaseError
|
32
|
+
ensure
|
27
33
|
create
|
28
34
|
end
|
29
35
|
|
@@ -31,25 +37,41 @@ module ActiveRecord
|
|
31
37
|
connection.encoding
|
32
38
|
end
|
33
39
|
|
34
|
-
def structure_dump(filename)
|
35
|
-
|
36
|
-
|
40
|
+
def structure_dump(filename, extra_flags)
|
41
|
+
args = []
|
42
|
+
args.concat(Array(extra_flags)) if extra_flags
|
43
|
+
args << configuration["database"]
|
44
|
+
|
45
|
+
ignore_tables = ActiveRecord::SchemaDumper.ignore_tables
|
46
|
+
if ignore_tables.any?
|
47
|
+
condition = ignore_tables.map { |table| connection.quote(table) }.join(", ")
|
48
|
+
args << "SELECT sql FROM sqlite_master WHERE tbl_name NOT IN (#{condition}) ORDER BY tbl_name, type DESC, name"
|
49
|
+
else
|
50
|
+
args << ".schema"
|
51
|
+
end
|
52
|
+
run_cmd("sqlite3", args, filename)
|
37
53
|
end
|
38
54
|
|
39
|
-
def structure_load(filename)
|
40
|
-
dbfile = configuration[
|
41
|
-
|
55
|
+
def structure_load(filename, extra_flags)
|
56
|
+
dbfile = configuration["database"]
|
57
|
+
flags = extra_flags.join(" ") if extra_flags
|
58
|
+
`sqlite3 #{flags} #{dbfile} < "#{filename}"`
|
42
59
|
end
|
43
60
|
|
44
61
|
private
|
45
62
|
|
46
|
-
|
47
|
-
@configuration
|
48
|
-
end
|
63
|
+
attr_reader :configuration, :root
|
49
64
|
|
50
|
-
|
51
|
-
|
52
|
-
|
65
|
+
def run_cmd(cmd, args, out)
|
66
|
+
fail run_cmd_error(cmd, args) unless Kernel.system(cmd, *args, out: out)
|
67
|
+
end
|
68
|
+
|
69
|
+
def run_cmd_error(cmd, args)
|
70
|
+
msg = +"failed to execute:\n"
|
71
|
+
msg << "#{cmd} #{args.join(' ')}\n\n"
|
72
|
+
msg << "Please check the output above for any errors and make sure that `#{cmd}` is installed in your PATH and has proper permissions.\n\n"
|
73
|
+
msg
|
74
|
+
end
|
53
75
|
end
|
54
76
|
end
|
55
77
|
end
|