aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAkira Matsuda <ronnie@dio.jp>2017-03-13 19:22:03 +0900
committerGitHub <noreply@github.com>2017-03-13 19:22:03 +0900
commit11f10840936a323eda1a9eab02521eff9bdccedb (patch)
tree989a99cba718bda0583cb512a35927d45f05161f
parent097612e8f5bc520bbcdd3c9134a3421eac4d624a (diff)
parentc5f8fe9379dc144a54ceb5663aa449d35d1bf405 (diff)
downloadrails-11f10840936a323eda1a9eab02521eff9bdccedb.tar.gz
rails-11f10840936a323eda1a9eab02521eff9bdccedb.tar.bz2
rails-11f10840936a323eda1a9eab02521eff9bdccedb.zip
Merge pull request #28352 from alpaca-tc/fixes_renderer_with_defaults
Fixes ActionController::Rendering#with_defaults
-rw-r--r--actionpack/CHANGELOG.md6
-rw-r--r--actionpack/lib/action_controller/renderer.rb2
-rw-r--r--actionpack/test/controller/renderer_test.rb10
3 files changed, 17 insertions, 1 deletions
diff --git a/actionpack/CHANGELOG.md b/actionpack/CHANGELOG.md
index 770bda1d44..a0cddbe709 100644
--- a/actionpack/CHANGELOG.md
+++ b/actionpack/CHANGELOG.md
@@ -1,3 +1,9 @@
+* Fix `ActionController::Renderer#with_defaults` does not work
+
+ Fixes `NameError: undefined local variable or method `env'`.
+
+ *Hiroyuki Ishii*
+
* Added `#reverse_merge` and `#reverse_merge!` methods to `ActionController::Parameters`
*Edouard Chin*, *Mitsutaka Mimura*
diff --git a/actionpack/lib/action_controller/renderer.rb b/actionpack/lib/action_controller/renderer.rb
index e1441bd343..3d2edb5242 100644
--- a/actionpack/lib/action_controller/renderer.rb
+++ b/actionpack/lib/action_controller/renderer.rb
@@ -56,7 +56,7 @@ module ActionController
# Create a new renderer for the same controller but with new defaults.
def with_defaults(defaults)
- self.class.new controller, env, self.defaults.merge(defaults)
+ self.class.new controller, @env, self.defaults.merge(defaults)
end
# Accepts a custom Rack environment to render templates in.
diff --git a/actionpack/test/controller/renderer_test.rb b/actionpack/test/controller/renderer_test.rb
index 81b32a67b3..052c974d68 100644
--- a/actionpack/test/controller/renderer_test.rb
+++ b/actionpack/test/controller/renderer_test.rb
@@ -19,6 +19,16 @@ class RendererTest < ActiveSupport::TestCase
assert_equal controller, renderer.controller
end
+ test "creating with new defaults" do
+ renderer = ApplicationController.renderer
+
+ new_defaults = { https: true }
+ new_renderer = renderer.with_defaults(new_defaults).new
+ content = new_renderer.render(inline: "<%= request.ssl? %>")
+
+ assert_equal "true", content
+ end
+
test "rendering with a class renderer" do
renderer = ApplicationController.renderer
content = renderer.render template: "ruby_template"