aboutsummaryrefslogtreecommitdiffstats
path: root/actionpack/test
diff options
context:
space:
mode:
authorJeremy Kemper <jeremy@bitsweat.net>2007-09-23 21:56:22 +0000
committerJeremy Kemper <jeremy@bitsweat.net>2007-09-23 21:56:22 +0000
commita6f49d9b786bfcc049a99f843de8e4d838de1179 (patch)
tree139e2e6e450e64de213294115324ab877802b690 /actionpack/test
parentc61900385452e50bd825f1ab5abef95bc969fadc (diff)
downloadrails-a6f49d9b786bfcc049a99f843de8e4d838de1179.tar.gz
rails-a6f49d9b786bfcc049a99f843de8e4d838de1179.tar.bz2
rails-a6f49d9b786bfcc049a99f843de8e4d838de1179.zip
Introduce ActionController::Base.rescue_from to declare exception-handling methods. Cleaner style than the case-heavy rescue_action_in_public. Closes #9449.
git-svn-id: http://svn-commit.rubyonrails.org/rails/trunk@7597 5ecf4fe2-1ee6-0310-87b1-e25e094e27de
Diffstat (limited to 'actionpack/test')
-rw-r--r--actionpack/test/controller/rescue_test.rb48
1 files changed, 38 insertions, 10 deletions
diff --git a/actionpack/test/controller/rescue_test.rb b/actionpack/test/controller/rescue_test.rb
index 6756e226c3..f0d0526a36 100644
--- a/actionpack/test/controller/rescue_test.rb
+++ b/actionpack/test/controller/rescue_test.rb
@@ -3,6 +3,15 @@ require File.dirname(__FILE__) + '/../abstract_unit'
uses_mocha 'rescue' do
class RescueController < ActionController::Base
+ class NotAuthorized < StandardError
+ end
+
+ class RecordInvalid < StandardError
+ end
+
+ rescue_from NotAuthorized, :with => :deny_access
+ rescue_from RecordInvalid, :with => :show_errors
+
def raises
render :text => 'already rendered'
raise "don't panic!"
@@ -15,10 +24,27 @@ class RescueController < ActionController::Base
def not_implemented
raise ActionController::NotImplemented.new(:get, :put)
end
+
+ def not_authorized
+ raise NotAuthorized
+ end
+
+ def record_invalid
+ raise RecordInvalid
+ end
- def missing_template; end
-end
+ def missing_template
+ end
+
+ protected
+ def deny_access
+ head :forbidden
+ end
+ def show_errors(exception)
+ head :unprocessable_entity
+ end
+end
class RescueTest < Test::Unit::TestCase
FIXTURE_PUBLIC = "#{File.dirname(__FILE__)}/../fixtures".freeze
@@ -38,7 +64,6 @@ class RescueTest < Test::Unit::TestCase
end
end
-
def test_rescue_action_locally_if_all_requests_local
@controller.expects(:local_request?).never
@controller.expects(:rescue_action_locally).with(@exception)
@@ -69,7 +94,6 @@ class RescueTest < Test::Unit::TestCase
end
end
-
def test_rescue_action_in_public_with_error_file
with_rails_root FIXTURE_PUBLIC do
with_all_requests_local false do
@@ -93,7 +117,6 @@ class RescueTest < Test::Unit::TestCase
assert_equal ' ', @response.body
end
-
def test_rescue_unknown_action_in_public_with_error_file
with_rails_root FIXTURE_PUBLIC do
with_all_requests_local false do
@@ -117,7 +140,6 @@ class RescueTest < Test::Unit::TestCase
assert_equal ' ', @response.body
end
-
def test_rescue_missing_template_in_public
with_rails_root FIXTURE_PUBLIC do
with_all_requests_local true do
@@ -129,7 +151,6 @@ class RescueTest < Test::Unit::TestCase
assert @response.body.include?('missing_template'), "Response should include the template name."
end
-
def test_rescue_action_locally
get :raises
assert_response :internal_server_error
@@ -138,7 +159,6 @@ class RescueTest < Test::Unit::TestCase
assert @response.body.include?("don't panic"), "Response should include exception message."
end
-
def test_local_request_when_remote_addr_is_localhost
@controller.expects(:request).returns(@request).at_least_once
with_remote_addr '127.0.0.1' do
@@ -153,7 +173,6 @@ class RescueTest < Test::Unit::TestCase
end
end
-
def test_rescue_responses
responses = ActionController::Base.rescue_responses
@@ -182,7 +201,6 @@ class RescueTest < Test::Unit::TestCase
assert_equal 'template_error', templates[ActionView::TemplateError.name]
end
-
def test_clean_backtrace
with_rails_root nil do
# No action if RAILS_ROOT isn't set.
@@ -217,6 +235,16 @@ class RescueTest < Test::Unit::TestCase
assert_equal "GET, HEAD, PUT", @response.headers['Allow']
end
+ def test_rescue_handler
+ get :not_authorized
+ assert_response :forbidden
+ end
+
+ def test_rescue_handler_with_argument
+ @controller.expects(:show_errors).once.with { |e| e.is_a?(Exception) }
+ get :record_invalid
+ end
+
protected
def with_all_requests_local(local = true)
old_local, ActionController::Base.consider_all_requests_local =