On 21 December 2016 at 06:32, Chen Qi <Qi.Chen@windriver.com> wrote: > > We need to have scriptlet output captured in log. If we don't do so, > some useful information from scriptlets (especially postinstall script) > would be missing. In case a script has a warning message but it does not > necessarily have to fail, the message should be captured. > > Opkg has already done that. Change for rpm and dpkg so that scriptlet > output is captured and no warning message is missing. > > Signed-off-by: Chen Qi <Qi.Chen@windriver.com> > --- > meta/lib/oe/package_manager.py | 9 +++++---- > 1 file changed, 5 insertions(+), 4 deletions(-) > > diff --git a/meta/lib/oe/package_manager.py b/meta/lib/oe/package_manager.py > index e557473..6892106 100644 > --- a/meta/lib/oe/package_manager.py > +++ b/meta/lib/oe/package_manager.py > @@ -669,11 +669,11 @@ class RpmPM(PackageManager): > self.install_dir_path = os.path.join(self.target_rootfs, self.install_dir_name) > self.rpm_cmd = bb.utils.which(os.getenv('PATH'), "rpm") > self.smart_cmd = bb.utils.which(os.getenv('PATH'), "smart") > - # 0 = default, only warnings > - # 1 = --log-level=info (includes information about executing scriptlets and their output) > + # 0 = --log-level=warning, only warnings > + # 1 = --log-level=info (includes information about executing scriptlets and their output), default > # 2 = --log-level=debug > # 3 = --log-level=debug plus dumps of scriplet content and command invocation > - self.debug_level = int(d.getVar('ROOTFS_RPM_DEBUG') or "0") > + self.debug_level = int(d.getVar('ROOTFS_RPM_DEBUG') or "1") > self.smart_opt = ["--log-level=%s" % > ("warning" if self.debug_level == 0 else > "info" if self.debug_level == 1 else > @@ -2025,7 +2025,8 @@ class DpkgPM(OpkgDpkgPM): > bb.note("Executing %s for package: %s ..." % > (control_script.name.lower(), pkg_name)) > subprocess.check_output([p_full, control_script.argument], > - stderr=subprocess.STDOUT) > + stderr=subprocess.STDOUT).decode("utf-8") > + bb.note(output)