Ooops! Fixed upgrade of Rails.
This commit is contained in:
parent
5536e6e79e
commit
bba0cf6b10
177 changed files with 13221 additions and 0 deletions
154
vendor/rails/actionpack/test/controller/integration_test.rb
vendored
Normal file
154
vendor/rails/actionpack/test/controller/integration_test.rb
vendored
Normal file
|
@ -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
|
Loading…
Add table
Add a link
Reference in a new issue