From b39d4eac28ccbefa519500726dd2af99b5ae27f2 Mon Sep 17 00:00:00 2001 From: hsbt Date: Sat, 7 May 2016 12:55:17 +0000 Subject: * 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 --- ChangeLog | 4 ++++ test/webrick/test_ssl_server.rb | 28 ++++++++++++++++++++++++++++ 2 files changed, 32 insertions(+) create mode 100644 test/webrick/test_ssl_server.rb diff --git a/ChangeLog b/ChangeLog index c387f26a42..0ebd63ef37 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,7 @@ +Sat May 7 21:55:12 2016 SHIBATA Hiroshi + + * test/webrick/test_ssl_server.rb: Added basic test for `webrick/ssl` + Sat May 7 16:22:13 2016 Nobuyoshi Nakada * 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 -- cgit v1.2.3