Compare commits

..

3 Commits

Author SHA1 Message Date
David Dollar
7bb1e58879 0.8.0 2010-09-20 16:22:31 -04:00
David Dollar
62b6cac741 print message when signal received 2010-09-20 16:22:13 -04:00
Keith Rarick
2a7dadc2b2 Wait cleanly for child processes to exit.
Signed-off-by: David Dollar <ddollar@gmail.com>
2010-09-20 16:21:41 -04:00
2 changed files with 8 additions and 10 deletions

View File

@@ -1,6 +1,6 @@
module Foreman
VERSION = "0.7.5"
VERSION = "0.8.0"
class AppDoesNotExist < Exception; end

View File

@@ -39,8 +39,8 @@ class Foreman::Engine
fork process, options
end
trap("TERM") { kill_and_exit("TERM") }
trap("INT") { kill_and_exit("INT") }
trap("TERM") { puts "SIGTERM received"; kill_all("TERM") }
trap("INT") { puts "SIGINT received"; kill_all("INT") }
watch_for_termination
end
@@ -48,8 +48,8 @@ class Foreman::Engine
def execute(name, options={})
fork processes[name], options
trap("TERM") { kill_and_exit("TERM") }
trap("INT") { kill_and_exit("INT") }
trap("TERM") { puts "SIGTERM received"; kill_all("TERM") }
trap("INT") { puts "SIGINT received"; kill_all("INT") }
watch_for_termination
end
@@ -97,18 +97,15 @@ private ######################################################################
rescue PTY::ChildExited, Interrupt
info "process exiting", process
end
Process.waitall
end
end
def kill_and_exit(signal="TERM")
def kill_all(signal="TERM")
info "terminating"
running_processes.each do |pid, process|
info "killing #{process.name} in pid #{pid}"
Process.kill(signal, pid)
end
Process.waitall
exit 0
end
def info(message, process=nil)
@@ -151,7 +148,8 @@ private ######################################################################
pid, status = Process.wait2
process = running_processes.delete(pid)
info "process terminated", process
kill_and_exit
kill_all
Process.waitall
end
def running_processes