2ba6619a16
Resolves: #2163759
212 lines
6.4 KiB
Diff
212 lines
6.4 KiB
Diff
From 9bffb4630b2fc026fe32ddcb2674499c863aac32 Mon Sep 17 00:00:00 2001
|
||
From: =?UTF-8?q?Ond=C5=99ej=20M=C3=ADchal?= <harrymichal@seznam.cz>
|
||
Date: Sat, 8 Jan 2022 19:53:53 +0200
|
||
Subject: [PATCH 1/3] pkg/utils: Use new UBI toolbox image
|
||
|
||
Red Hat has published a new UBI image made specificaly for Toolbx.
|
||
Make use of it from now on.
|
||
|
||
Fixes: https://github.com/containers/toolbox/issues/961
|
||
|
||
https://github.com/containers/toolbox/issues/976
|
||
(cherry picked from commit f456c173b6fd69ad390a419d23dafcf3f25b15a8)
|
||
---
|
||
src/pkg/utils/utils.go | 2 +-
|
||
test/system/libs/helpers.bash | 2 +-
|
||
2 files changed, 2 insertions(+), 2 deletions(-)
|
||
|
||
diff --git a/src/pkg/utils/utils.go b/src/pkg/utils/utils.go
|
||
index ab59afc22283..3119fee74375 100644
|
||
--- a/src/pkg/utils/utils.go
|
||
+++ b/src/pkg/utils/utils.go
|
||
@@ -104,7 +104,7 @@ var (
|
||
},
|
||
"rhel": {
|
||
"rhel-toolbox",
|
||
- "ubi",
|
||
+ "toolbox",
|
||
parseReleaseRHEL,
|
||
"registry.access.redhat.com",
|
||
"ubi8",
|
||
diff --git a/test/system/libs/helpers.bash b/test/system/libs/helpers.bash
|
||
index 548c4c0e745f..e29273a644dd 100644
|
||
--- a/test/system/libs/helpers.bash
|
||
+++ b/test/system/libs/helpers.bash
|
||
@@ -18,7 +18,7 @@ readonly SKOPEO=$(command -v skopeo)
|
||
# Images
|
||
declare -Ag IMAGES=([busybox]="quay.io/toolbox_tests/busybox" \
|
||
[fedora]="registry.fedoraproject.org/fedora-toolbox" \
|
||
- [rhel]="registry.access.redhat.com/ubi8")
|
||
+ [rhel]="registry.access.redhat.com/ubi8/toolbox")
|
||
|
||
|
||
function cleanup_all() {
|
||
--
|
||
2.39.1
|
||
|
||
|
||
From 643384caf11050a1e8d694176a6e09d732461975 Mon Sep 17 00:00:00 2001
|
||
From: Debarshi Ray <rishi@fedoraproject.org>
|
||
Date: Sun, 29 Jan 2023 09:41:16 +0100
|
||
Subject: [PATCH 2/3] pkg/utils: Be more strict about what is acceptable
|
||
|
||
https://github.com/containers/toolbox/issues/1065
|
||
(cherry picked from commit 262c90e06fdb91e0b693fae33a519eb2756de75b)
|
||
---
|
||
src/pkg/utils/utils.go | 15 ++++++++++++++-
|
||
1 file changed, 14 insertions(+), 1 deletion(-)
|
||
|
||
diff --git a/src/pkg/utils/utils.go b/src/pkg/utils/utils.go
|
||
index 3119fee74375..b4c012e8fe3a 100644
|
||
--- a/src/pkg/utils/utils.go
|
||
+++ b/src/pkg/utils/utils.go
|
||
@@ -1,5 +1,5 @@
|
||
/*
|
||
- * Copyright © 2019 – 2021 Red Hat Inc.
|
||
+ * Copyright © 2019 – 2023 Red Hat Inc.
|
||
*
|
||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||
* you may not use this file except in compliance with the License.
|
||
@@ -278,6 +278,19 @@ func GetEnvOptionsForPreservedVariables() []string {
|
||
func GetFullyQualifiedImageFromDistros(image, release string) (string, error) {
|
||
logrus.Debugf("Resolving fully qualified name for image %s from known registries", image)
|
||
|
||
+ if image == "" {
|
||
+ panic("image not specified")
|
||
+ }
|
||
+
|
||
+ if release == "" {
|
||
+ panic("release not specified")
|
||
+ }
|
||
+
|
||
+ if tag := ImageReferenceGetTag(image); tag != "" && release != tag {
|
||
+ panicMsg := fmt.Sprintf("image %s does not match release %s", image, release)
|
||
+ panic(panicMsg)
|
||
+ }
|
||
+
|
||
if ImageReferenceHasDomain(image) {
|
||
return image, nil
|
||
}
|
||
--
|
||
2.39.1
|
||
|
||
|
||
From 1ce213fabb3321937421404350e57f376cb9134d Mon Sep 17 00:00:00 2001
|
||
From: Debarshi Ray <rishi@fedoraproject.org>
|
||
Date: Sun, 29 Jan 2023 09:47:13 +0100
|
||
Subject: [PATCH 3/3] pkg/utils: Support RHEL 9 Toolbx containers
|
||
|
||
The URLs for the RHEL Toolbx images based on the Red Hat Universal Base
|
||
Images (or UBI) are a bit more complicated to construct, in comparison
|
||
to the URLs for Fedora's fedora-toolbox images. It's not enough to just
|
||
concatenate the registry, the image's basename and the release. Some
|
||
parts of the URL depend on the release's major number, which requires
|
||
custom code.
|
||
|
||
So far, the release's major number was hard coded to 8 since only RHEL 8
|
||
Toolbx containers were supported.
|
||
|
||
To support other RHEL major releases, it's necessary to have custom code
|
||
to construct the URLs for the Toolbx images.
|
||
|
||
https://github.com/containers/toolbox/issues/1065
|
||
(cherry picked from commit 0a29b374e649437126d8bbe12707fb44d20073d3)
|
||
---
|
||
src/pkg/utils/utils.go | 47 +++++++++++++++++++++---------------------
|
||
1 file changed, 23 insertions(+), 24 deletions(-)
|
||
|
||
diff --git a/src/pkg/utils/utils.go b/src/pkg/utils/utils.go
|
||
index b4c012e8fe3a..4e4abeca4817 100644
|
||
--- a/src/pkg/utils/utils.go
|
||
+++ b/src/pkg/utils/utils.go
|
||
@@ -38,15 +38,14 @@ import (
|
||
"golang.org/x/sys/unix"
|
||
)
|
||
|
||
+type GetFullyQualifiedImageFunc func(string, string) string
|
||
type ParseReleaseFunc func(string) (string, error)
|
||
|
||
type Distro struct {
|
||
ContainerNamePrefix string
|
||
ImageBasename string
|
||
+ GetFullyQualifiedImage GetFullyQualifiedImageFunc
|
||
ParseRelease ParseReleaseFunc
|
||
- Registry string
|
||
- Repository string
|
||
- RepositoryNeedsRelease bool
|
||
}
|
||
|
||
const (
|
||
@@ -97,18 +96,14 @@ var (
|
||
"fedora": {
|
||
"fedora-toolbox",
|
||
"fedora-toolbox",
|
||
+ getFullyQualifiedImageFedora,
|
||
parseReleaseFedora,
|
||
- "registry.fedoraproject.org",
|
||
- "",
|
||
- false,
|
||
},
|
||
"rhel": {
|
||
"rhel-toolbox",
|
||
"toolbox",
|
||
+ getFullyQualifiedImageRHEL,
|
||
parseReleaseRHEL,
|
||
- "registry.access.redhat.com",
|
||
- "ubi8",
|
||
- false,
|
||
},
|
||
}
|
||
)
|
||
@@ -305,21 +300,8 @@ func GetFullyQualifiedImageFromDistros(image, release string) (string, error) {
|
||
continue
|
||
}
|
||
|
||
- var repository string
|
||
-
|
||
- if distroObj.RepositoryNeedsRelease {
|
||
- repository = fmt.Sprintf(distroObj.Repository, release)
|
||
- } else {
|
||
- repository = distroObj.Repository
|
||
- }
|
||
-
|
||
- imageFull := distroObj.Registry
|
||
-
|
||
- if repository != "" {
|
||
- imageFull = imageFull + "/" + repository
|
||
- }
|
||
-
|
||
- imageFull = imageFull + "/" + image
|
||
+ getFullyQualifiedImageImpl := distroObj.GetFullyQualifiedImage
|
||
+ imageFull := getFullyQualifiedImageImpl(image, release)
|
||
|
||
logrus.Debugf("Resolved image %s to %s", image, imageFull)
|
||
|
||
@@ -329,6 +311,23 @@ func GetFullyQualifiedImageFromDistros(image, release string) (string, error) {
|
||
return "", fmt.Errorf("failed to resolve image %s", image)
|
||
}
|
||
|
||
+func getFullyQualifiedImageFedora(image, release string) string {
|
||
+ imageFull := "registry.fedoraproject.org/" + image
|
||
+ return imageFull
|
||
+}
|
||
+
|
||
+func getFullyQualifiedImageRHEL(image, release string) string {
|
||
+ i := strings.IndexRune(release, '.')
|
||
+ if i == -1 {
|
||
+ panicMsg := fmt.Sprintf("release %s not in '<major>.<minor>' format", release)
|
||
+ panic(panicMsg)
|
||
+ }
|
||
+
|
||
+ releaseMajor := release[:i]
|
||
+ imageFull := "registry.access.redhat.com/ubi" + releaseMajor + "/" + image
|
||
+ return imageFull
|
||
+}
|
||
+
|
||
// GetGroupForSudo returns the name of the sudoers group.
|
||
//
|
||
// Some distros call it 'sudo' (eg. Ubuntu) and some call it 'wheel' (eg. Fedora).
|
||
--
|
||
2.39.1
|
||
|