Files
poky/meta/lib/oeqa/runtime/utils/targetbuildproject.py
Richard Purdie 6840618f1a oeqa/runtime: Improve failure log output
Printing a message which says "configure failed" without the log output
is effectively useless. If a command fails, print the output by default
and simplify the calling code which makes debugging any of these failures
much easier.

(From OE-Core rev: b6352ff001c29f0bff10c18879b92c5618ec645c)

Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
2017-02-05 09:22:17 +00:00

41 lines
1.4 KiB
Python

# Copyright (C) 2016 Intel Corporation
# Released under the MIT license (see COPYING.MIT)
from oeqa.utils.buildproject import BuildProject
class TargetBuildProject(BuildProject):
def __init__(self, target, uri, foldername=None, dl_dir=None):
self.target = target
self.targetdir = "~/"
BuildProject.__init__(self, uri, foldername, tmpdir="/tmp",
dl_dir=dl_dir)
def download_archive(self):
self._download_archive()
status, output = self.target.copyTo(self.localarchive, self.targetdir)
if status:
raise Exception('Failed to copy archive to target, '
'output: %s' % output)
cmd = 'tar xf %s%s -C %s' % (self.targetdir,
self.archive,
self.targetdir)
status, output = self.target.run(cmd)
if status:
raise Exception('Failed to extract archive, '
'output: %s' % output)
# Change targetdir to project folder
self.targetdir = self.targetdir + self.fname
# The timeout parameter of target.run is set to 0
# to make the ssh command run with no timeout.
def _run(self, cmd):
ret = self.target.run(cmd, 0)
msg = "Command %s failed with exit code %s: %s" % (cmd, ret[0], ret[1])
if ret[0] != 0:
raise Exception(msg)
return ret[0]