summaryrefslogtreecommitdiff
path: root/test/webrick
diff options
context:
space:
mode:
authorhsbt <hsbt@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2015-03-16 08:43:28 +0000
committerhsbt <hsbt@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2015-03-16 08:43:28 +0000
commit7d75a78604a83a4bd2eb30af4efa9f13c18966f1 (patch)
tree5d89b66df67554e10d107b831c0b850bf3a1ab64 /test/webrick
parentdc37d6dababaf1947d9395ba0610097821906791 (diff)
* lib/webrick/server.rb: Fix regression bug in WEBrick's
:DoNotReverseLookup config option implementation. [fix GH-731] Patch by @vais * test/webrick/test_do_not_reverse_lookup.rb: ditto. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@49980 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'test/webrick')
-rw-r--r--test/webrick/test_do_not_reverse_lookup.rb70
1 files changed, 70 insertions, 0 deletions
diff --git a/test/webrick/test_do_not_reverse_lookup.rb b/test/webrick/test_do_not_reverse_lookup.rb
new file mode 100644
index 0000000000..57f3b1d3ef
--- /dev/null
+++ b/test/webrick/test_do_not_reverse_lookup.rb
@@ -0,0 +1,70 @@
+require "test/unit"
+require "webrick"
+require_relative "utils"
+
+class TestDoNotReverseLookup < Test::Unit::TestCase
+ class DNRL < WEBrick::GenericServer
+ def run(sock)
+ sock << sock.do_not_reverse_lookup.to_s
+ end
+ end
+
+ @@original_do_not_reverse_lookup_value = Socket.do_not_reverse_lookup
+
+ def teardown
+ Socket.do_not_reverse_lookup = @@original_do_not_reverse_lookup_value
+ end
+
+ def do_not_reverse_lookup?(config)
+ result = nil
+ TestWEBrick.start_server(DNRL, config) do |server, addr, port, log|
+ TCPSocket.open(addr, port) do |sock|
+ result = {'true' => true, 'false' => false}[sock.gets]
+ end
+ end
+ result
+ end
+
+ # +--------------------------------------------------------------------------+
+ # | Expected interaction between Socket.do_not_reverse_lookup |
+ # | and WEBrick::Config::General[:DoNotReverseLookup] |
+ # +----------------------------+---------------------------------------------+
+ # | |WEBrick::Config::General[:DoNotReverseLookup]|
+ # +----------------------------+--------------+---------------+--------------+
+ # |Socket.do_not_reverse_lookup| TRUE | FALSE | NIL |
+ # +----------------------------+--------------+---------------+--------------+
+ # | TRUE | true | false | true |
+ # +----------------------------+--------------+---------------+--------------+
+ # | FALSE | true | false | false |
+ # +----------------------------+--------------+---------------+--------------+
+
+ def test_socket_dnrl_true_server_dnrl_true
+ Socket.do_not_reverse_lookup = true
+ assert_equal(true, do_not_reverse_lookup?(:DoNotReverseLookup => true))
+ end
+
+ def test_socket_dnrl_true_server_dnrl_false
+ Socket.do_not_reverse_lookup = true
+ assert_equal(false, do_not_reverse_lookup?(:DoNotReverseLookup => false))
+ end
+
+ def test_socket_dnrl_true_server_dnrl_nil
+ Socket.do_not_reverse_lookup = true
+ assert_equal(true, do_not_reverse_lookup?(:DoNotReverseLookup => nil))
+ end
+
+ def test_socket_dnrl_false_server_dnrl_true
+ Socket.do_not_reverse_lookup = false
+ assert_equal(true, do_not_reverse_lookup?(:DoNotReverseLookup => true))
+ end
+
+ def test_socket_dnrl_false_server_dnrl_false
+ Socket.do_not_reverse_lookup = false
+ assert_equal(false, do_not_reverse_lookup?(:DoNotReverseLookup => false))
+ end
+
+ def test_socket_dnrl_false_server_dnrl_nil
+ Socket.do_not_reverse_lookup = false
+ assert_equal(false, do_not_reverse_lookup?(:DoNotReverseLookup => nil))
+ end
+end