diff options
author | Jeremy Kemper <jeremy@bitsweat.net> | 2006-09-03 23:34:57 +0000 |
---|---|---|
committer | Jeremy Kemper <jeremy@bitsweat.net> | 2006-09-03 23:34:57 +0000 |
commit | 71dbef6d27210259ae263b84120f94fe9d6784e7 (patch) | |
tree | b863ce62374da9be207a72d89ea53e378585b620 /actionpack/test/controller | |
parent | 8ca3f34db18d23ff26ee71f11a2eba3dcfdff22f (diff) | |
download | rails-71dbef6d27210259ae263b84120f94fe9d6784e7.tar.gz rails-71dbef6d27210259ae263b84120f94fe9d6784e7.tar.bz2 rails-71dbef6d27210259ae263b84120f94fe9d6784e7.zip |
Integration tests: thoroughly test ActionController::Integration::Session. Closes #6022.
git-svn-id: http://svn-commit.rubyonrails.org/rails/trunk@4954 5ecf4fe2-1ee6-0310-87b1-e25e094e27de
Diffstat (limited to 'actionpack/test/controller')
-rw-r--r-- | actionpack/test/controller/base_test.rb | 11 | ||||
-rw-r--r-- | actionpack/test/controller/integration_test.rb | 154 |
2 files changed, 165 insertions, 0 deletions
diff --git a/actionpack/test/controller/base_test.rb b/actionpack/test/controller/base_test.rb index 9cf035d1cb..bcc473263f 100644 --- a/actionpack/test/controller/base_test.rb +++ b/actionpack/test/controller/base_test.rb @@ -74,13 +74,24 @@ class ControllerInstanceTests < Test::Unit::TestCase def test_action_methods @empty_controllers.each do |c| + hide_mocha_methods_from_controller(c) assert_equal Set.new, c.send(:action_methods), "#{c.controller_path} should be empty!" end @non_empty_controllers.each do |c| + hide_mocha_methods_from_controller(c) assert_equal Set.new('public_action'), c.send(:action_methods), "#{c.controller_path} should not be empty!" end end + protected + + # Mocha adds methods to Object which are then included in the public_instance_methods + # This method hides those from the controller so the above tests won't know the difference + def hide_mocha_methods_from_controller(controller) + mocha_methods = [:expects, :metaclass, :mocha, :mocha_inspect, :reset_mocha, :stubba_object, :stubba_method, :stubs, :verify] + controller.class.send(:hide_action, *mocha_methods) + end + end diff --git a/actionpack/test/controller/integration_test.rb b/actionpack/test/controller/integration_test.rb new file mode 100644 index 0000000000..665c5901e5 --- /dev/null +++ b/actionpack/test/controller/integration_test.rb @@ -0,0 +1,154 @@ +require File.dirname(__FILE__) + '/../abstract_unit' + +$:.unshift File.dirname(__FILE__) + '/../../../railties/lib' +require 'action_controller/integration' + +begin # rescue LoadError +require 'mocha' +require 'stubba' + +# Stub process for testing. +module ActionController + module Integration + class Session + def process + end + + def generic_url_rewriter + end + end + end +end + +class SessionTest < Test::Unit::TestCase + def setup + @session = ActionController::Integration::Session.new + end + def test_https_bang_works_and_sets_truth_by_default + assert !@session.https? + @session.https! + assert @session.https? + @session.https! false + assert !@session.https? + end + + def test_host! + assert_not_equal "glu.ttono.us", @session.host + @session.host! "rubyonrails.com" + assert_equal "rubyonrails.com", @session.host + end + + def test_follow_redirect_raises_when_no_redirect + @session.stubs(:redirect?).returns(false) + assert_raise(RuntimeError) { @session.follow_redirect! } + end + + def test_follow_redirect_calls_get_and_returns_status + @session.stubs(:redirect?).returns(true) + @session.stubs(:headers).returns({"location" => ["www.google.com"]}) + @session.stubs(:status).returns(200) + @session.expects(:get) + assert_equal 200, @session.follow_redirect! + end + + def test_get_via_redirect + path = "/somepath"; args = {:id => '1'} + + @session.expects(:get).with(path,args) + + redirects = [true, true, false] + @session.stubs(:redirect?).returns(lambda { redirects.shift }) + @session.expects(:follow_redirect!).times(2) + + @session.stubs(:status).returns(200) + assert_equal 200, @session.get_via_redirect(path, args) + end + + def test_post_via_redirect + path = "/somepath"; args = {:id => '1'} + + @session.expects(:post).with(path,args) + + redirects = [true, true, false] + @session.stubs(:redirect?).returns(lambda { redirects.shift }) + @session.expects(:follow_redirect!).times(2) + + @session.stubs(:status).returns(200) + assert_equal 200, @session.post_via_redirect(path, args) + end + + def test_url_for_with_controller + options = {:action => 'show'} + mock_controller = mock() + mock_controller.expects(:url_for).with(options).returns('/show') + @session.stubs(:controller).returns(mock_controller) + assert_equal '/show', @session.url_for(options) + end + + def test_url_for_without_controller + options = {:action => 'show'} + mock_rewriter = mock() + mock_rewriter.expects(:rewrite).with(options).returns('/show') + @session.stubs(:generic_url_rewriter).returns(mock_rewriter) + @session.stubs(:controller).returns(nil) + assert_equal '/show', @session.url_for(options) + end + + def test_redirect_bool_with_status_in_300s + @session.stubs(:status).returns 301 + assert @session.redirect? + end + + def test_redirect_bool_with_status_in_200s + @session.stubs(:status).returns 200 + assert !@session.redirect? + end + + def test_get + path = "/index"; params = "blah"; headers = {:location => 'blah'} + @session.expects(:process).with(:get,path,params,headers) + @session.get(path,params,headers) + end + + def test_post + path = "/index"; params = "blah"; headers = {:location => 'blah'} + @session.expects(:process).with(:post,path,params,headers) + @session.post(path,params,headers) + end + + def test_put + path = "/index"; params = "blah"; headers = {:location => 'blah'} + @session.expects(:process).with(:put,path,params,headers) + @session.put(path,params,headers) + end + + def test_delete + path = "/index"; params = "blah"; headers = {:location => 'blah'} + @session.expects(:process).with(:delete,path,params,headers) + @session.delete(path,params,headers) + end + + def test_head + path = "/index"; params = "blah"; headers = {:location => 'blah'} + @session.expects(:process).with(:head,path,params,headers) + @session.head(path,params,headers) + end + + def test_xml_http_request + path = "/index"; params = "blah"; headers = {:location => 'blah'} + headers_after_xhr = headers.merge( + "X-Requested-With" => "XMLHttpRequest", + "Accept" => "text/javascript, text/html, application/xml, text/xml, */*" + ) + @session.expects(:post).with(path,params,headers_after_xhr) + @session.xml_http_request(path,params,headers) + end +end + +# TODO +# class MockCGITest < Test::Unit::TestCase +# end + +rescue LoadError + $stderr.puts "Skipping integration tests. `gem install mocha` and try again." +end |