summaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authordanielsdeleo <dan@getchef.com>2014-03-31 10:24:50 -0700
committerdanielsdeleo <dan@getchef.com>2014-03-31 10:24:50 -0700
commit6faa04e8c173e5c1f029a0d378c991a9a908dc36 (patch)
treee291ec19b3cab03688274122452b068df5fdf516 /lib
parenta6b9916767825b0902059e72025b7e649c61d7fd (diff)
downloadmixlib-shellout-6faa04e8c173e5c1f029a0d378c991a9a908dc36.tar.gz
Handle ESRCH when getting pgid of a zombie on OS X
Diffstat (limited to 'lib')
-rw-r--r--lib/mixlib/shellout/unix.rb18
1 files changed, 17 insertions, 1 deletions
diff --git a/lib/mixlib/shellout/unix.rb b/lib/mixlib/shellout/unix.rb
index e8aa26e..03f619b 100644
--- a/lib/mixlib/shellout/unix.rb
+++ b/lib/mixlib/shellout/unix.rb
@@ -63,7 +63,7 @@ module Mixlib
# CHEF-3390: Marshall.load on Ruby < 1.8.7p369 also has a GC bug related
# to Marshall.load, so try disabling GC first.
propagate_pre_exec_failure
- @child_pgid = -Process.getpgid(@child_pid)
+ get_child_pgid
@result = nil
@execution_time = 0
@@ -107,6 +107,18 @@ module Mixlib
private
+ def get_child_pgid
+ # The behavior of Process.getpgid (see also getpgid(2) ) when the
+ # argument is the pid of a zombie isn't well specified. On Linux it
+ # works, on OS X it returns ESRCH (which ruby turns into Errno::ESRCH).
+ #
+ # If the child dies very quickly, @child_pid may be a zombie, so handle
+ # ESRCH here.
+ @child_pgid = -Process.getpgid(@child_pid)
+ rescue Errno::ESRCH
+ @child_pgid = nil
+ end
+
def set_user
if user
Process.euid = uid
@@ -137,6 +149,10 @@ module Mixlib
# Process group id of the child. Returned as a negative value so you can
# put it directly in arguments to kill, wait, etc.
+ #
+ # This may be nil if the child dies before the parent can query the
+ # system for its pgid (on some systems it is an error to get the pgid of
+ # a zombie).
def child_pgid
@child_pgid
end