aboutsummaryrefslogtreecommitdiffstats
path: root/actionpack/test
diff options
context:
space:
mode:
authorAaron Patterson <aaron.patterson@gmail.com>2012-10-25 11:34:37 -0700
committerAaron Patterson <aaron.patterson@gmail.com>2012-10-25 11:34:37 -0700
commitcde326bcefa7e842d5f8090d24b700399ac3d705 (patch)
tree2c8a95e838513012aa06803cc02e835258524fab /actionpack/test
parentfacd3e87104b0b9bc1142471b76d7b0c80d7062e (diff)
downloadrails-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.rb14
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({})