mirror of
git://git.yoctoproject.org/poky.git
synced 2025-07-19 21:09:03 +02:00

Out of the box subprocess.CalledProcessError.__str__() just displays the command and exit code, which isn't very useful for debugging. Add a function to oeqa.utils.subprocesstweak to monkey-patch __str__() so that it can also display the value of stdout and stderr. (From OE-Core rev: c55401ba1646202fa36e4973b05dbacaa146cb16) Signed-off-by: Ross Burton <ross.burton@intel.com> Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
20 lines
694 B
Python
20 lines
694 B
Python
import subprocess
|
|
|
|
class OETestCalledProcessError(subprocess.CalledProcessError):
|
|
def __str__(self):
|
|
def strify(o):
|
|
if isinstance(o, bytes):
|
|
return o.decode("utf-8", errors="replace")
|
|
else:
|
|
return o
|
|
|
|
s = "Command '%s' returned non-zero exit status %d" % (self.cmd, self.returncode)
|
|
if hasattr(self, "output") and self.output:
|
|
s = s + "\nStandard Output: " + strify(self.output)
|
|
if hasattr(self, "stderr") and self.stderr:
|
|
s = s + "\nStandard Error: " + strify(self.stderr)
|
|
return s
|
|
|
|
def errors_have_output():
|
|
subprocess.CalledProcessError = OETestCalledProcessError
|