diff options
author | hsbt <hsbt@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2016-05-07 12:55:17 +0000 |
---|---|---|
committer | hsbt <hsbt@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2016-05-07 12:55:17 +0000 |
commit | b39d4eac28ccbefa519500726dd2af99b5ae27f2 (patch) | |
tree | c52756a077429cda644667ea319c9c9791586a5e /test/webrick | |
parent | ed5b98565095fd1ba39e038a786f1037df1fcca2 (diff) |
* test/webrick/test_ssl_server.rb: Added basic test for `webrick/ssl`
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@54939 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'test/webrick')
-rw-r--r-- | test/webrick/test_ssl_server.rb | 28 |
1 files changed, 28 insertions, 0 deletions
diff --git a/test/webrick/test_ssl_server.rb b/test/webrick/test_ssl_server.rb new file mode 100644 index 0000000000..bbc30cf6d4 --- /dev/null +++ b/test/webrick/test_ssl_server.rb @@ -0,0 +1,28 @@ +require "test/unit" +require "webrick" +require "webrick/ssl" +require_relative "utils" + +class TestWEBrickSSLServer < Test::Unit::TestCase + class Echo < WEBrick::GenericServer + def run(sock) + while line = sock.gets + sock << line + end + end + end + + def test_self_signed_cert_server + config = { + :SSLEnable => true, + :SSLCertName => [["C", "JP"], ["O", "www.ruby-lang.org"], ["CN", "Ruby"]] + } + TestWEBrick.start_server(Echo, config){|server, addr, port, log| + sock = OpenSSL::SSL::SSLSocket.new(TCPSocket.new(addr, port)) + sock.connect + sock.puts(server.ssl_context.cert.subject.to_s) + assert_equal("/C=JP/O=www.ruby-lang.org/CN=Ruby\n", sock.gets, log.call) + sock.close + } + end +end |