blob: 861b2cdd46a18fc2798aa10781d1a138cabc0523 [file] [log] [blame]
Brad Bishop19323692019-04-05 15:28:33 -04001From 5d5436dfa3bdde7b4e87ce5a40cbc724199847d6 Mon Sep 17 00:00:00 2001
Brad Bishopd7bf8c12018-02-25 22:55:05 -05002From: Hongxu Jia <hongxu.jia@windriver.com>
3Date: Mon, 8 May 2017 16:18:02 +0800
Brad Bishop1a4b7ee2018-12-16 17:11:34 -08004Subject: [PATCH 03/11] support infinit timeout
Brad Bishopd7bf8c12018-02-25 22:55:05 -05005
6Upstream-Status: Pending
7
8Signed-off-by: Hongxu Jia <hongxu.jia@windriver.com>
9---
10 blivet/util.py | 12 ++++++++----
11 1 file changed, 8 insertions(+), 4 deletions(-)
12
13diff --git a/blivet/util.py b/blivet/util.py
Brad Bishop19323692019-04-05 15:28:33 -040014index 4f05076..7e89949 100644
Brad Bishopd7bf8c12018-02-25 22:55:05 -050015--- a/blivet/util.py
16+++ b/blivet/util.py
Brad Bishop19323692019-04-05 15:28:33 -040017@@ -158,6 +158,7 @@ class Path(str):
Brad Bishopd7bf8c12018-02-25 22:55:05 -050018 def __hash__(self):
19 return self._path.__hash__()
20
21+# timeout = -1 means infinite timeout, always wait.
22 def timeout_command(argv, timeout, *args, **kwargs):
23 """call shell-command and either return its output or kill it
24 if it doesn't normally exit within timeout seconds and return None"""
Brad Bishop19323692019-04-05 15:28:33 -040025@@ -169,7 +170,7 @@ def timeout_command(argv, timeout, *args, **kwargs):
Brad Bishopd7bf8c12018-02-25 22:55:05 -050026 while proc.poll() is None:
27 time.sleep(0.1)
28 now = datetime.datetime.now()
29- if (now - start).seconds> timeout:
30+ if timeout != -1 and (now - start).seconds> timeout:
31 os.kill(proc.pid, signal.SIGKILL)
32 os.waitpid(-1, os.WNOHANG)
33 program_log.debug("%d seconds timeout" % timeout)
Brad Bishop19323692019-04-05 15:28:33 -040034@@ -183,7 +184,7 @@ def timeout_command(argv, timeout, *args, **kwargs):
Brad Bishopd7bf8c12018-02-25 22:55:05 -050035 program_log.debug("Return code: %d", proc.returncode)
36 return (proc.returncode, proc.stdout.read())
37
38-def _run_program(argv, root='/', stdin=None, env_prune=None, stderr_to_stdout=False, binary_output=False):
39+def _run_program(argv, root='/', stdin=None, env_prune=None, stderr_to_stdout=False, binary_output=False, timeout=10):
40 if env_prune is None:
41 env_prune = []
42
Brad Bishop19323692019-04-05 15:28:33 -040043@@ -192,7 +193,10 @@ def _run_program(argv, root='/', stdin=None, env_prune=None, stderr_to_stdout=Fa
Brad Bishopd7bf8c12018-02-25 22:55:05 -050044 os.chroot(root)
45
46 with program_log_lock: # pylint: disable=not-context-manager
47- program_log.info("Running... %s", " ".join(argv))
48+ if timeout != -1:
49+ program_log.info("Running... %s", " ".join(argv))
50+ else:
51+ program_log.info("Running... %s ...infinite timeout", " ".join(argv))
52
53 env = os.environ.copy()
54 env.update({"LC_ALL": "C",
Brad Bishop19323692019-04-05 15:28:33 -040055@@ -205,7 +209,7 @@ def _run_program(argv, root='/', stdin=None, env_prune=None, stderr_to_stdout=Fa
Brad Bishopd7bf8c12018-02-25 22:55:05 -050056 else:
57 stderr_dir = subprocess.PIPE
58
59- res, out = timeout_command(argv, 10,
60+ res, out = timeout_command(argv, timeout,
61 stdin=stdin,
62 stdout=subprocess.PIPE,
63 stderr=stderr_dir,
64--
652.7.4
66