aboutsummaryrefslogtreecommitdiffstats
path: root/activerecord/lib/active_record/fixtures.rb
diff options
context:
space:
mode:
authorAaron Patterson <aaron.patterson@gmail.com>2013-09-05 14:30:37 -0700
committerAaron Patterson <aaron.patterson@gmail.com>2013-09-05 14:30:37 -0700
commit8588082aecd7dc70ffaf3b54a99184d98c259fce (patch)
treeff288cdeffd8163a7dcbc0ebdfb328f5f2553b94 /activerecord/lib/active_record/fixtures.rb
parent3b351037937199d6dcb95c0db2ed9519f660e353 (diff)
downloadrails-8588082aecd7dc70ffaf3b54a99184d98c259fce.tar.gz
rails-8588082aecd7dc70ffaf3b54a99184d98c259fce.tar.bz2
rails-8588082aecd7dc70ffaf3b54a99184d98c259fce.zip
push constant lookup in the a cache object
Diffstat (limited to 'activerecord/lib/active_record/fixtures.rb')
-rw-r--r--activerecord/lib/active_record/fixtures.rb23
1 files changed, 21 insertions, 2 deletions
diff --git a/activerecord/lib/active_record/fixtures.rb b/activerecord/lib/active_record/fixtures.rb
index 40263b2a70..07a7621c40 100644
--- a/activerecord/lib/active_record/fixtures.rb
+++ b/activerecord/lib/active_record/fixtures.rb
@@ -436,9 +436,26 @@ module ActiveRecord
cattr_accessor :all_loaded_fixtures
self.all_loaded_fixtures = {}
+ class ClassCache
+ def initialize(class_names, config)
+ @class_names = class_names.dup.stringify_keys
+ @config = config
+ end
+
+ def [](fs_name)
+ @class_names[fs_name] ||= default_fixture_model(fs_name, @config).safe_constantize
+ end
+
+ private
+
+ def default_fixture_model(fs_name, config)
+ ActiveRecord::FixtureSet.default_fixture_model_name(fs_name, config)
+ end
+ end
+
def self.create_fixtures(fixtures_directory, fixture_set_names, class_names = {}, config = ActiveRecord::Base)
fixture_set_names = Array(fixture_set_names).map(&:to_s)
- class_names = class_names.stringify_keys
+ class_names = ClassCache.new class_names, config
# FIXME: Apparently JK uses this.
connection = block_given? ? yield : ActiveRecord::Base.connection
@@ -452,10 +469,11 @@ module ActiveRecord
fixtures_map = {}
fixture_sets = files_to_read.map do |fs_name|
+ klass = class_names[fs_name]
fixtures_map[fs_name] = new( # ActiveRecord::FixtureSet.new
connection,
fs_name,
- class_names[fs_name] || (default_fixture_model_name(fs_name, config).safe_constantize),
+ klass,
::File.join(fixtures_directory, fs_name))
end
@@ -613,6 +631,7 @@ module ActiveRecord
end
def handle_habtm(rows, row, association)
+ # This is the case when the join table has no fixtures file
if (targets = row.delete(association.name.to_s))
targets = targets.is_a?(Array) ? targets : targets.split(/\s*,\s*/)
table_name = association.join_table