summaryrefslogtreecommitdiff
path: root/test/xmlrpc/webrick_testing.rb
diff options
context:
space:
mode:
authormneumann <mneumann@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2004-12-21 16:23:33 +0000
committermneumann <mneumann@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2004-12-21 16:23:33 +0000
commite537aaba91ac5ad8a554b155afbcc2d0efb50f66 (patch)
treeadc5962295bc5a7c3d00bda294dde0f23ac54117 /test/xmlrpc/webrick_testing.rb
parentd1be7e2cd30dafd729674c1578a2796f766d4b31 (diff)
* lib/xmlrpc/client.rb: use "" instead of "." if prefix argument is
nil in proxy methods. nil is default value. * test/xmlrpc/test_webrick_server.rb, test/xmlrpc/webrick_testing.rb: use threads instead of forking. this should fix issue #1208 (http://rubyforge.org/tracker/?func=detail&atid=1698&aid=1208&group_id=426). removed testing of SSL enabled servlet as this hangs. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@7630 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'test/xmlrpc/webrick_testing.rb')
-rw-r--r--test/xmlrpc/webrick_testing.rb30
1 files changed, 15 insertions, 15 deletions
diff --git a/test/xmlrpc/webrick_testing.rb b/test/xmlrpc/webrick_testing.rb
index d8b3a864c84..a6830cece1c 100644
--- a/test/xmlrpc/webrick_testing.rb
+++ b/test/xmlrpc/webrick_testing.rb
@@ -7,20 +7,20 @@ module WEBrick_Testing
end
def start_server(config={})
- raise "already started" if @__server_pid or @__started
- trap('HUP') { @__started = true }
- @__server_pid = fork do
- w = WEBrick::HTTPServer.new(
+ raise "already started" if @__server
+ @__started = false
+
+ Thread.new {
+ @__server = WEBrick::HTTPServer.new(
{
:Logger => DummyLog.new,
:AccessLog => [],
- :StartCallback => proc { Process.kill('HUP', Process.ppid) }
+ :StartCallback => proc { @__started = true }
}.update(config))
- yield w
- trap('INT') { w.shutdown }
- w.start
- exit
- end
+ yield @__server
+ @__server.start
+ @__started = false
+ }
Timeout.timeout(5) {
nil until @__started # wait until the server is ready
@@ -28,10 +28,10 @@ module WEBrick_Testing
end
def stop_server
- Process.kill('INT', @__server_pid)
- @__server_pid = nil
- @__started = false
- Process.wait
- raise unless $?.success?
+ Timeout.timeout(5) {
+ @__server.shutdown
+ nil while @__started # wait until the server is down
+ }
+ @__server = nil
end
end