diff options
author | Aaron Patterson <aaron.patterson@gmail.com> | 2012-10-25 11:34:37 -0700 |
---|---|---|
committer | Aaron Patterson <aaron.patterson@gmail.com> | 2012-10-25 11:34:37 -0700 |
commit | cde326bcefa7e842d5f8090d24b700399ac3d705 (patch) | |
tree | 2c8a95e838513012aa06803cc02e835258524fab /actionpack/test | |
parent | facd3e87104b0b9bc1142471b76d7b0c80d7062e (diff) | |
download | rails-cde326bcefa7e842d5f8090d24b700399ac3d705.tar.gz rails-cde326bcefa7e842d5f8090d24b700399ac3d705.tar.bz2 rails-cde326bcefa7e842d5f8090d24b700399ac3d705.zip |
give access to the original exception raised in case of a parse error
Diffstat (limited to 'actionpack/test')
-rw-r--r-- | actionpack/test/dispatch/request_test.rb | 14 |
1 files changed, 14 insertions, 0 deletions
diff --git a/actionpack/test/dispatch/request_test.rb b/actionpack/test/dispatch/request_test.rb index 26db91c741..e2964f9071 100644 --- a/actionpack/test/dispatch/request_test.rb +++ b/actionpack/test/dispatch/request_test.rb @@ -560,6 +560,20 @@ class RequestTest < ActiveSupport::TestCase assert_equal({}, request.parameters) end + test "we have access to the original exception" do + mock_rack_env = { "QUERY_STRING" => "x[y]=1&x[y][][w]=2", "rack.input" => "foo" } + request = nil + request = stub_request(mock_rack_env) + + e = assert_raises(ActionController::BadRequest) do + # rack will raise a TypeError when parsing this query string + request.parameters + end + + assert e.original_exception + assert_equal e.original_exception.backtrace, e.backtrace + end + test "formats with accept header" do request = stub_request 'HTTP_ACCEPT' => 'text/html' request.expects(:parameters).at_least_once.returns({}) |