diff --git a/pkg/sosreport/sosreport.jsx b/pkg/sosreport/sosreport.jsx index f99a1e3d5617..bb4f917ad3d9 100644 --- a/pkg/sosreport/sosreport.jsx +++ b/pkg/sosreport/sosreport.jsx @@ -220,7 +220,16 @@ function sosDownload(path) { } function sosRemove(path) { - return cockpit.script(cockpit.format("rm -f '$0' '$0'.*", path), { superuser: true, err: "message" }); + // there are various potential extra files; not all of them are expected to exist, + // the file API tolerates removing nonexisting files + const paths = [ + path, + path + ".asc", + path + ".gpg", + path + ".md5", + path + ".sha256", + ]; + return Promise.all(paths.map(p => cockpit.file(p, { superuser: true }).replace(null))); } const SOSDialog = () => { diff --git a/test/verify/check-sosreport b/test/verify/check-sosreport index 4e6e50261414..15f21f022623 100755 --- a/test/verify/check-sosreport +++ b/test/verify/check-sosreport @@ -82,8 +82,9 @@ only-plugins=release,date,host,cgroups,networking # while the download is ongoing, it will have an *.xz.tmpsuffix name, gets renamed to *.xz when done testlib.wait(lambda: len(downloaded_sosreports()) > 0) report_gpg = downloaded_sosreports()[0] + report = report_gpg.removesuffix(".gpg") base_report_gpg = os.path.basename(report_gpg) - report = report_gpg.replace(".gpg", "") + base_report = base_report_gpg.removesuffix(".gpg") m.execute(f"test -f /var/tmp/{base_report_gpg}") @@ -100,7 +101,8 @@ only-plugins=release,date,host,cgroups,networking b.click("tr:contains(mylabel) button.pf-v5-c-dropdown__toggle") b.click("tr:contains(mylabel) li:contains(Delete)") b.click("#sos-remove-dialog button:contains(Delete)") - testlib.wait(lambda: m.execute(f"! test -f /var/tmp/{base_report_gpg} && echo yes")) + # ensure it removes the report itself, and auxiliary files like .gpg + m.execute(f"while ls /var/tmp/{base_report}*; do sleep 1; done", stdout=None, timeout=10) # error reporting self.write_file("/usr/sbin/sos", """#!/bin/sh