activerecord 7.2.0 → 8.0.0.beta1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/CHANGELOG.md +189 -745
- data/README.rdoc +1 -1
- data/lib/active_record/associations/association.rb +25 -5
- data/lib/active_record/associations/builder/association.rb +7 -6
- data/lib/active_record/associations/collection_association.rb +10 -8
- data/lib/active_record/associations/disable_joins_association_scope.rb +1 -1
- data/lib/active_record/associations/has_many_through_association.rb +3 -2
- data/lib/active_record/associations/join_dependency/join_association.rb +3 -2
- data/lib/active_record/associations/join_dependency.rb +5 -5
- data/lib/active_record/associations/preloader/association.rb +2 -2
- data/lib/active_record/associations/singular_association.rb +8 -3
- data/lib/active_record/associations.rb +34 -4
- data/lib/active_record/asynchronous_queries_tracker.rb +28 -24
- data/lib/active_record/attribute_assignment.rb +9 -1
- data/lib/active_record/attribute_methods/time_zone_conversion.rb +4 -0
- data/lib/active_record/attributes.rb +6 -5
- data/lib/active_record/autosave_association.rb +69 -27
- data/lib/active_record/connection_adapters/abstract/connection_handler.rb +16 -10
- data/lib/active_record/connection_adapters/abstract/connection_pool/queue.rb +0 -1
- data/lib/active_record/connection_adapters/abstract/connection_pool/reaper.rb +0 -1
- data/lib/active_record/connection_adapters/abstract/connection_pool.rb +23 -44
- data/lib/active_record/connection_adapters/abstract/database_statements.rb +90 -43
- data/lib/active_record/connection_adapters/abstract/query_cache.rb +53 -18
- data/lib/active_record/connection_adapters/abstract/quoting.rb +1 -1
- data/lib/active_record/connection_adapters/abstract/schema_definitions.rb +1 -1
- data/lib/active_record/connection_adapters/abstract/schema_statements.rb +26 -5
- data/lib/active_record/connection_adapters/abstract/transaction.rb +15 -5
- data/lib/active_record/connection_adapters/abstract_adapter.rb +24 -25
- data/lib/active_record/connection_adapters/abstract_mysql_adapter.rb +20 -38
- data/lib/active_record/connection_adapters/mysql/quoting.rb +0 -8
- data/lib/active_record/connection_adapters/mysql/schema_definitions.rb +2 -8
- data/lib/active_record/connection_adapters/mysql/schema_statements.rb +44 -46
- data/lib/active_record/connection_adapters/mysql2/database_statements.rb +42 -98
- data/lib/active_record/connection_adapters/mysql2_adapter.rb +1 -8
- data/lib/active_record/connection_adapters/postgresql/database_statements.rb +64 -42
- data/lib/active_record/connection_adapters/postgresql/oid/cidr.rb +1 -1
- data/lib/active_record/connection_adapters/postgresql/oid/point.rb +10 -0
- data/lib/active_record/connection_adapters/postgresql/schema_creation.rb +0 -1
- data/lib/active_record/connection_adapters/postgresql/schema_statements.rb +50 -6
- data/lib/active_record/connection_adapters/postgresql_adapter.rb +38 -90
- data/lib/active_record/connection_adapters/schema_cache.rb +1 -3
- data/lib/active_record/connection_adapters/sqlite3/database_statements.rb +76 -100
- data/lib/active_record/connection_adapters/sqlite3/schema_creation.rb +0 -6
- data/lib/active_record/connection_adapters/sqlite3/schema_dumper.rb +13 -0
- data/lib/active_record/connection_adapters/sqlite3/schema_statements.rb +8 -1
- data/lib/active_record/connection_adapters/sqlite3_adapter.rb +55 -12
- data/lib/active_record/connection_adapters/trilogy/database_statements.rb +37 -67
- data/lib/active_record/connection_adapters/trilogy_adapter.rb +0 -17
- data/lib/active_record/connection_handling.rb +22 -0
- data/lib/active_record/core.rb +16 -9
- data/lib/active_record/database_configurations/connection_url_resolver.rb +1 -1
- data/lib/active_record/encryption/config.rb +3 -1
- data/lib/active_record/encryption/encryptable_record.rb +5 -5
- data/lib/active_record/encryption/encrypted_attribute_type.rb +12 -3
- data/lib/active_record/encryption/encryptor.rb +16 -9
- data/lib/active_record/encryption/extended_deterministic_queries.rb +4 -2
- data/lib/active_record/encryption/key_provider.rb +1 -1
- data/lib/active_record/encryption/scheme.rb +8 -1
- data/lib/active_record/encryption.rb +2 -0
- data/lib/active_record/enum.rb +8 -0
- data/lib/active_record/errors.rb +13 -5
- data/lib/active_record/fixtures.rb +0 -1
- data/lib/active_record/future_result.rb +14 -10
- data/lib/active_record/gem_version.rb +3 -3
- data/lib/active_record/insert_all.rb +1 -1
- data/lib/active_record/migration/command_recorder.rb +22 -5
- data/lib/active_record/migration/compatibility.rb +5 -2
- data/lib/active_record/migration.rb +35 -33
- data/lib/active_record/model_schema.rb +6 -3
- data/lib/active_record/nested_attributes.rb +11 -2
- data/lib/active_record/persistence.rb +128 -130
- data/lib/active_record/query_logs.rb +97 -39
- data/lib/active_record/query_logs_formatter.rb +17 -28
- data/lib/active_record/querying.rb +6 -6
- data/lib/active_record/railtie.rb +8 -14
- data/lib/active_record/reflection.rb +19 -10
- data/lib/active_record/relation/batches/batch_enumerator.rb +4 -3
- data/lib/active_record/relation/batches.rb +135 -75
- data/lib/active_record/relation/calculations.rb +24 -19
- data/lib/active_record/relation/delegation.rb +25 -14
- data/lib/active_record/relation/finder_methods.rb +18 -18
- data/lib/active_record/relation/merger.rb +8 -8
- data/lib/active_record/relation/predicate_builder/polymorphic_array_value.rb +1 -1
- data/lib/active_record/relation/predicate_builder/relation_handler.rb +4 -3
- data/lib/active_record/relation/predicate_builder.rb +6 -1
- data/lib/active_record/relation/query_methods.rb +58 -37
- data/lib/active_record/relation/record_fetch_warning.rb +2 -2
- data/lib/active_record/relation/spawn_methods.rb +1 -1
- data/lib/active_record/relation.rb +72 -61
- data/lib/active_record/result.rb +68 -7
- data/lib/active_record/sanitization.rb +7 -6
- data/lib/active_record/schema_dumper.rb +5 -0
- data/lib/active_record/schema_migration.rb +2 -1
- data/lib/active_record/scoping/named.rb +6 -2
- data/lib/active_record/statement_cache.rb +12 -12
- data/lib/active_record/store.rb +7 -3
- data/lib/active_record/tasks/database_tasks.rb +36 -16
- data/lib/active_record/tasks/mysql_database_tasks.rb +0 -2
- data/lib/active_record/tasks/sqlite_database_tasks.rb +2 -2
- data/lib/active_record/test_fixtures.rb +12 -0
- data/lib/active_record/token_for.rb +1 -1
- data/lib/active_record/validations/uniqueness.rb +9 -8
- data/lib/active_record.rb +15 -0
- data/lib/arel/collectors/bind.rb +1 -1
- metadata +14 -14
@@ -175,37 +175,35 @@ module ActiveRecord
|
|
175
175
|
|
176
176
|
def prepare_all
|
177
177
|
seed = false
|
178
|
+
dump_db_configs = []
|
178
179
|
|
179
180
|
each_current_configuration(env) do |db_config|
|
180
|
-
|
181
|
-
begin
|
182
|
-
database_initialized = migration_connection_pool.schema_migration.table_exists?
|
183
|
-
rescue ActiveRecord::NoDatabaseError
|
184
|
-
create(db_config)
|
185
|
-
retry
|
186
|
-
end
|
187
|
-
|
188
|
-
unless database_initialized
|
189
|
-
if File.exist?(schema_dump_path(db_config))
|
190
|
-
load_schema(db_config, ActiveRecord.schema_format, nil)
|
191
|
-
end
|
181
|
+
database_initialized = initialize_database(db_config)
|
192
182
|
|
193
|
-
|
194
|
-
end
|
195
|
-
end
|
183
|
+
seed = true if database_initialized
|
196
184
|
end
|
197
185
|
|
198
186
|
each_current_environment(env) do |environment|
|
199
187
|
db_configs_with_versions(environment).sort.each do |version, db_configs|
|
188
|
+
dump_db_configs |= db_configs
|
189
|
+
|
200
190
|
db_configs.each do |db_config|
|
201
191
|
with_temporary_pool(db_config) do
|
202
192
|
migrate(version)
|
203
|
-
dump_schema(db_config) if ActiveRecord.dump_schema_after_migration
|
204
193
|
end
|
205
194
|
end
|
206
195
|
end
|
207
196
|
end
|
208
197
|
|
198
|
+
# Dump schema for databases that were migrated.
|
199
|
+
if ActiveRecord.dump_schema_after_migration
|
200
|
+
dump_db_configs.each do |db_config|
|
201
|
+
with_temporary_pool(db_config) do
|
202
|
+
dump_schema(db_config)
|
203
|
+
end
|
204
|
+
end
|
205
|
+
end
|
206
|
+
|
209
207
|
load_seed if seed
|
210
208
|
end
|
211
209
|
|
@@ -248,6 +246,8 @@ module ActiveRecord
|
|
248
246
|
|
249
247
|
check_target_version
|
250
248
|
|
249
|
+
initialize_database(migration_connection_pool.db_config)
|
250
|
+
|
251
251
|
migration_connection_pool.migration_context.migrate(target_version) do |migration|
|
252
252
|
if version.blank?
|
253
253
|
scope.blank? || scope == migration.scope
|
@@ -656,6 +656,26 @@ module ActiveRecord
|
|
656
656
|
rescue ActiveRecord::NoDatabaseError
|
657
657
|
end
|
658
658
|
end
|
659
|
+
|
660
|
+
def initialize_database(db_config)
|
661
|
+
with_temporary_pool(db_config) do
|
662
|
+
begin
|
663
|
+
database_already_initialized = migration_connection_pool.schema_migration.table_exists?
|
664
|
+
rescue ActiveRecord::NoDatabaseError
|
665
|
+
create(db_config)
|
666
|
+
retry
|
667
|
+
end
|
668
|
+
|
669
|
+
unless database_already_initialized
|
670
|
+
schema_dump_path = schema_dump_path(db_config)
|
671
|
+
if schema_dump_path && File.exist?(schema_dump_path)
|
672
|
+
load_schema(db_config, ActiveRecord.schema_format, nil)
|
673
|
+
end
|
674
|
+
end
|
675
|
+
|
676
|
+
!database_already_initialized
|
677
|
+
end
|
678
|
+
end
|
659
679
|
end
|
660
680
|
end
|
661
681
|
end
|
@@ -50,9 +50,9 @@ module ActiveRecord
|
|
50
50
|
if ignore_tables.any?
|
51
51
|
ignore_tables = connection.data_sources.select { |table| ignore_tables.any? { |pattern| pattern === table } }
|
52
52
|
condition = ignore_tables.map { |table| connection.quote(table) }.join(", ")
|
53
|
-
args << "SELECT sql FROM sqlite_master WHERE tbl_name NOT IN (#{condition}) ORDER BY tbl_name, type DESC, name"
|
53
|
+
args << "SELECT sql || ';' FROM sqlite_master WHERE tbl_name NOT IN (#{condition}) ORDER BY tbl_name, type DESC, name"
|
54
54
|
else
|
55
|
-
args << ".schema"
|
55
|
+
args << ".schema --nosys"
|
56
56
|
end
|
57
57
|
run_cmd("sqlite3", args, filename)
|
58
58
|
end
|
@@ -137,12 +137,15 @@ module ActiveRecord
|
|
137
137
|
invalidate_already_loaded_fixtures
|
138
138
|
@loaded_fixtures = load_fixtures(config)
|
139
139
|
end
|
140
|
+
setup_asynchronous_queries_session
|
140
141
|
|
141
142
|
# Instantiate fixtures for every test if requested.
|
142
143
|
instantiate_fixtures if use_instantiated_fixtures
|
143
144
|
end
|
144
145
|
|
145
146
|
def teardown_fixtures
|
147
|
+
teardown_asynchronous_queries_session
|
148
|
+
|
146
149
|
# Rollback changes if a transaction is active.
|
147
150
|
if run_in_transaction?
|
148
151
|
teardown_transactional_fixtures
|
@@ -154,6 +157,14 @@ module ActiveRecord
|
|
154
157
|
ActiveRecord::Base.connection_handler.clear_active_connections!(:all)
|
155
158
|
end
|
156
159
|
|
160
|
+
def setup_asynchronous_queries_session
|
161
|
+
@_async_queries_session = ActiveRecord::Base.asynchronous_queries_tracker.start_session
|
162
|
+
end
|
163
|
+
|
164
|
+
def teardown_asynchronous_queries_session
|
165
|
+
ActiveRecord::Base.asynchronous_queries_tracker.finalize_session(true) if @_async_queries_session
|
166
|
+
end
|
167
|
+
|
157
168
|
def invalidate_already_loaded_fixtures
|
158
169
|
@@already_loaded_fixtures.clear
|
159
170
|
end
|
@@ -190,6 +201,7 @@ module ActiveRecord
|
|
190
201
|
|
191
202
|
def teardown_transactional_fixtures
|
192
203
|
ActiveSupport::Notifications.unsubscribe(@connection_subscriber) if @connection_subscriber
|
204
|
+
|
193
205
|
unless @fixture_connection_pools.map(&:unpin_connection!).all?
|
194
206
|
# Something caused the transaction to be committed or rolled back
|
195
207
|
# We can no longer trust the database is in a clean state.
|
@@ -40,7 +40,7 @@ module ActiveRecord
|
|
40
40
|
# +nil+ if the token is invalid or the record was not found.
|
41
41
|
def find_by_token_for(purpose, token)
|
42
42
|
raise UnknownPrimaryKey.new(self) unless model.primary_key
|
43
|
-
model.token_definitions.fetch(purpose).resolve_token(token) { |id| find_by(model.primary_key => id) }
|
43
|
+
model.token_definitions.fetch(purpose).resolve_token(token) { |id| find_by(model.primary_key => [id]) }
|
44
44
|
end
|
45
45
|
|
46
46
|
# Finds a record using a given +token+ for a predefined +purpose+. Raises
|
@@ -14,6 +14,7 @@ module ActiveRecord
|
|
14
14
|
end
|
15
15
|
super
|
16
16
|
@klass = options[:class]
|
17
|
+
@klass = @klass.superclass if @klass.singleton_class?
|
17
18
|
end
|
18
19
|
|
19
20
|
def validate_each(record, attribute, value)
|
@@ -53,17 +54,17 @@ module ActiveRecord
|
|
53
54
|
private
|
54
55
|
# The check for an existing value should be run from a class that
|
55
56
|
# isn't abstract. This means working down from the current class
|
56
|
-
# (self), to the first non-abstract class.
|
57
|
-
# their subclasses, we have to build the hierarchy between self and
|
58
|
-
# the record's class.
|
57
|
+
# (self), to the first non-abstract class.
|
59
58
|
def find_finder_class_for(record)
|
60
|
-
|
61
|
-
|
62
|
-
|
63
|
-
|
59
|
+
current_class = record.class
|
60
|
+
found_class = nil
|
61
|
+
loop do
|
62
|
+
found_class = current_class unless current_class.abstract_class?
|
63
|
+
break if current_class == @klass
|
64
|
+
current_class = current_class.superclass
|
64
65
|
end
|
65
66
|
|
66
|
-
|
67
|
+
found_class
|
67
68
|
end
|
68
69
|
|
69
70
|
def validation_needed?(klass, record, attribute)
|
data/lib/active_record.rb
CHANGED
@@ -29,6 +29,7 @@ require "active_support/ordered_options"
|
|
29
29
|
require "active_model"
|
30
30
|
require "arel"
|
31
31
|
require "yaml"
|
32
|
+
require "zlib"
|
32
33
|
|
33
34
|
require "active_record/version"
|
34
35
|
require "active_record/deprecator"
|
@@ -196,6 +197,20 @@ module ActiveRecord
|
|
196
197
|
singleton_class.attr_accessor :schema_cache_ignored_tables
|
197
198
|
self.schema_cache_ignored_tables = []
|
198
199
|
|
200
|
+
# Checks to see if the +table_name+ is ignored by checking
|
201
|
+
# against the +schema_cache_ignored_tables+ option.
|
202
|
+
#
|
203
|
+
# ActiveRecord.schema_cache_ignored_table?(:developers)
|
204
|
+
#
|
205
|
+
def self.schema_cache_ignored_table?(table_name)
|
206
|
+
ActiveRecord.schema_cache_ignored_tables.any? do |ignored|
|
207
|
+
ignored === table_name
|
208
|
+
end
|
209
|
+
end
|
210
|
+
|
211
|
+
singleton_class.attr_accessor :database_cli
|
212
|
+
self.database_cli = { postgresql: "psql", mysql: %w[mysql mysql5], sqlite: "sqlite3" }
|
213
|
+
|
199
214
|
singleton_class.attr_reader :default_timezone
|
200
215
|
|
201
216
|
# Determines whether to use Time.utc (using :utc) or Time.local (using :local) when pulling
|
data/lib/arel/collectors/bind.rb
CHANGED
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: activerecord
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version:
|
4
|
+
version: 8.0.0.beta1
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- David Heinemeier Hansson
|
8
|
-
autorequire:
|
8
|
+
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2024-
|
11
|
+
date: 2024-09-26 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: activesupport
|
@@ -16,28 +16,28 @@ dependencies:
|
|
16
16
|
requirements:
|
17
17
|
- - '='
|
18
18
|
- !ruby/object:Gem::Version
|
19
|
-
version:
|
19
|
+
version: 8.0.0.beta1
|
20
20
|
type: :runtime
|
21
21
|
prerelease: false
|
22
22
|
version_requirements: !ruby/object:Gem::Requirement
|
23
23
|
requirements:
|
24
24
|
- - '='
|
25
25
|
- !ruby/object:Gem::Version
|
26
|
-
version:
|
26
|
+
version: 8.0.0.beta1
|
27
27
|
- !ruby/object:Gem::Dependency
|
28
28
|
name: activemodel
|
29
29
|
requirement: !ruby/object:Gem::Requirement
|
30
30
|
requirements:
|
31
31
|
- - '='
|
32
32
|
- !ruby/object:Gem::Version
|
33
|
-
version:
|
33
|
+
version: 8.0.0.beta1
|
34
34
|
type: :runtime
|
35
35
|
prerelease: false
|
36
36
|
version_requirements: !ruby/object:Gem::Requirement
|
37
37
|
requirements:
|
38
38
|
- - '='
|
39
39
|
- !ruby/object:Gem::Version
|
40
|
-
version:
|
40
|
+
version: 8.0.0.beta1
|
41
41
|
- !ruby/object:Gem::Dependency
|
42
42
|
name: timeout
|
43
43
|
requirement: !ruby/object:Gem::Requirement
|
@@ -476,12 +476,12 @@ licenses:
|
|
476
476
|
- MIT
|
477
477
|
metadata:
|
478
478
|
bug_tracker_uri: https://github.com/rails/rails/issues
|
479
|
-
changelog_uri: https://github.com/rails/rails/blob/
|
480
|
-
documentation_uri: https://api.rubyonrails.org/
|
479
|
+
changelog_uri: https://github.com/rails/rails/blob/v8.0.0.beta1/activerecord/CHANGELOG.md
|
480
|
+
documentation_uri: https://api.rubyonrails.org/v8.0.0.beta1/
|
481
481
|
mailing_list_uri: https://discuss.rubyonrails.org/c/rubyonrails-talk
|
482
|
-
source_code_uri: https://github.com/rails/rails/tree/
|
482
|
+
source_code_uri: https://github.com/rails/rails/tree/v8.0.0.beta1/activerecord
|
483
483
|
rubygems_mfa_required: 'true'
|
484
|
-
post_install_message:
|
484
|
+
post_install_message:
|
485
485
|
rdoc_options:
|
486
486
|
- "--main"
|
487
487
|
- README.rdoc
|
@@ -491,15 +491,15 @@ required_ruby_version: !ruby/object:Gem::Requirement
|
|
491
491
|
requirements:
|
492
492
|
- - ">="
|
493
493
|
- !ruby/object:Gem::Version
|
494
|
-
version: 3.
|
494
|
+
version: 3.2.0
|
495
495
|
required_rubygems_version: !ruby/object:Gem::Requirement
|
496
496
|
requirements:
|
497
497
|
- - ">="
|
498
498
|
- !ruby/object:Gem::Version
|
499
499
|
version: '0'
|
500
500
|
requirements: []
|
501
|
-
rubygems_version: 3.5.
|
502
|
-
signing_key:
|
501
|
+
rubygems_version: 3.5.16
|
502
|
+
signing_key:
|
503
503
|
specification_version: 4
|
504
504
|
summary: Object-relational mapper framework (part of Rails).
|
505
505
|
test_files: []
|