[Piuparts-commits] [SCM] piuparts git repository branch, bikeshed, updated. 0.52-50-g1ca8406
Andreas Beckmann
anbe at debian.org
Sat Jun 1 13:43:14 UTC 2013
The following commit has been merged in the bikeshed branch:
commit 35154e1af2de1d727df390e87fa50b45b14181dc
Author: Andreas Beckmann <anbe at debian.org>
Date: Fri May 31 16:34:28 2013 +0200
p: allow check_for_no_processes() to be non-fatal
the very first (before any installation) and the very last (after restoring
the package list to the reference) test for running processes should
always fail if something is found
Signed-off-by: Andreas Beckmann <anbe at debian.org>
diff --git a/piuparts.py b/piuparts.py
index 3f17e32..87e84e5 100644
--- a/piuparts.py
+++ b/piuparts.py
@@ -1435,15 +1435,16 @@ class Chroot:
return vdict
- def check_for_no_processes(self):
+ def check_for_no_processes(self, fail=True):
"""Check there are no processes running inside the chroot."""
(status, output) = run(["lsof", "-w", "+D", self.name], ignore_errors=True)
count = len(output.split("\n")) - 1
if count > 0:
- logging.error("FAIL: Processes are running inside chroot:\n%s" %
- indent_string(output))
- self.terminate_running_processes()
- panic()
+ logging.error("%s: Processes are running inside chroot:\n%s" %
+ ("FAIL" if fail else "WARN", indent_string(output)))
+ if fail:
+ self.terminate_running_processes()
+ panic()
def terminate_running_processes(self):
@@ -2233,6 +2234,9 @@ def install_purge_test(chroot, chroot_state, package_files, packages, extra_pack
chroot.enable_testdebs_repo()
+ chroot.check_for_no_processes(fail=True)
+ chroot.check_for_broken_symlinks()
+
chroot.run_scripts("pre_install")
chroot.install_packages([], extra_packages, with_scripts=False)
@@ -2325,7 +2329,7 @@ def install_purge_test(chroot, chroot_state, package_files, packages, extra_pack
# Remove all packages from the chroot that weren't there initially.
chroot.restore_selections(chroot_state["selections"], packages)
- chroot.check_for_no_processes()
+ chroot.check_for_no_processes(fail=True)
chroot.check_for_broken_symlinks()
return check_results(chroot, chroot_state, file_owners, deps_info=deps_info)
@@ -2366,7 +2370,7 @@ def install_upgrade_test(chroot, chroot_state, package_files, packages, old_pack
# Remove all packages from the chroot that weren't there initially.
chroot.restore_selections(chroot_state["selections"], packages)
- chroot.check_for_no_processes()
+ chroot.check_for_no_processes(fail=True)
chroot.check_for_broken_symlinks()
return check_results(chroot, chroot_state, file_owners)
@@ -2434,7 +2438,7 @@ def install_and_upgrade_between_distros(package_files, packages_qualified):
chroot.upgrade_to_distros(settings.debian_distros[1:], [])
- chroot.check_for_no_processes()
+ chroot.check_for_no_processes(fail=True)
# set root_info and selections
chroot_state = {}
@@ -2459,7 +2463,7 @@ def install_and_upgrade_between_distros(package_files, packages_qualified):
chroot.remove_temp_tgz_file(temp_tgz)
dont_do_on_panic(panic_handler_id)
- chroot.check_for_no_processes()
+ chroot.check_for_no_processes(fail=True)
chroot.run_scripts("pre_test")
@@ -2502,7 +2506,7 @@ def install_and_upgrade_between_distros(package_files, packages_qualified):
# Remove all packages from the chroot that weren't in the reference chroot.
chroot.restore_selections(chroot_state["selections"], packages_qualified)
- chroot.check_for_no_processes()
+ chroot.check_for_no_processes(fail=True)
result = check_results(chroot, chroot_state, file_owners)
--
piuparts git repository
More information about the Piuparts-commits
mailing list