mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
fix tests.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@24869 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
efa4ed8cce
commit
0ab4b21d81
1 changed files with 61 additions and 28 deletions
|
@ -118,79 +118,81 @@ class TestOpenURI < Test::Unit::TestCase
|
||||||
|
|
||||||
def test_proxy
|
def test_proxy
|
||||||
with_http {|srv, dr, url|
|
with_http {|srv, dr, url|
|
||||||
prxy = WEBrick::HTTPProxyServer.new({
|
log = ''
|
||||||
|
proxy = WEBrick::HTTPProxyServer.new({
|
||||||
:ServerType => Thread,
|
:ServerType => Thread,
|
||||||
:Logger => WEBrick::Log.new(NullLog),
|
:Logger => WEBrick::Log.new(NullLog),
|
||||||
:AccessLog => [[sio=StringIO.new, WEBrick::AccessLog::COMMON_LOG_FORMAT]],
|
:AccessLog => [[NullLog, ""]],
|
||||||
|
:ProxyAuthProc => lambda {|req, res|
|
||||||
|
log << req.request_line
|
||||||
|
},
|
||||||
:BindAddress => '127.0.0.1',
|
:BindAddress => '127.0.0.1',
|
||||||
:Port => 0})
|
:Port => 0})
|
||||||
_, p_port, _, p_host = prxy.listeners[0].addr
|
_, proxy_port, _, proxy_host = proxy.listeners[0].addr
|
||||||
begin
|
begin
|
||||||
th = prxy.start
|
th = proxy.start
|
||||||
open("#{dr}/proxy", "w") {|f| f << "proxy" }
|
open("#{dr}/proxy", "w") {|f| f << "proxy" }
|
||||||
open("#{url}/proxy", :proxy=>"http://#{p_host}:#{p_port}/") {|f|
|
open("#{url}/proxy", :proxy=>"http://#{proxy_host}:#{proxy_port}/") {|f|
|
||||||
assert_equal("200", f.status[0])
|
assert_equal("200", f.status[0])
|
||||||
assert_equal("proxy", f.read)
|
assert_equal("proxy", f.read)
|
||||||
}
|
}
|
||||||
assert_match(/#{Regexp.quote url}/, sio.string)
|
assert_match(/#{Regexp.quote url}/, log); log.clear
|
||||||
sio.truncate(0); sio.rewind
|
open("#{url}/proxy", :proxy=>URI("http://#{proxy_host}:#{proxy_port}/")) {|f|
|
||||||
open("#{url}/proxy", :proxy=>URI("http://#{p_host}:#{p_port}/")) {|f|
|
|
||||||
assert_equal("200", f.status[0])
|
assert_equal("200", f.status[0])
|
||||||
assert_equal("proxy", f.read)
|
assert_equal("proxy", f.read)
|
||||||
}
|
}
|
||||||
assert_match(/#{Regexp.quote url}/, sio.string)
|
assert_match(/#{Regexp.quote url}/, log); log.clear
|
||||||
sio.truncate(0); sio.rewind
|
|
||||||
open("#{url}/proxy", :proxy=>nil) {|f|
|
open("#{url}/proxy", :proxy=>nil) {|f|
|
||||||
assert_equal("200", f.status[0])
|
assert_equal("200", f.status[0])
|
||||||
assert_equal("proxy", f.read)
|
assert_equal("proxy", f.read)
|
||||||
}
|
}
|
||||||
assert_equal("", sio.string)
|
assert_equal("", log); log.clear
|
||||||
assert_raise(ArgumentError) {
|
assert_raise(ArgumentError) {
|
||||||
open("#{url}/proxy", :proxy=>:invalid) {}
|
open("#{url}/proxy", :proxy=>:invalid) {}
|
||||||
}
|
}
|
||||||
assert_equal("", sio.string)
|
assert_equal("", log); log.clear
|
||||||
ensure
|
ensure
|
||||||
prxy.shutdown
|
proxy.shutdown
|
||||||
end
|
end
|
||||||
}
|
}
|
||||||
end
|
end
|
||||||
|
|
||||||
def test_proxy_http_basic_authentication
|
def test_proxy_http_basic_authentication
|
||||||
with_http {|srv, dr, url|
|
with_http {|srv, dr, url|
|
||||||
prxy = WEBrick::HTTPProxyServer.new({
|
log = ''
|
||||||
|
proxy = WEBrick::HTTPProxyServer.new({
|
||||||
:ServerType => Thread,
|
:ServerType => Thread,
|
||||||
:Logger => WEBrick::Log.new(NullLog),
|
:Logger => WEBrick::Log.new(NullLog),
|
||||||
:AccessLog => [[sio=StringIO.new, WEBrick::AccessLog::COMMON_LOG_FORMAT]],
|
:AccessLog => [[NullLog, ""]],
|
||||||
:ProxyAuthProc => lambda {|req, res|
|
:ProxyAuthProc => lambda {|req, res|
|
||||||
|
log << req.request_line
|
||||||
if req["Proxy-Authorization"] != "Basic #{['user:pass'].pack('m').chomp}"
|
if req["Proxy-Authorization"] != "Basic #{['user:pass'].pack('m').chomp}"
|
||||||
raise WEBrick::HTTPStatus::ProxyAuthenticationRequired
|
raise WEBrick::HTTPStatus::ProxyAuthenticationRequired
|
||||||
end
|
end
|
||||||
},
|
},
|
||||||
:BindAddress => '127.0.0.1',
|
:BindAddress => '127.0.0.1',
|
||||||
:Port => 0})
|
:Port => 0})
|
||||||
_, p_port, _, p_host = prxy.listeners[0].addr
|
_, proxy_port, _, proxy_host = proxy.listeners[0].addr
|
||||||
p_url = "http://#{p_host}:#{p_port}/"
|
proxy_url = "http://#{proxy_host}:#{proxy_port}/"
|
||||||
begin
|
begin
|
||||||
th = prxy.start
|
th = proxy.start
|
||||||
open("#{dr}/proxy", "w") {|f| f << "proxy" }
|
open("#{dr}/proxy", "w") {|f| f << "proxy" }
|
||||||
exc = assert_raise(OpenURI::HTTPError) { open("#{url}/proxy", :proxy=>p_url) {} }
|
exc = assert_raise(OpenURI::HTTPError) { open("#{url}/proxy", :proxy=>proxy_url) {} }
|
||||||
assert_equal("407", exc.io.status[0])
|
assert_equal("407", exc.io.status[0])
|
||||||
assert_match(/#{Regexp.quote url}/, sio.string)
|
assert_match(/#{Regexp.quote url}/, log); log.clear
|
||||||
sio.truncate(0); sio.rewind
|
|
||||||
open("#{url}/proxy",
|
open("#{url}/proxy",
|
||||||
:proxy_http_basic_authentication=>[p_url, "user", "pass"]) {|f|
|
:proxy_http_basic_authentication=>[proxy_url, "user", "pass"]) {|f|
|
||||||
assert_equal("200", f.status[0])
|
assert_equal("200", f.status[0])
|
||||||
assert_equal("proxy", f.read)
|
assert_equal("proxy", f.read)
|
||||||
}
|
}
|
||||||
assert_match(/#{Regexp.quote url}/, sio.string)
|
assert_match(/#{Regexp.quote url}/, log); log.clear
|
||||||
sio.truncate(0); sio.rewind
|
|
||||||
assert_raise(ArgumentError) {
|
assert_raise(ArgumentError) {
|
||||||
open("#{url}/proxy",
|
open("#{url}/proxy",
|
||||||
:proxy_http_basic_authentication=>[true, "user", "pass"]) {}
|
:proxy_http_basic_authentication=>[true, "user", "pass"]) {}
|
||||||
}
|
}
|
||||||
assert_equal("", sio.string)
|
assert_equal("", log); log.clear
|
||||||
ensure
|
ensure
|
||||||
prxy.shutdown
|
proxy.shutdown
|
||||||
end
|
end
|
||||||
}
|
}
|
||||||
end
|
end
|
||||||
|
@ -209,6 +211,39 @@ class TestOpenURI < Test::Unit::TestCase
|
||||||
}
|
}
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def test_redirect_relative
|
||||||
|
TCPServer.open("127.0.0.1", 0) {|serv|
|
||||||
|
port = serv.addr[1]
|
||||||
|
th = Thread.new {
|
||||||
|
sock = serv.accept
|
||||||
|
begin
|
||||||
|
req = sock.gets("\r\n\r\n")
|
||||||
|
assert_match(%r{\AGET /foo/bar }, req)
|
||||||
|
sock.print "HTTP/1.0 302 Found\r\n"
|
||||||
|
sock.print "Location: ../baz\r\n\r\n"
|
||||||
|
ensure
|
||||||
|
sock.close
|
||||||
|
end
|
||||||
|
sock = serv.accept
|
||||||
|
begin
|
||||||
|
req = sock.gets("\r\n\r\n")
|
||||||
|
assert_match(%r{\AGET /baz }, req)
|
||||||
|
sock.print "HTTP/1.0 200 OK\r\n"
|
||||||
|
sock.print "Content-Length: 4\r\n\r\n"
|
||||||
|
sock.print "ab\r\n"
|
||||||
|
ensure
|
||||||
|
sock.close
|
||||||
|
end
|
||||||
|
}
|
||||||
|
begin
|
||||||
|
content = URI("http://127.0.0.1:#{port}/foo/bar").read
|
||||||
|
assert_equal("ab\r\n", content)
|
||||||
|
ensure
|
||||||
|
Thread.kill(th)
|
||||||
|
end
|
||||||
|
}
|
||||||
|
end
|
||||||
|
|
||||||
def test_redirect_auth
|
def test_redirect_auth
|
||||||
with_http {|srv, dr, url|
|
with_http {|srv, dr, url|
|
||||||
srv.mount_proc("/r1/") {|req, res| res.status = 301; res["location"] = "#{url}/r2" }
|
srv.mount_proc("/r1/") {|req, res| res.status = 301; res["location"] = "#{url}/r2" }
|
||||||
|
@ -436,7 +471,6 @@ class TestOpenURI < Test::Unit::TestCase
|
||||||
proxy_sock.print "HTTP/1.0 200 OK\r\n"
|
proxy_sock.print "HTTP/1.0 200 OK\r\n"
|
||||||
proxy_sock.print "Content-Length: 4\r\n\r\n"
|
proxy_sock.print "Content-Length: 4\r\n\r\n"
|
||||||
proxy_sock.print "ab\r\n"
|
proxy_sock.print "ab\r\n"
|
||||||
proxy_sock.close
|
|
||||||
ensure
|
ensure
|
||||||
proxy_sock.close
|
proxy_sock.close
|
||||||
end
|
end
|
||||||
|
@ -464,7 +498,6 @@ class TestOpenURI < Test::Unit::TestCase
|
||||||
proxy_sock.print "HTTP/1.0 200 OK\r\n"
|
proxy_sock.print "HTTP/1.0 200 OK\r\n"
|
||||||
proxy_sock.print "Content-Length: 4\r\n\r\n"
|
proxy_sock.print "Content-Length: 4\r\n\r\n"
|
||||||
proxy_sock.print "ab\r\n"
|
proxy_sock.print "ab\r\n"
|
||||||
proxy_sock.close
|
|
||||||
ensure
|
ensure
|
||||||
proxy_sock.close
|
proxy_sock.close
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in a new issue