From 69d76fe2e2d6755a919f3dfaa50aa10dc9aa03da Mon Sep 17 00:00:00 2001 From: Martin Pitt Date: Wed, 25 Oct 2023 08:16:10 +0200 Subject: [PATCH] test: Adjust stratis pool stopping/destroying to stratis-cli 3.6.0 The CLI changed in an incompatible way: Earlier versions just expected the pool name/UUID as positional argument, 3.6.0 now expects it through an `--uuid` or `--name` option. --- test/verify/check-storage-stratis | 18 ++++++++++++------ 1 file changed, 12 insertions(+), 6 deletions(-) diff --git a/test/verify/check-storage-stratis b/test/verify/check-storage-stratis index e7ecb025840f..ed7ae99a06b5 100755 --- a/test/verify/check-storage-stratis +++ b/test/verify/check-storage-stratis @@ -36,12 +36,18 @@ class TestStorageStratis(storagelib.StorageCase): self.stratis_v2 = self.image.startswith("rhel-8") or self.image == "centos-8-stream" + # the CLI changed in an incompatible way in Fedora 40 + if '--name' in exe("stratis pool stop --help"): + self.pool_type_opt = "--name" + else: + self.pool_type_opt = "" + self.addCleanup(exe, "stratis report | jq -r '.pools[] | .name' |" - "xargs -n1 --no-run-if-empty stratis pool destroy") + f"xargs -n1 --no-run-if-empty stratis pool destroy {self.pool_type_opt}") self.addCleanup(exe, "stratis report | jq -r '.pools[] | .name' |" - "xargs -n1 --no-run-if-empty stratis pool stop") + f"xargs -n1 --no-run-if-empty stratis pool stop {self.pool_type_opt}") def testBasic(self): m = self.machine @@ -87,7 +93,7 @@ class TestStorageStratis(storagelib.StorageCase): if not self.stratis_v2: # Stop the pool (only works with Stratis 3) pool_uuid = m.execute("stratis --unhyphenated-uuids pool list --name pool0 | grep ^UUID | cut -d' ' -f2").strip() - m.execute("stratis pool stop pool0") + m.execute(f"stratis pool stop {self.pool_type_opt} pool0") b.wait_in_text(f'.sidepanel-row:contains("{pool_uuid}")', "Stopped Stratis pool") # Start it @@ -366,7 +372,7 @@ systemctl restart stratisd b.wait_not_in_text("#detail-content", "fsys2") # Destroy the pool outside of Cockpit - m.execute("stratis pool destroy TEST1") + m.execute(f"stratis pool destroy {self.pool_type_opt} TEST1") b.wait_in_text("#storage-detail", "Not found") b.go("#/") @@ -860,7 +866,7 @@ class TestStorageStratisNBDE(packagelib.PackageCase, storagelib.StorageCase): # Stop the pool and start it again. This should not ask # for the passphrase (since there isn't any) - m.execute("stratis pool stop pool0") + m.execute(f"stratis pool stop {self.pool_type_opt} pool0") b.wait_in_text('#detail-header', "Stopped Stratis pool") tang_m.execute("systemctl stop tangd.socket") b.click('#detail-header button:contains(Start)') @@ -882,7 +888,7 @@ class TestStorageStratisNBDE(packagelib.PackageCase, storagelib.StorageCase): self.dialog({'passphrase': "foodeeboodeebar", 'passphrase2': "foodeeboodeebar"}) b.wait_visible('#detail-header .pf-v5-c-description-list__group:contains(Keyserver) button:contains(Remove):not([aria-disabled=true])') - m.execute("stratis pool stop pool0") + m.execute(f"stratis pool stop {self.pool_type_opt} pool0") tang_m.execute("systemctl stop tangd.socket") b.click('#detail-header button:contains(Start)') self.dialog_wait_open()