Skip to content

Commit

Permalink
list: Recognize UBI8 as Toolbox image & split tracked labels
Browse files Browse the repository at this point in the history
UBI[0] does not have the recommend Toolbox labels used to track whether
an image/container is truly a toolbox image/container. Thankfully, they
have a number of labels to choose from that we can use to identify the
image. The "com.redhat.component=ubi8-container" seems to be ideal.

The approach of using the UBI8 label introduces one problem though. If
we were to use only one set of labels for both images and containers,
containers created with Podman and not Toolbox from UBI8 would also be
marked as toolbox containers. This is not desired and therefore there
are now two sets of labels. Ones for images where the new label has been
added and other for containers that stays the same.
  • Loading branch information
HarryMichal committed May 26, 2021
1 parent 0f68fcf commit 7b9f7ad
Show file tree
Hide file tree
Showing 2 changed files with 39 additions and 4 deletions.
15 changes: 11 additions & 4 deletions src/cmd/list.go
Original file line number Diff line number Diff line change
Expand Up @@ -52,11 +52,18 @@ var (
onlyImages bool
}

// toolboxLabels holds labels used by containers/images that mark them as compatible with Toolbox
toolboxLabels = map[string]string{
// toolboxImageLabels holds labels used by images that mark them as compatible with Toolbox
toolboxImageLabels = map[string]string{
"com.github.debarshiray.toolbox": "true",
"com.github.containers.toolbox": "true",
"com.redhat.component": "ubi8-container",
}

// toolboxContainerLabels holds labels used by container that mark them as compatible with Toolbox
toolboxContainerLabels = map[string]string{
"com.github.debarshiray.toolbox": "true",
"com.github.containrs.toolbox": "true",
}
)

var listCmd = &cobra.Command{
Expand Down Expand Up @@ -157,7 +164,7 @@ func getContainers() ([]toolboxContainer, error) {
continue
}

for label := range toolboxLabels {
for label := range toolboxContainerLabels {
if _, ok := c.Labels[label]; ok {
isToolboxContainer = true
break
Expand Down Expand Up @@ -222,7 +229,7 @@ func getImages() ([]toolboxImage, error) {
continue
}

for label := range toolboxLabels {
for label := range toolboxImageLabels {
if _, ok := i.Labels[label]; ok {
isToolboxImage = true
break
Expand Down
28 changes: 28 additions & 0 deletions test/system/102-list.bats
Original file line number Diff line number Diff line change
Expand Up @@ -82,3 +82,31 @@ teardown() {
assert_output --partial "non-default-one"
assert_output --partial "non-default-two"
}

@test "list: Run 'list -i' with UBI image (8.4; public) present" {
pull_distro_image rhel 8.4

run toolbox list --images

assert_success
assert_output --partial "registry.access.redhat.com/ubi8/ubi:8.4"
}

@test "list: Run 'list' with UBI image (8.4; public), toolbox container and non-toolbox container" {
local num_of_containers

pull_distro_image rhel 8.4

create_distro_container rhel 8.4 rhel-toolbox
podman create --name podman-container ubi8/ubi /bin/sh

num_of_containers=$(list_containers)
assert [ $num_of_containers -eq 2 ]

run toolbox list

assert_success
assert_line --index 1 --partial ubi8/ubi
assert_line --index 3 rhel-toolbox
refute_output --partial podman-container
}

0 comments on commit 7b9f7ad

Please sign in to comment.