From ebac9154ddfb26b6f68767ff78df4f5c330c5847 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 --- test/webrick/test_ssl_server.rb | 28 ++++++++++++++++++++++++++++ 1 file changed, 28 insertions(+) create mode 100644 test/webrick/test_ssl_server.rb (limited to 'test') 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