From bff157012a543e39d826e4294dbb073a58db7b64 Mon Sep 17 00:00:00 2001 From: Adrian Stobbe Date: Fri, 8 Sep 2023 08:36:06 +0200 Subject: [PATCH] fixup! leo feedback --- cli/internal/cmd/configgenerate.go | 3 +-- cli/internal/cmd/init.go | 3 +-- cli/internal/kubecmd/kubecmd.go | 13 +++++++++---- cli/internal/kubecmd/kubecmd_test.go | 2 +- internal/versions/versions.go | 6 +++--- 5 files changed, 15 insertions(+), 12 deletions(-) diff --git a/cli/internal/cmd/configgenerate.go b/cli/internal/cmd/configgenerate.go index 1e857af58f..316157adb8 100644 --- a/cli/internal/cmd/configgenerate.go +++ b/cli/internal/cmd/configgenerate.go @@ -14,13 +14,12 @@ import ( "github.com/edgelesssys/constellation/v2/internal/attestation/variant" "github.com/edgelesssys/constellation/v2/internal/cloud/cloudprovider" "github.com/edgelesssys/constellation/v2/internal/config" - "golang.org/x/mod/semver" - "github.com/edgelesssys/constellation/v2/internal/constants" "github.com/edgelesssys/constellation/v2/internal/file" "github.com/edgelesssys/constellation/v2/internal/versions" "github.com/spf13/afero" "github.com/spf13/cobra" + "golang.org/x/mod/semver" ) func newConfigGenerateCmd() *cobra.Command { diff --git a/cli/internal/cmd/init.go b/cli/internal/cmd/init.go index 17daa3077c..8663ec0fbd 100644 --- a/cli/internal/cmd/init.go +++ b/cli/internal/cmd/init.go @@ -153,7 +153,7 @@ func (i *initCmd) initialize( return err } // cfg validation does not check k8s patch version since upgrade may accept an outdated patch version. - _, err = versions.NewValidK8sVersion(string(conf.KubernetesVersion), true) + k8sVersion, err := versions.NewValidK8sVersion(string(conf.KubernetesVersion), true) if err != nil { return err } @@ -172,7 +172,6 @@ func (i *initCmd) initialize( return fmt.Errorf("reading cluster ID file: %w", err) } - k8sVersion := conf.KubernetesVersion i.log.Debugf("Validated k8s version as %s", k8sVersion) if versions.IsPreviewK8sVersion(k8sVersion) { cmd.PrintErrf("Warning: Constellation with Kubernetes %v is still in preview. Use only for evaluation purposes.\n", k8sVersion) diff --git a/cli/internal/kubecmd/kubecmd.go b/cli/internal/kubecmd/kubecmd.go index 4f9f84eded..0b93119b25 100644 --- a/cli/internal/kubecmd/kubecmd.go +++ b/cli/internal/kubecmd/kubecmd.go @@ -145,8 +145,14 @@ func (k *KubeCmd) UpgradeNodeVersion(ctx context.Context, conf *config.Config, f err = compatibility.NewInvalidUpgradeError(nodeVersion.Spec.KubernetesClusterVersion, string(conf.KubernetesVersion), innerErr) } else { - versionConfig := versions.VersionConfigs[conf.KubernetesVersion] - components, err = k.updateK8s(&nodeVersion, versionConfig.ClusterVersion, versionConfig.KubernetesComponents, force) + versionConfig, ok := versions.VersionConfigs[conf.KubernetesVersion] + if !ok { + err = compatibility.NewInvalidUpgradeError(nodeVersion.Spec.KubernetesClusterVersion, + string(conf.KubernetesVersion), fmt.Errorf("no version config matching K8s %s", conf.KubernetesVersion)) + } else { + components, err = k.prepareUpdateK8s(&nodeVersion, versionConfig.ClusterVersion, + versionConfig.KubernetesComponents, force) + } } switch { @@ -161,7 +167,6 @@ func (k *KubeCmd) UpgradeNodeVersion(ctx context.Context, conf *config.Config, f return fmt.Errorf("updating Kubernetes version: %w", err) } } - if len(upgradeErrs) == 2 { return errors.Join(upgradeErrs...) } @@ -423,7 +428,7 @@ func (k *KubeCmd) isValidImageUpgrade(nodeVersion updatev1alpha1.NodeVersion, ne return nil } -func (k *KubeCmd) updateK8s(nodeVersion *updatev1alpha1.NodeVersion, newClusterVersion string, components components.Components, force bool) (*corev1.ConfigMap, error) { +func (k *KubeCmd) prepareUpdateK8s(nodeVersion *updatev1alpha1.NodeVersion, newClusterVersion string, components components.Components, force bool) (*corev1.ConfigMap, error) { configMap, err := internalk8s.ConstructK8sComponentsCM(components, newClusterVersion) if err != nil { return nil, fmt.Errorf("constructing k8s-components ConfigMap: %w", err) diff --git a/cli/internal/kubecmd/kubecmd_test.go b/cli/internal/kubecmd/kubecmd_test.go index fd8cb61ec0..9d1d37896b 100644 --- a/cli/internal/kubecmd/kubecmd_test.go +++ b/cli/internal/kubecmd/kubecmd_test.go @@ -444,7 +444,7 @@ func TestUpdateK8s(t *testing.T) { }, } - _, err := upgrader.updateK8s(&nodeVersion, tc.newClusterVersion, components.Components{}, false) + _, err := upgrader.prepareUpdateK8s(&nodeVersion, tc.newClusterVersion, components.Components{}, false) if tc.wantErr { assert.Error(err) diff --git a/internal/versions/versions.go b/internal/versions/versions.go index d6ce41d0d1..c2a75bd3ae 100644 --- a/internal/versions/versions.go +++ b/internal/versions/versions.go @@ -85,7 +85,7 @@ func ResolveK8sPatchVersion(k8sVersion string) (string, error) { if hasPatchVersion(k8sVersion) { return k8sVersion, nil } - extendedVersion := K8sVersionFromMajorMinor(k8sVersion) + extendedVersion := k8sVersionFromMajorMinor(k8sVersion) if extendedVersion == "" { return "", fmt.Errorf("Kubernetes version %s is not valid. Supported versions: %s", strings.TrimPrefix(k8sVersion, "v"), supportedVersions()) @@ -94,10 +94,10 @@ func ResolveK8sPatchVersion(k8sVersion string) (string, error) { return extendedVersion, nil } -// K8sVersionFromMajorMinor takes a semver in format MAJOR.MINOR +// k8sVersionFromMajorMinor takes a semver in format MAJOR.MINOR // and returns the version in format MAJOR.MINOR.PATCH with the // supported patch version as PATCH. -func K8sVersionFromMajorMinor(version string) string { +func k8sVersionFromMajorMinor(version string) string { switch version { case semver.MajorMinor(string(V1_26)): return string(V1_26)