diff options
| author | Rafael Mendonça França <rafaelmfranca@gmail.com> | 2018-04-20 16:36:34 -0400 | 
|---|---|---|
| committer | Rafael Mendonça França <rafaelmfranca@gmail.com> | 2018-04-20 16:39:02 -0400 | 
| commit | 5033e2c08232a5e6e740fb6c117daeb51d5ef2c1 (patch) | |
| tree | 4842dff29f3805962b09a9483c9e98308659e589 /actionpack/lib/action_dispatch | |
| parent | 1e56b31dd6810806e0f5593311ff624b0eb34443 (diff) | |
| parent | 297a579de4f8cb8d8144b18d85ee370558c0977c (diff) | |
| download | rails-5033e2c08232a5e6e740fb6c117daeb51d5ef2c1.tar.gz rails-5033e2c08232a5e6e740fb6c117daeb51d5ef2c1.tar.bz2 rails-5033e2c08232a5e6e740fb6c117daeb51d5ef2c1.zip | |
Merge pull request #29286 from vinistock/create_missing_exact_template_exception
Create MissingExactTemplate exception with separate template
Diffstat (limited to 'actionpack/lib/action_dispatch')
3 files changed, 29 insertions, 5 deletions
| diff --git a/actionpack/lib/action_dispatch/middleware/exception_wrapper.rb b/actionpack/lib/action_dispatch/middleware/exception_wrapper.rb index d1b4508378..f05c69137b 100644 --- a/actionpack/lib/action_dispatch/middleware/exception_wrapper.rb +++ b/actionpack/lib/action_dispatch/middleware/exception_wrapper.rb @@ -12,6 +12,7 @@ module ActionDispatch        "ActionController::UnknownHttpMethod"          => :method_not_allowed,        "ActionController::NotImplemented"             => :not_implemented,        "ActionController::UnknownFormat"              => :not_acceptable, +      "ActionController::MissingExactTemplate"       => :not_acceptable,        "ActionController::InvalidAuthenticityToken"   => :unprocessable_entity,        "ActionController::InvalidCrossOriginRequest"  => :unprocessable_entity,        "ActionDispatch::Http::Parameters::ParseError" => :bad_request, @@ -22,11 +23,12 @@ module ActionDispatch      )      cattr_accessor :rescue_templates, default: Hash.new("diagnostics").merge!( -      "ActionView::MissingTemplate"         => "missing_template", -      "ActionController::RoutingError"      => "routing_error", -      "AbstractController::ActionNotFound"  => "unknown_action", -      "ActiveRecord::StatementInvalid"      => "invalid_statement", -      "ActionView::Template::Error"         => "template_error" +      "ActionView::MissingTemplate"            => "missing_template", +      "ActionController::RoutingError"         => "routing_error", +      "AbstractController::ActionNotFound"     => "unknown_action", +      "ActiveRecord::StatementInvalid"         => "invalid_statement", +      "ActionView::Template::Error"            => "template_error", +      "ActionController::MissingExactTemplate" => "missing_exact_template",      )      attr_reader :backtrace_cleaner, :exception, :line_number, :file diff --git a/actionpack/lib/action_dispatch/middleware/templates/rescues/missing_exact_template.html.erb b/actionpack/lib/action_dispatch/middleware/templates/rescues/missing_exact_template.html.erb new file mode 100644 index 0000000000..3621ea81de --- /dev/null +++ b/actionpack/lib/action_dispatch/middleware/templates/rescues/missing_exact_template.html.erb @@ -0,0 +1,19 @@ +<header> +  <h1>No template for interactive request</h1> +</header> + +<div id="container"> +  <h3><%= h @exception.message %></h3> + +  <p class="summary"> +    <strong>NOTE!</strong><br> +    Unless told otherwise, Rails expects an action to render a template with the same name,<br> +    contained in a folder named after its controller. + +    If this controller is an API responding with 204 (No Content), <br> +    which does not require a template, +    then this error will occur when trying to access it via browser,<br> +    since we expect an HTML template +    to be rendered for such requests. If that's the case, carry on. +  </p> +</div> diff --git a/actionpack/lib/action_dispatch/middleware/templates/rescues/missing_exact_template.text.erb b/actionpack/lib/action_dispatch/middleware/templates/rescues/missing_exact_template.text.erb new file mode 100644 index 0000000000..fcdbe6069d --- /dev/null +++ b/actionpack/lib/action_dispatch/middleware/templates/rescues/missing_exact_template.text.erb @@ -0,0 +1,3 @@ +Missing exact template + +<%= @exception.message %> | 
