diff options
author | shyouhei <shyouhei@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2007-08-15 19:08:43 +0000 |
---|---|---|
committer | shyouhei <shyouhei@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2007-08-15 19:08:43 +0000 |
commit | d464704f111d211c1f1ff9ef23ef1d755054be00 (patch) | |
tree | b58b17b645dc463322e5fca57fe282360db659c9 /ruby_1_8_5/test/webrick/test_httpauth.rb | |
parent | e4f06b3f2dec4b5d6334c5e9907e1cecbf649fc4 (diff) |
add tag v1_8_5_54
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/tags/v1_8_5_54@12952 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'ruby_1_8_5/test/webrick/test_httpauth.rb')
-rw-r--r-- | ruby_1_8_5/test/webrick/test_httpauth.rb | 82 |
1 files changed, 82 insertions, 0 deletions
diff --git a/ruby_1_8_5/test/webrick/test_httpauth.rb b/ruby_1_8_5/test/webrick/test_httpauth.rb new file mode 100644 index 0000000000..75926b1624 --- /dev/null +++ b/ruby_1_8_5/test/webrick/test_httpauth.rb @@ -0,0 +1,82 @@ +require "test/unit" +require "net/http" +require "tempfile" +require "webrick" +require "webrick/httpauth/basicauth" +require File.join(File.dirname(__FILE__), "utils.rb") + +class TestWEBrickHTTPAuth < Test::Unit::TestCase + def test_basic_auth + TestWEBrick.start_httpserver{|server, addr, port| + 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" + } + res.body = "hoge" + } + http = Net::HTTP.new(addr, port) + g = Net::HTTP::Get.new(path) + g.basic_auth("webrick", "supersecretpassword") + http.request(g){|res| assert_equal("hoge", res.body)} + g.basic_auth("webrick", "not super") + http.request(g){|res| assert_not_equal("hoge", res.body)} + } + end + + def test_basic_auth2 + TestWEBrick.start_httpserver{|server, addr, port| + 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 } + assert_equal(2, users.size) + assert(users.member?("webrick")) + assert(users.member?("foo")) + + 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") + http.request(g){|res| assert_equal("hoge", res.body)} + g.basic_auth("webrick", "not super") + http.request(g){|res| assert_not_equal("hoge", res.body)} + } + end + + def test_basic_auth3 + tmpfile = Tempfile.new("test_webrick_auth") + tmpfile.puts("webrick:{SHA}GJYFRpBbdchp595jlh3Bhfmgp8k=") + tmpfile.flush + assert_raises(NotImplementedError){ + WEBrick::HTTPAuth::Htpasswd.new(tmpfile.path) + } + tmpfile.close(true) + + tmpfile = Tempfile.new("test_webrick_auth") + tmpfile.puts("webrick:$apr1$IOVMD/..$rmnOSPXr0.wwrLPZHBQZy0") + tmpfile.flush + assert_raises(NotImplementedError){ + WEBrick::HTTPAuth::Htpasswd.new(tmpfile.path) + } + tmpfile.close(true) + end +end |