From 6c9edede349a7d391cacd40bb9d212796354561e Mon Sep 17 00:00:00 2001 From: Jelle van der Waa Date: Wed, 18 Jan 2023 17:00:59 +0100 Subject: [PATCH] test: test ignore MAC Address on restore feature This was broken in 4.0 and now fixed in 4.4 which is still an release candidate. Locally this has been tested with podman-4.4.0~rc1. Closes #1179 --- test/check-application | 18 +++++++++++++++--- 1 file changed, 15 insertions(+), 3 deletions(-) diff --git a/test/check-application b/test/check-application index 6f5d71412..ca6404fbb 100755 --- a/test/check-application +++ b/test/check-application @@ -32,6 +32,11 @@ DISTROS_WITHOUT_PODMAN_USER_RESTART = ['ubuntu-stable', 'ubuntu-2204'] DISTROS_WITHOUT_PODMAN_POD_VOLUMES = ['ubuntu-stable', 'ubuntu-2204', 'debian-testing'] +def podman_version(cls): + version = cls.execute(False, "podman -v").strip().split(' ')[-1] + return tuple(int(v) for v in version.split('.')) + + def showImages(browser): if browser.attr("#containers-images button.pf-c-expandable-section__toggle", "aria-expanded") == 'false': browser.click("#containers-images button.pf-c-expandable-section__toggle") @@ -1162,7 +1167,8 @@ class TestApplication(testlib.MachineCase): return # Run a container - self.execute(True, "podman run -dit --name swamped-crate --stop-timeout 0 busybox:latest sh; podman stop swamped-crate") + mac_address = '92:d0:c6:0a:29:38' + self.execute(True, f"podman run -dit --mac-address {mac_address} --name swamped-crate --stop-timeout 0 busybox:latest sh; podman stop swamped-crate") b.wait(lambda: self.execute(True, "podman ps --all | grep -e swamped-crate -e Exited")) # Check that the restore option is not present (i.e. start is a regular button) @@ -1201,6 +1207,13 @@ class TestApplication(testlib.MachineCase): b.click('.pf-c-modal-box button:contains(Restore)') b.wait(lambda: self.getContainerAttr("swamped-crate", "State") in 'Running') + # A new MAC address should have been generated + # Fixed in podman 4.4.0 https://github.com/containers/podman/issues/16666 + import json + print(json.dumps(podman_version(self))) + if podman_version(self) >= (4, 4, 0): + self.assertNotEqual(self.execute(True, "podman inspect --format '{{.NetworkSettings.MacAddress}}' swamped-crate").strip(), mac_address) + # Checkpoint the container without stopping self.waitContainerRow("swamped-crate") self.performContainerAction("swamped-crate", "Checkpoint") @@ -1461,8 +1474,7 @@ class TestApplication(testlib.MachineCase): # Just drop user images so we can use simpler selectors if auth: self.execute(False, "podman rmi alpine busybox quay.io/cockpit/registry:2") - _, _, version = self.execute(False, "podman -v").split(' ') - if int(version[0]) < 4: + if podman_version(self)[0] < 4: self.execute(False, "podman rmi pause:3.5") self.login(auth)