summaryrefslogtreecommitdiff
path: root/script
diff options
context:
space:
mode:
authorStefan Metzmacher <metze@samba.org>2020-11-20 09:20:14 +0000
committerStefan Metzmacher <metze@samba.org>2021-01-27 18:17:17 +0000
commit9883ac45939f253a63f3ff312fc3912c5f02cdac (patch)
tree3b9803befaa66185d747ba3b0b83bd456b137c80 /script
parent7a5df2deaaf62a7edd7c64251f75ab15abe94c07 (diff)
downloadsamba-9883ac45939f253a63f3ff312fc3912c5f02cdac.tar.gz
script/autobuild.py: let cleanup() ignore errors from rmdir_force() by default
It's not useful to generate a python backtrace from within the cleanup code. Signed-off-by: Stefan Metzmacher <metze@samba.org> Reviewed-by: Ralph Boehme <slow@samba.org> Autobuild-User(master): Stefan Metzmacher <metze@samba.org> Autobuild-Date(master): Wed Jan 27 18:17:17 UTC 2021 on sn-devel-184
Diffstat (limited to 'script')
-rwxr-xr-xscript/autobuild.py15
1 files changed, 12 insertions, 3 deletions
diff --git a/script/autobuild.py b/script/autobuild.py
index c1d59b9c1a5..dded5c9dec9 100755
--- a/script/autobuild.py
+++ b/script/autobuild.py
@@ -1045,14 +1045,23 @@ class buildlist(object):
self.tail_proc = Popen(cmd, close_fds=True)
-def cleanup():
+def cleanup(do_raise=False):
if options.nocleanup:
return
run_cmd("stat %s || true" % test_tmpdir, show=True)
run_cmd("stat %s" % testbase, show=True)
do_print("Cleaning up %r" % cleanup_list)
for d in cleanup_list:
- rmdir_force(d)
+ ok = rmdir_force(d, re_raise=False)
+ if ok:
+ continue
+ if os.path.isdir(d):
+ do_print("Killing, waiting and retry")
+ run_cmd("killbysubdir %s > /dev/null 2>&1" % d, checkfail=False)
+ else:
+ do_print("Waiting and retry")
+ time.sleep(1)
+ rmdir_force(d, re_raise=do_raise)
def daemonize(logfile):
@@ -1318,7 +1327,7 @@ while True:
(status, failed_task, failed_stage, failed_tag, errstr) = blist.run()
if status != 0 or errstr != "retry":
break
- cleanup()
+ cleanup(do_raise=True)
except Exception:
cleanup()
raise