From cc2a7c083250b103220d972683266beba2943473 Mon Sep 17 00:00:00 2001 From: Subho Date: Thu, 14 Sep 2023 16:33:56 +0530 Subject: [PATCH] enhance: show toolbox & distrobox containers different in containers listing fixes #865 --- src/Containers.jsx | 8 +++++++- src/podman.scss | 8 ++++++++ test/check-application | 21 +++++++++++++++++++++ 3 files changed, 36 insertions(+), 1 deletion(-) diff --git a/src/Containers.jsx b/src/Containers.jsx index 7057f2369..4096648d9 100644 --- a/src/Containers.jsx +++ b/src/Containers.jsx @@ -375,6 +375,8 @@ class Containers extends React.Component { renderRow(containersStats, container, localImages) { const containerStats = containersStats[container.Id + container.isSystem.toString()]; const image = container.ImageName; + const isToolboxContainer = container.Config?.Labels?.["com.github.containers.toolbox"] === "true"; + const isDistroboxContainer = container.Config?.Labels?.manager === "distrobox"; let localized_health = null; // this needs to get along with stub containers from image run dialog, where most properties don't exist yet @@ -397,7 +399,11 @@ class Containers extends React.Component { } const info_block = (
- {container.Name} + + {container.Name} + {isToolboxContainer && toolbox} + {isDistroboxContainer && distrobox} + {image} {utils.quote_cmdline(container.Config?.Cmd)}
diff --git a/src/podman.scss b/src/podman.scss index 71b60fe94..66ffe03ac 100644 --- a/src/podman.scss +++ b/src/podman.scss @@ -69,6 +69,14 @@ color: white; } +.ct-badge-toolbox { + background-color: var(--pf-v5-global--palette--purple-500); +} + +.ct-badge-distrobox { + background-color: var(--pf-v5-global--palette--gold-500); +} + .green { color: var(--pf-v5-global--success-color--100); } diff --git a/test/check-application b/test/check-application index b8d3aff1d..3c5bada1d 100755 --- a/test/check-application +++ b/test/check-application @@ -2607,6 +2607,27 @@ class TestApplication(testlib.MachineCase): for i in range(31): self.execute(True, f"podman rm -f container{i}") + def testSpecialContainers(self): + m = self.machine + b = self.browser + + toolbox_label = "com.github.containers.toolbox=true" + distrobox_label = "manager=distrobox" + + container_1_id = m.execute(f"podman run -d --name container_1 -l {toolbox_label} {IMG_BUSYBOX}").strip() + container_2_id = m.execute(f"podman run -d --name container_2 -l {distrobox_label} {IMG_BUSYBOX}").strip() + + self.login() + + self.waitContainerRow('container_1') + self.waitContainerRow('container_2') + + container_1_sel = f"#containers-containers tbody tr[data-row-id=\"{container_1_id}{'true'}\"]" + container_2_sel = f"#containers-containers tbody tr[data-row-id=\"{container_2_id}{'true'}\"]" + + b.wait_visible(container_1_sel + " .ct-badge-toolbox:contains('toolbox')") + b.wait_visible(container_2_sel + " .ct-badge-distrobox:contains('distrobox')") + def testCreatePodSystem(self): self._createPod(True)