2008-06-01 14:25:11 -04:00
|
|
|
require 'abstract_unit'
|
|
|
|
|
2009-01-28 23:50:46 -05:00
|
|
|
# TODO: Merge these tests into RequestTest
|
|
|
|
|
|
|
|
class BaseRackTest < ActiveSupport::TestCase
|
2008-06-01 14:25:11 -04:00
|
|
|
def setup
|
2008-06-02 22:02:26 -04:00
|
|
|
@env = {
|
|
|
|
"HTTP_MAX_FORWARDS" => "10",
|
2008-12-28 12:05:12 -05:00
|
|
|
"SERVER_NAME" => "glu.ttono.us",
|
2008-06-02 22:02:26 -04:00
|
|
|
"FCGI_ROLE" => "RESPONDER",
|
2008-07-01 22:52:28 -04:00
|
|
|
"AUTH_TYPE" => "Basic",
|
2008-06-02 22:02:26 -04:00
|
|
|
"HTTP_X_FORWARDED_HOST" => "glu.ttono.us",
|
2008-07-01 22:52:28 -04:00
|
|
|
"HTTP_ACCEPT_CHARSET" => "UTF-8",
|
2008-06-02 22:02:26 -04:00
|
|
|
"HTTP_ACCEPT_ENCODING" => "gzip, deflate",
|
2008-07-01 22:52:28 -04:00
|
|
|
"HTTP_CACHE_CONTROL" => "no-cache, max-age=0",
|
|
|
|
"HTTP_PRAGMA" => "no-cache",
|
2008-06-02 22:02:26 -04:00
|
|
|
"HTTP_USER_AGENT" => "Mozilla/5.0 (Macintosh; U; PPC Mac OS X; en)",
|
2008-07-01 22:52:28 -04:00
|
|
|
"PATH_INFO" => "/homepage/",
|
2008-06-02 22:02:26 -04:00
|
|
|
"HTTP_ACCEPT_LANGUAGE" => "en",
|
2008-07-01 22:52:28 -04:00
|
|
|
"HTTP_NEGOTIATE" => "trans",
|
2008-06-02 22:02:26 -04:00
|
|
|
"HTTP_HOST" => "glu.ttono.us:8007",
|
2008-07-01 22:52:28 -04:00
|
|
|
"HTTP_REFERER" => "http://www.google.com/search?q=glu.ttono.us",
|
|
|
|
"HTTP_FROM" => "googlebot",
|
2008-06-02 22:02:26 -04:00
|
|
|
"SERVER_PROTOCOL" => "HTTP/1.1",
|
|
|
|
"REDIRECT_URI" => "/dispatch.fcgi",
|
|
|
|
"SCRIPT_NAME" => "/dispatch.fcgi",
|
|
|
|
"SERVER_ADDR" => "207.7.108.53",
|
|
|
|
"REMOTE_ADDR" => "207.7.108.53",
|
2008-07-01 22:52:28 -04:00
|
|
|
"REMOTE_HOST" => "google.com",
|
|
|
|
"REMOTE_IDENT" => "kevin",
|
|
|
|
"REMOTE_USER" => "kevin",
|
2008-06-02 22:02:26 -04:00
|
|
|
"SERVER_SOFTWARE" => "lighttpd/1.4.5",
|
|
|
|
"HTTP_COOKIE" => "_session_id=c84ace84796670c052c6ceb2451fb0f2; is_admin=yes",
|
|
|
|
"HTTP_X_FORWARDED_SERVER" => "glu.ttono.us",
|
|
|
|
"REQUEST_URI" => "/admin",
|
|
|
|
"DOCUMENT_ROOT" => "/home/kevinc/sites/typo/public",
|
2008-07-01 22:52:28 -04:00
|
|
|
"PATH_TRANSLATED" => "/home/kevinc/sites/typo/public/homepage/",
|
2008-06-02 22:02:26 -04:00
|
|
|
"SERVER_PORT" => "8007",
|
|
|
|
"QUERY_STRING" => "",
|
|
|
|
"REMOTE_PORT" => "63137",
|
|
|
|
"GATEWAY_INTERFACE" => "CGI/1.1",
|
|
|
|
"HTTP_X_FORWARDED_FOR" => "65.88.180.234",
|
|
|
|
"HTTP_ACCEPT" => "*/*",
|
|
|
|
"SCRIPT_FILENAME" => "/home/kevinc/sites/typo/public/dispatch.fcgi",
|
|
|
|
"REDIRECT_STATUS" => "200",
|
|
|
|
"REQUEST_METHOD" => "GET"
|
|
|
|
}
|
2009-01-27 19:54:01 -05:00
|
|
|
@request = ActionDispatch::Request.new(@env)
|
2008-06-01 14:25:11 -04:00
|
|
|
# some Nokia phone browsers omit the space after the semicolon separator.
|
|
|
|
# some developers have grown accustomed to using comma in cookie values.
|
2009-01-27 19:54:01 -05:00
|
|
|
@alt_cookie_fmt_request = ActionDispatch::Request.new(@env.merge({"HTTP_COOKIE"=>"_session_id=c84ace847,96670c052c6ceb2451fb0f2;is_admin=yes"}))
|
2008-06-01 14:25:11 -04:00
|
|
|
end
|
|
|
|
|
2008-07-16 00:01:29 -04:00
|
|
|
private
|
2009-01-28 23:50:46 -05:00
|
|
|
def set_content_data(data)
|
|
|
|
@request.env['REQUEST_METHOD'] = 'POST'
|
|
|
|
@request.env['CONTENT_LENGTH'] = data.length
|
|
|
|
@request.env['CONTENT_TYPE'] = 'application/x-www-form-urlencoded; charset=utf-8'
|
|
|
|
@request.env['rack.input'] = StringIO.new(data)
|
|
|
|
end
|
2008-06-01 14:25:11 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
class RackRequestTest < BaseRackTest
|
2009-01-28 23:50:46 -05:00
|
|
|
test "proxy request" do
|
2009-02-02 12:54:23 -05:00
|
|
|
assert_equal 'glu.ttono.us', @request.host_with_port
|
2008-06-01 14:25:11 -04:00
|
|
|
end
|
|
|
|
|
2009-01-28 23:50:46 -05:00
|
|
|
test "http host" do
|
2008-06-01 14:25:11 -04:00
|
|
|
@env.delete "HTTP_X_FORWARDED_HOST"
|
|
|
|
@env['HTTP_HOST'] = "rubyonrails.org:8080"
|
2009-01-27 12:26:07 -05:00
|
|
|
assert_equal "rubyonrails.org", @request.host
|
|
|
|
assert_equal "rubyonrails.org:8080", @request.host_with_port
|
2008-06-01 14:25:11 -04:00
|
|
|
|
|
|
|
@env['HTTP_X_FORWARDED_HOST'] = "www.firsthost.org, www.secondhost.org"
|
2009-01-27 12:26:07 -05:00
|
|
|
assert_equal "www.secondhost.org", @request.host
|
2008-06-01 14:25:11 -04:00
|
|
|
end
|
|
|
|
|
2009-01-28 23:50:46 -05:00
|
|
|
test "http host with default port overrides server port" do
|
2008-06-01 14:25:11 -04:00
|
|
|
@env.delete "HTTP_X_FORWARDED_HOST"
|
|
|
|
@env['HTTP_HOST'] = "rubyonrails.org"
|
2009-01-27 12:26:07 -05:00
|
|
|
assert_equal "rubyonrails.org", @request.host_with_port
|
2008-06-01 14:25:11 -04:00
|
|
|
end
|
|
|
|
|
2009-01-28 23:50:46 -05:00
|
|
|
test "host with port defaults to server name if no host headers" do
|
2008-06-01 14:25:11 -04:00
|
|
|
@env.delete "HTTP_X_FORWARDED_HOST"
|
|
|
|
@env.delete "HTTP_HOST"
|
2009-01-27 12:26:07 -05:00
|
|
|
assert_equal "glu.ttono.us:8007", @request.host_with_port
|
2008-06-01 14:25:11 -04:00
|
|
|
end
|
|
|
|
|
2009-01-28 23:50:46 -05:00
|
|
|
test "host with port falls back to server addr if necessary" do
|
2008-06-01 14:25:11 -04:00
|
|
|
@env.delete "HTTP_X_FORWARDED_HOST"
|
|
|
|
@env.delete "HTTP_HOST"
|
|
|
|
@env.delete "SERVER_NAME"
|
2009-01-27 12:26:07 -05:00
|
|
|
assert_equal "207.7.108.53", @request.host
|
|
|
|
assert_equal 8007, @request.port
|
|
|
|
assert_equal "207.7.108.53:8007", @request.host_with_port
|
2008-06-01 14:25:11 -04:00
|
|
|
end
|
|
|
|
|
2009-01-28 23:50:46 -05:00
|
|
|
test "host with port if http standard port is specified" do
|
2008-06-01 14:25:11 -04:00
|
|
|
@env['HTTP_X_FORWARDED_HOST'] = "glu.ttono.us:80"
|
2009-01-27 12:26:07 -05:00
|
|
|
assert_equal "glu.ttono.us", @request.host_with_port
|
2008-06-01 14:25:11 -04:00
|
|
|
end
|
|
|
|
|
2009-01-28 23:50:46 -05:00
|
|
|
test "host with port if https standard port is specified" do
|
2008-06-01 14:25:11 -04:00
|
|
|
@env['HTTP_X_FORWARDED_PROTO'] = "https"
|
|
|
|
@env['HTTP_X_FORWARDED_HOST'] = "glu.ttono.us:443"
|
2009-01-27 12:26:07 -05:00
|
|
|
assert_equal "glu.ttono.us", @request.host_with_port
|
2008-06-01 14:25:11 -04:00
|
|
|
end
|
|
|
|
|
2009-01-28 23:50:46 -05:00
|
|
|
test "host if ipv6 reference" do
|
2008-06-01 14:25:11 -04:00
|
|
|
@env.delete "HTTP_X_FORWARDED_HOST"
|
|
|
|
@env['HTTP_HOST'] = "[2001:1234:5678:9abc:def0::dead:beef]"
|
2009-01-27 12:26:07 -05:00
|
|
|
assert_equal "[2001:1234:5678:9abc:def0::dead:beef]", @request.host
|
2008-06-01 14:25:11 -04:00
|
|
|
end
|
|
|
|
|
2009-01-28 23:50:46 -05:00
|
|
|
test "host if ipv6 reference with port" do
|
2008-06-01 14:25:11 -04:00
|
|
|
@env.delete "HTTP_X_FORWARDED_HOST"
|
|
|
|
@env['HTTP_HOST'] = "[2001:1234:5678:9abc:def0::dead:beef]:8008"
|
2009-01-27 12:26:07 -05:00
|
|
|
assert_equal "[2001:1234:5678:9abc:def0::dead:beef]", @request.host
|
2008-06-01 14:25:11 -04:00
|
|
|
end
|
|
|
|
|
2009-01-28 23:50:46 -05:00
|
|
|
test "cgi environment variables" do
|
2008-07-01 22:52:28 -04:00
|
|
|
assert_equal "Basic", @request.auth_type
|
|
|
|
assert_equal 0, @request.content_length
|
|
|
|
assert_equal nil, @request.content_type
|
|
|
|
assert_equal "CGI/1.1", @request.gateway_interface
|
|
|
|
assert_equal "*/*", @request.accept
|
|
|
|
assert_equal "UTF-8", @request.accept_charset
|
|
|
|
assert_equal "gzip, deflate", @request.accept_encoding
|
|
|
|
assert_equal "en", @request.accept_language
|
|
|
|
assert_equal "no-cache, max-age=0", @request.cache_control
|
|
|
|
assert_equal "googlebot", @request.from
|
|
|
|
assert_equal "glu.ttono.us", @request.host
|
|
|
|
assert_equal "trans", @request.negotiate
|
|
|
|
assert_equal "no-cache", @request.pragma
|
|
|
|
assert_equal "http://www.google.com/search?q=glu.ttono.us", @request.referer
|
|
|
|
assert_equal "Mozilla/5.0 (Macintosh; U; PPC Mac OS X; en)", @request.user_agent
|
|
|
|
assert_equal "/homepage/", @request.path_info
|
|
|
|
assert_equal "/home/kevinc/sites/typo/public/homepage/", @request.path_translated
|
|
|
|
assert_equal "", @request.query_string
|
|
|
|
assert_equal "207.7.108.53", @request.remote_addr
|
|
|
|
assert_equal "google.com", @request.remote_host
|
|
|
|
assert_equal "kevin", @request.remote_ident
|
|
|
|
assert_equal "kevin", @request.remote_user
|
|
|
|
assert_equal :get, @request.request_method
|
|
|
|
assert_equal "/dispatch.fcgi", @request.script_name
|
2008-12-28 12:05:12 -05:00
|
|
|
assert_equal "glu.ttono.us", @request.server_name
|
2008-07-01 22:52:28 -04:00
|
|
|
assert_equal 8007, @request.server_port
|
|
|
|
assert_equal "HTTP/1.1", @request.server_protocol
|
|
|
|
assert_equal "lighttpd", @request.server_software
|
|
|
|
end
|
|
|
|
|
2009-01-28 23:50:46 -05:00
|
|
|
test "cookie syntax resilience" do
|
2008-06-04 23:32:09 -04:00
|
|
|
cookies = @request.cookies
|
2008-12-07 17:37:48 -05:00
|
|
|
assert_equal "c84ace84796670c052c6ceb2451fb0f2", cookies["_session_id"], cookies.inspect
|
|
|
|
assert_equal "yes", cookies["is_admin"], cookies.inspect
|
2008-06-01 14:25:11 -04:00
|
|
|
|
2008-06-04 23:32:09 -04:00
|
|
|
alt_cookies = @alt_cookie_fmt_request.cookies
|
2008-12-07 17:37:48 -05:00
|
|
|
#assert_equal "c84ace847,96670c052c6ceb2451fb0f2", alt_cookies["_session_id"], alt_cookies.inspect
|
|
|
|
assert_equal "yes", alt_cookies["is_admin"], alt_cookies.inspect
|
2008-06-01 14:25:11 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
class RackRequestParamsParsingTest < BaseRackTest
|
2009-01-28 23:50:46 -05:00
|
|
|
test "doesnt break when content type has charset" do
|
2008-07-16 00:07:34 -04:00
|
|
|
set_content_data 'flamenco=love'
|
|
|
|
|
2008-06-01 14:25:11 -04:00
|
|
|
assert_equal({"flamenco"=> "love"}, @request.request_parameters)
|
|
|
|
end
|
|
|
|
|
2009-01-28 23:50:46 -05:00
|
|
|
test "doesnt interpret request uri as query string when missing" do
|
2008-06-01 14:25:11 -04:00
|
|
|
@request.env['REQUEST_URI'] = 'foo'
|
|
|
|
assert_equal({}, @request.query_parameters)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2008-07-15 22:18:09 -04:00
|
|
|
class RackRequestContentTypeTest < BaseRackTest
|
2009-01-28 23:50:46 -05:00
|
|
|
test "html content type verification" do
|
2008-07-15 22:18:09 -04:00
|
|
|
@request.env['CONTENT_TYPE'] = Mime::HTML.to_s
|
|
|
|
assert @request.content_type.verify_request?
|
|
|
|
end
|
|
|
|
|
2009-01-28 23:50:46 -05:00
|
|
|
test "xml content type verification" do
|
2008-07-15 22:18:09 -04:00
|
|
|
@request.env['CONTENT_TYPE'] = Mime::XML.to_s
|
|
|
|
assert !@request.content_type.verify_request?
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2008-06-01 14:25:11 -04:00
|
|
|
class RackRequestNeedsRewoundTest < BaseRackTest
|
2009-01-28 23:50:46 -05:00
|
|
|
test "body should be rewound" do
|
2008-06-01 14:25:11 -04:00
|
|
|
data = 'foo'
|
|
|
|
@env['rack.input'] = StringIO.new(data)
|
|
|
|
@env['CONTENT_LENGTH'] = data.length
|
|
|
|
@env['CONTENT_TYPE'] = 'application/x-www-form-urlencoded; charset=utf-8'
|
|
|
|
|
|
|
|
# Read the request body by parsing params.
|
2009-01-27 19:54:01 -05:00
|
|
|
request = ActionDispatch::Request.new(@env)
|
2008-06-01 14:25:11 -04:00
|
|
|
request.request_parameters
|
|
|
|
|
|
|
|
# Should have rewound the body.
|
|
|
|
assert_equal 0, request.body.pos
|
|
|
|
end
|
|
|
|
end
|