2005-01-03 01:31:13 +03:00
|
|
|
require "test/unit"
|
|
|
|
require "net/http"
|
|
|
|
require "tempfile"
|
|
|
|
require "webrick"
|
|
|
|
require "webrick/httpauth/basicauth"
|
2010-02-02 16:58:56 +03:00
|
|
|
require_relative "utils"
|
2005-01-03 01:31:13 +03:00
|
|
|
|
|
|
|
class TestWEBrickHTTPAuth < Test::Unit::TestCase
|
|
|
|
def test_basic_auth
|
2008-10-29 14:48:35 +03:00
|
|
|
TestWEBrick.start_httpserver{|server, addr, port, log|
|
2005-01-03 01:31:13 +03:00
|
|
|
realm = "WEBrick's realm"
|
|
|
|
path = "/basic_auth"
|
|
|
|
|
|
|
|
server.mount_proc(path){|req, res|
|
|
|
|
WEBrick::HTTPAuth.basic_auth(req, res, realm){|user, pass|
|
|
|
|
user == "webrick" && pass == "supersecretpassword"
|
2009-03-06 06:56:38 +03:00
|
|
|
}
|
2005-01-03 01:31:13 +03:00
|
|
|
res.body = "hoge"
|
|
|
|
}
|
|
|
|
http = Net::HTTP.new(addr, port)
|
|
|
|
g = Net::HTTP::Get.new(path)
|
|
|
|
g.basic_auth("webrick", "supersecretpassword")
|
2008-10-29 14:48:35 +03:00
|
|
|
http.request(g){|res| assert_equal("hoge", res.body, log.call)}
|
2005-01-03 01:31:13 +03:00
|
|
|
g.basic_auth("webrick", "not super")
|
2008-10-29 14:48:35 +03:00
|
|
|
http.request(g){|res| assert_not_equal("hoge", res.body, log.call)}
|
2005-01-03 01:31:13 +03:00
|
|
|
}
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_basic_auth2
|
2008-10-29 14:48:35 +03:00
|
|
|
TestWEBrick.start_httpserver{|server, addr, port, log|
|
2005-01-03 01:31:13 +03:00
|
|
|
realm = "WEBrick's realm"
|
|
|
|
path = "/basic_auth2"
|
|
|
|
|
|
|
|
tmpfile = Tempfile.new("test_webrick_auth")
|
|
|
|
tmpfile.close
|
|
|
|
tmp_pass = WEBrick::HTTPAuth::Htpasswd.new(tmpfile.path)
|
|
|
|
tmp_pass.set_passwd(realm, "webrick", "supersecretpassword")
|
|
|
|
tmp_pass.set_passwd(realm, "foo", "supersecretpassword")
|
|
|
|
tmp_pass.flush
|
|
|
|
|
|
|
|
htpasswd = WEBrick::HTTPAuth::Htpasswd.new(tmpfile.path)
|
|
|
|
users = []
|
|
|
|
htpasswd.each{|user, pass| users << user }
|
2008-10-29 14:48:35 +03:00
|
|
|
assert_equal(2, users.size, log.call)
|
|
|
|
assert(users.member?("webrick"), log.call)
|
|
|
|
assert(users.member?("foo"), log.call)
|
2005-01-03 01:31:13 +03:00
|
|
|
|
|
|
|
server.mount_proc(path){|req, res|
|
|
|
|
auth = WEBrick::HTTPAuth::BasicAuth.new(
|
|
|
|
:Realm => realm, :UserDB => htpasswd,
|
|
|
|
:Logger => server.logger
|
|
|
|
)
|
|
|
|
auth.authenticate(req, res)
|
|
|
|
res.body = "hoge"
|
|
|
|
}
|
|
|
|
http = Net::HTTP.new(addr, port)
|
|
|
|
g = Net::HTTP::Get.new(path)
|
|
|
|
g.basic_auth("webrick", "supersecretpassword")
|
2008-10-29 14:48:35 +03:00
|
|
|
http.request(g){|res| assert_equal("hoge", res.body, log.call)}
|
2005-01-03 01:31:13 +03:00
|
|
|
g.basic_auth("webrick", "not super")
|
2008-10-29 14:48:35 +03:00
|
|
|
http.request(g){|res| assert_not_equal("hoge", res.body, log.call)}
|
2005-01-03 01:31:13 +03:00
|
|
|
}
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_basic_auth3
|
|
|
|
tmpfile = Tempfile.new("test_webrick_auth")
|
|
|
|
tmpfile.puts("webrick:{SHA}GJYFRpBbdchp595jlh3Bhfmgp8k=")
|
|
|
|
tmpfile.flush
|
2008-09-24 21:44:39 +04:00
|
|
|
assert_raise(NotImplementedError){
|
2005-01-03 01:31:13 +03:00
|
|
|
WEBrick::HTTPAuth::Htpasswd.new(tmpfile.path)
|
|
|
|
}
|
|
|
|
tmpfile.close(true)
|
|
|
|
|
|
|
|
tmpfile = Tempfile.new("test_webrick_auth")
|
|
|
|
tmpfile.puts("webrick:$apr1$IOVMD/..$rmnOSPXr0.wwrLPZHBQZy0")
|
|
|
|
tmpfile.flush
|
2008-09-24 21:44:39 +04:00
|
|
|
assert_raise(NotImplementedError){
|
2005-01-03 01:31:13 +03:00
|
|
|
WEBrick::HTTPAuth::Htpasswd.new(tmpfile.path)
|
|
|
|
}
|
|
|
|
tmpfile.close(true)
|
|
|
|
end
|
|
|
|
end
|