summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--ChangeLog9
-rw-r--r--lib/webrick/server.rb8
-rw-r--r--test/webrick/test_server.rb4
3 files changed, 15 insertions, 6 deletions
diff --git a/ChangeLog b/ChangeLog
index 29cdac877d..fd8829eb36 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,12 @@
+Sat Apr 14 10:45:18 2012 NARUSE, Yui <naruse@ruby-lang.org>
+
+ * lib/webrick/server.rb (WEBrick::GenericServer#start):
+ partially revert r35315.
+
+ * test/webrick/test_server.rb (test_start_exception):
+ received signal is delivered to the main thread, so it is needed to
+ emulate it. patched by Eric Hodel. [ruby-core:44348] [Feature #6236]
+
Sat Apr 14 09:35:45 2012 Eric Hodel <drbrain@segment7.net>
* variable.c (trace_ev): Removed "not reached" comment as this line is
diff --git a/lib/webrick/server.rb b/lib/webrick/server.rb
index bd9dcb0d1c..2eabf5d55c 100644
--- a/lib/webrick/server.rb
+++ b/lib/webrick/server.rb
@@ -133,12 +133,12 @@ module WEBrick
rescue Errno::EBADF, IOError => ex
# if the listening socket was closed in GenericServer#shutdown,
# IO::select raise it.
- rescue Interrupt => ex # ^C
- @logger.fatal ex
- raise
- rescue Exception => ex
+ rescue StandardError => ex
msg = "#{ex.class}: #{ex.message}\n\t#{ex.backtrace[0]}"
@logger.error msg
+ rescue Exception => ex
+ @logger.fatal ex
+ raise
end
end
diff --git a/test/webrick/test_server.rb b/test/webrick/test_server.rb
index 86fccac09c..eb13994db7 100644
--- a/test/webrick/test_server.rb
+++ b/test/webrick/test_server.rb
@@ -29,12 +29,12 @@ class TestWEBrickServer < Test::Unit::TestCase
:StopCallback => Proc.new{ stopped += 1 },
}
- e = assert_raises(Interrupt) do
+ e = assert_raises(SignalException) do
TestWEBrick.start_server(Echo, config) { |server, addr, port, log|
listener = server.listeners.first
def listener.accept
- Process.kill(:INT, $$) # simulate ^C
+ raise SignalException, 'SIGTERM' # simulate signal in main thread
end
Thread.pass while server.status != :Running