diff options
author | Eileen M. Uchitelle <eileencodes@users.noreply.github.com> | 2019-06-05 10:01:18 -0400 |
---|---|---|
committer | GitHub <noreply@github.com> | 2019-06-05 10:01:18 -0400 |
commit | 71a019efe8eaaac100640645d14ea6016fff2df7 (patch) | |
tree | 3b7146bdcda9b0509436f22a000d3a504fa0c4ba /activerecord/lib | |
parent | b159cfc414cd2df0a43d14380745ff30000a68d0 (diff) | |
parent | 2f8b397258b66581409b0e6537f98ea9b56e9f19 (diff) | |
download | rails-71a019efe8eaaac100640645d14ea6016fff2df7.tar.gz rails-71a019efe8eaaac100640645d14ea6016fff2df7.tar.bz2 rails-71a019efe8eaaac100640645d14ea6016fff2df7.zip |
Merge pull request #36394 from eileencodes/treat-application-record-as-primary
Treat ActiveRecord::Base and ApplicationRecord as "primary"
Diffstat (limited to 'activerecord/lib')
-rw-r--r-- | activerecord/lib/active_record/connection_handling.rb | 8 |
1 files changed, 6 insertions, 2 deletions
diff --git a/activerecord/lib/active_record/connection_handling.rb b/activerecord/lib/active_record/connection_handling.rb index 040ebdb960..d472eb2e2b 100644 --- a/activerecord/lib/active_record/connection_handling.rb +++ b/activerecord/lib/active_record/connection_handling.rb @@ -173,7 +173,7 @@ module ActiveRecord raise "Anonymous class is not allowed." unless name config_or_env ||= DEFAULT_ENV.call.to_sym - pool_name = self == Base ? "primary" : name + pool_name = primary_class? ? "primary" : name self.connection_specification_name = pool_name resolver = ConnectionAdapters::ConnectionSpecification::Resolver.new(Base.configurations) @@ -204,11 +204,15 @@ module ActiveRecord # Return the specification name from the current class or its parent. def connection_specification_name if !defined?(@connection_specification_name) || @connection_specification_name.nil? - return self == Base ? "primary" : superclass.connection_specification_name + return primary_class? ? "primary" : superclass.connection_specification_name end @connection_specification_name end + def primary_class? # :nodoc: + self == Base || defined?(ApplicationRecord) && self == ApplicationRecord + end + # Returns the configuration of the associated connection as a hash: # # ActiveRecord::Base.connection_config |