diff options
author | Kasper Timm Hansen <kaspth@gmail.com> | 2015-06-27 22:18:17 +0200 |
---|---|---|
committer | Kasper Timm Hansen <kaspth@gmail.com> | 2015-06-27 22:18:17 +0200 |
commit | 991e98f5640874a9bda41855af4f9315aff8260a (patch) | |
tree | 3ac737a8da60859ab97c94707884a033e0bbfffe /actionpack | |
parent | a821ec13f3648218b6b38aa1e41206e4341979d4 (diff) | |
parent | 6fda6c3778b27ea9ca70645bb65956154c2da27b (diff) | |
download | rails-991e98f5640874a9bda41855af4f9315aff8260a.tar.gz rails-991e98f5640874a9bda41855af4f9315aff8260a.tar.bz2 rails-991e98f5640874a9bda41855af4f9315aff8260a.zip |
Merge pull request #20276 from davetron5000/revert-head-on-no-template
Allow default_render to take a block to customize behavior when there's no template
Diffstat (limited to 'actionpack')
-rw-r--r-- | actionpack/lib/action_controller/metal/implicit_render.rb | 19 | ||||
-rw-r--r-- | actionpack/test/controller/mime/respond_to_test.rb | 21 |
2 files changed, 38 insertions, 2 deletions
diff --git a/actionpack/lib/action_controller/metal/implicit_render.rb b/actionpack/lib/action_controller/metal/implicit_render.rb index d66b2214ce..17fcc2fa02 100644 --- a/actionpack/lib/action_controller/metal/implicit_render.rb +++ b/actionpack/lib/action_controller/metal/implicit_render.rb @@ -3,12 +3,27 @@ module ActionController include BasicImplicitRender + # Renders the template corresponding to the controller action, if it exists. + # The action name, format, and variant are all taken into account. + # For example, the "new" action with an HTML format and variant "phone" + # would try to render the <tt>new.html+phone.erb</tt> template. + # + # If no template is found <tt>ActionController::BasicImplicitRender</tt>'s implementation is called, unless + # a block is passed. In that case, it will override the super implementation. + # + # default_render do + # head 404 # No template was found + # end def default_render(*args) if template_exists?(action_name.to_s, _prefixes, variants: request.variant) render(*args) else - logger.info "No template found for #{self.class.name}\##{action_name}, rendering head :no_content" if logger - super + if block_given? + yield(*args) + else + logger.info "No template found for #{self.class.name}\##{action_name}, rendering head :no_content" if logger + super + end end end diff --git a/actionpack/test/controller/mime/respond_to_test.rb b/actionpack/test/controller/mime/respond_to_test.rb index 7aef8a50ce..8591bdb4d9 100644 --- a/actionpack/test/controller/mime/respond_to_test.rb +++ b/actionpack/test/controller/mime/respond_to_test.rb @@ -793,3 +793,24 @@ class RespondToControllerTest < ActionController::TestCase assert_equal "phone", @response.body end end + +class RespondToWithBlockOnDefaultRenderController < ActionController::Base + def show + default_render do + render text: 'default_render yielded' + end + end +end + +class RespondToWithBlockOnDefaultRenderControllerTest < ActionController::TestCase + def setup + super + @request.host = "www.example.com" + end + + def test_default_render_uses_block_when_no_template_exists + get :show + assert_equal "default_render yielded", @response.body + assert_equal "text/html", @response.content_type + end +end |