aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--activesupport/lib/active_support/dependencies.rb2
-rw-r--r--activesupport/test/dependencies_test.rb9
2 files changed, 10 insertions, 1 deletions
diff --git a/activesupport/lib/active_support/dependencies.rb b/activesupport/lib/active_support/dependencies.rb
index e845408137..f5d047ee07 100644
--- a/activesupport/lib/active_support/dependencies.rb
+++ b/activesupport/lib/active_support/dependencies.rb
@@ -155,7 +155,7 @@ module Dependencies #:nodoc:
name_error = NameError.new("uninitialized constant #{qualified_name}")
file_path = search_for_autoload_file(path_suffix)
- if file_path # We found a matching file to load
+ if file_path #&& ! loaded.include?(file_path) # We found a matching file to load
require_or_load file_path, qualified_name
raise LoadError, "Expected #{file_path} to define #{qualified_name}" unless from_mod.const_defined?(const_name)
return from_mod.const_get(const_name)
diff --git a/activesupport/test/dependencies_test.rb b/activesupport/test/dependencies_test.rb
index bf9aaac8c1..b607093e8e 100644
--- a/activesupport/test/dependencies_test.rb
+++ b/activesupport/test/dependencies_test.rb
@@ -300,4 +300,13 @@ class DependenciesTest < Test::Unit::TestCase
end
end
+ def test_const_missing_should_not_double_load
+ with_loading 'autoloading_fixtures' do
+ require_dependency 'counting_loader'
+ assert_equal 1, $counting_loaded_times
+ ModuleFolder
+ assert_equal 1, $counting_loaded_times
+ end
+ end
+
end