diff options
author | Yuki Nishijima <mail@yukinishijima.net> | 2014-11-23 13:04:31 -0800 |
---|---|---|
committer | Yuki Nishijima <mail@yukinishijima.net> | 2014-11-23 13:47:09 -0800 |
commit | 1d85c707b633b6ed1623290fa9aff5d7fd74d05e (patch) | |
tree | 0ed2c35481faa20f7ac08767ed5289db99c8b55a /actionpack | |
parent | c837259ae422a659b2a71e6f29e3a4f3ea049f05 (diff) | |
download | rails-1d85c707b633b6ed1623290fa9aff5d7fd74d05e.tar.gz rails-1d85c707b633b6ed1623290fa9aff5d7fd74d05e.tar.bz2 rails-1d85c707b633b6ed1623290fa9aff5d7fd74d05e.zip |
Do not rescue Exception in ParamsParser
Unlike ShowExceptions or PublicExceptions, ParamsParser shouldn't
transform exceptions like Interrupt and NoMemoryError into ParserError.
Diffstat (limited to 'actionpack')
-rw-r--r-- | actionpack/lib/action_dispatch/middleware/params_parser.rb | 2 | ||||
-rw-r--r-- | actionpack/test/controller/webservice_test.rb | 10 |
2 files changed, 11 insertions, 1 deletions
diff --git a/actionpack/lib/action_dispatch/middleware/params_parser.rb b/actionpack/lib/action_dispatch/middleware/params_parser.rb index b426183488..29d43faeed 100644 --- a/actionpack/lib/action_dispatch/middleware/params_parser.rb +++ b/actionpack/lib/action_dispatch/middleware/params_parser.rb @@ -47,7 +47,7 @@ module ActionDispatch else false end - rescue Exception => e # JSON or Ruby code block errors + rescue => e # JSON or Ruby code block errors logger(env).debug "Error occurred while parsing request parameters.\nContents:\n\n#{request.raw_post}" raise ParseError.new(e.message, e) diff --git a/actionpack/test/controller/webservice_test.rb b/actionpack/test/controller/webservice_test.rb index d80b0e2da0..2b109ff19e 100644 --- a/actionpack/test/controller/webservice_test.rb +++ b/actionpack/test/controller/webservice_test.rb @@ -83,6 +83,16 @@ class WebServiceTest < ActionDispatch::IntegrationTest end end + def test_parsing_json_doesnot_rescue_exception + with_test_route_set do + with_params_parsers Mime::JSON => Proc.new { |data| raise Interrupt } do + assert_raises(Interrupt) do + post "/", '{"title":"JSON"}}', 'CONTENT_TYPE' => 'application/json' + end + end + end + end + private def with_params_parsers(parsers = {}) old_session = @integration_session |