aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorhsbt <hsbt@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2016-05-07 12:55:17 +0000
committerhsbt <hsbt@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2016-05-07 12:55:17 +0000
commitb39d4eac28ccbefa519500726dd2af99b5ae27f2 (patch)
treec52756a077429cda644667ea319c9c9791586a5e
parented5b98565095fd1ba39e038a786f1037df1fcca2 (diff)
downloadruby-b39d4eac28ccbefa519500726dd2af99b5ae27f2.tar.gz
* 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
-rw-r--r--ChangeLog4
-rw-r--r--test/webrick/test_ssl_server.rb28
2 files changed, 32 insertions, 0 deletions
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 <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