diff options
-rw-r--r-- | ChangeLog | 4 | ||||
-rw-r--r-- | test/webrick/test_ssl_server.rb | 28 |
2 files changed, 32 insertions, 0 deletions
@@ -1,3 +1,7 @@ +Sat May 7 21:55:12 2016 SHIBATA Hiroshi <hsbt@ruby-lang.org> + + * test/webrick/test_ssl_server.rb: Added basic test for `webrick/ssl` + Sat May 7 16:22:13 2016 Nobuyoshi Nakada <nobu@ruby-lang.org> * random.c (int_pair_to_real_inclusive): optimize to multiply 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 |