Merge pull request #33 from nbudin/master
Use connection pool instead of actual connection on load (helps with Rails 3.1 on Heroku)
This commit is contained in:
commit
a41050c2b5
|
@ -2,15 +2,15 @@ class ActiveRecord::Base
|
||||||
class << self
|
class << self
|
||||||
def establish_connection_with_activerecord_import(*args)
|
def establish_connection_with_activerecord_import(*args)
|
||||||
establish_connection_without_activerecord_import(*args)
|
establish_connection_without_activerecord_import(*args)
|
||||||
ActiveSupport.run_load_hooks(:active_record_connection_established, connection)
|
ActiveSupport.run_load_hooks(:active_record_connection_established, connection_pool)
|
||||||
end
|
end
|
||||||
alias_method_chain :establish_connection, :activerecord_import
|
alias_method_chain :establish_connection, :activerecord_import
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
ActiveSupport.on_load(:active_record_connection_established) do |connection|
|
ActiveSupport.on_load(:active_record_connection_established) do |connection_pool|
|
||||||
if !ActiveRecord.const_defined?(:Import) || !ActiveRecord::Import.respond_to?(:load_from_connection)
|
if !ActiveRecord.const_defined?(:Import) || !ActiveRecord::Import.respond_to?(:load_from_connection_pool)
|
||||||
require File.join File.dirname(__FILE__), "activerecord-import/base"
|
require File.join File.dirname(__FILE__), "activerecord-import/base"
|
||||||
end
|
end
|
||||||
ActiveRecord::Import.load_from_connection connection
|
ActiveRecord::Import.load_from_connection_pool connection_pool
|
||||||
end
|
end
|
||||||
|
|
|
@ -12,12 +12,8 @@ module ActiveRecord::Import
|
||||||
end
|
end
|
||||||
|
|
||||||
# Loads the import functionality for the passed in ActiveRecord connection
|
# Loads the import functionality for the passed in ActiveRecord connection
|
||||||
def self.load_from_connection(connection)
|
def self.load_from_connection_pool(connection_pool)
|
||||||
import_adapter = "ActiveRecord::Import::#{connection.class.name.demodulize}::InstanceMethods"
|
require_adapter connection_pool.spec.config[:adapter]
|
||||||
unless connection.class.ancestors.map(&:name).include?(import_adapter)
|
|
||||||
config = connection.instance_variable_get :@config
|
|
||||||
require_adapter config[:adapter]
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue