aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAaron Patterson <aaron.patterson@gmail.com>2011-03-02 10:11:28 -0800
committerAaron Patterson <aaron.patterson@gmail.com>2011-03-02 10:11:28 -0800
commit1f2e7214aaed01f50be12017f0ffbf9fcdbdbb5e (patch)
tree8c2e018812b254493998e37eb03c8e4a710369c0
parent91983724211b0e654c9e79e73bacf10a65adf172 (diff)
downloadrails-1f2e7214aaed01f50be12017f0ffbf9fcdbdbb5e.tar.gz
rails-1f2e7214aaed01f50be12017f0ffbf9fcdbdbb5e.tar.bz2
rails-1f2e7214aaed01f50be12017f0ffbf9fcdbdbb5e.zip
make sure string keys are always looked up from the class cache
-rw-r--r--actionpack/lib/action_dispatch/middleware/stack.rb5
-rw-r--r--actionpack/test/dispatch/middleware_stack/middleware_test.rb25
2 files changed, 28 insertions, 2 deletions
diff --git a/actionpack/lib/action_dispatch/middleware/stack.rb b/actionpack/lib/action_dispatch/middleware/stack.rb
index d9bfd3d573..a4308f528c 100644
--- a/actionpack/lib/action_dispatch/middleware/stack.rb
+++ b/actionpack/lib/action_dispatch/middleware/stack.rb
@@ -4,7 +4,7 @@ require "active_support/dependencies"
module ActionDispatch
class MiddlewareStack
class Middleware
- attr_reader :args, :block
+ attr_reader :args, :block, :name, :classcache
def initialize(klass_or_name, *args, &block)
@klass = nil
@@ -16,11 +16,12 @@ module ActionDispatch
@name = klass_or_name.to_s
end
+ @classcache = ActiveSupport::Dependencies::Reference
@args, @block = args, block
end
def klass
- @klass ||= ActiveSupport::Inflector.constantize(@name)
+ @klass || classcache[@name]
end
def ==(middleware)
diff --git a/actionpack/test/dispatch/middleware_stack/middleware_test.rb b/actionpack/test/dispatch/middleware_stack/middleware_test.rb
index 4e16fdbc77..9607f026db 100644
--- a/actionpack/test/dispatch/middleware_stack/middleware_test.rb
+++ b/actionpack/test/dispatch/middleware_stack/middleware_test.rb
@@ -47,6 +47,31 @@ module ActionDispatch
mw = Middleware.new Omg
assert_operator mw, :==, "::#{Omg.name}"
end
+
+ def test_middleware_loads_classnames_from_cache
+ mw = Class.new(Middleware) {
+ attr_accessor :classcache
+ }.new(Omg.name)
+
+ fake_cache = { mw.name => Omg }
+ mw.classcache = fake_cache
+
+ assert_equal Omg, mw.klass
+
+ fake_cache[mw.name] = Middleware
+ assert_equal Middleware, mw.klass
+ end
+
+ def test_middleware_always_returns_class
+ mw = Class.new(Middleware) {
+ attr_accessor :classcache
+ }.new(Omg)
+
+ fake_cache = { mw.name => Middleware }
+ mw.classcache = fake_cache
+
+ assert_equal Omg, mw.klass
+ end
end
end
end