activerecord 7.2.0 → 8.0.0.beta1
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 +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: []
|