From d049f6505c7ad4119bfdc4e079c728b51655ab97 Mon Sep 17 00:00:00 2001 From: Hari Date: Thu, 21 Mar 2024 20:15:06 +0530 Subject: [PATCH] fix: bug where all yaml files were treated as K8s yamls by the Parameterizer (#1162) Signed-off-by: Harikrishnan Balagopal --- transformer/kubernetes/k8sschema/utils.go | 51 ++++++++++++++++--- .../kubernetes/parameterizer/parameterizer.go | 27 ++-------- 2 files changed, 47 insertions(+), 31 deletions(-) diff --git a/transformer/kubernetes/k8sschema/utils.go b/transformer/kubernetes/k8sschema/utils.go index 18db0a5dd..b0e055dcf 100644 --- a/transformer/kubernetes/k8sschema/utils.go +++ b/transformer/kubernetes/k8sschema/utils.go @@ -21,6 +21,7 @@ import ( "fmt" "os" "path/filepath" + "strings" "github.com/google/go-cmp/cmp" "github.com/konveyor/move2kube/common" @@ -49,25 +50,32 @@ func Intersection(objs1 []runtime.Object, objs2 []runtime.Object) []runtime.Obje return objs } -// GetInfoFromK8sResource returns some useful information given a k8s resource -func GetInfoFromK8sResource(k8sResource K8sResourceT) (kind, apiVersion, name string, err error) { - logrus.Trace("start getInfoFromK8sResource") - defer logrus.Trace("end getInfoFromK8sResource") +// GetOnlyGVKInfoFromK8sResource returns the Group Version Kind information given a k8s resource +func GetOnlyGVKInfoFromK8sResource(k8sResource K8sResourceT) (kind, apiVersion string, err error) { kindI, ok := k8sResource["kind"] if !ok { - return "", "", "", fmt.Errorf("there is no kind specified in the k8s resource %+v", k8sResource) + return "", "", fmt.Errorf("there is no kind specified in the k8s resource %+v", k8sResource) } kind, ok = kindI.(string) if !ok { - return "", "", "", fmt.Errorf("expected kind to be of type string. Actual value %+v is of type %T", kindI, kindI) + return "", "", fmt.Errorf("expected kind to be of type string. Actual value %+v is of type %T", kindI, kindI) } apiVersionI, ok := k8sResource["apiVersion"] if !ok { - return kind, "", "", fmt.Errorf("there is no apiVersion specified in the k8s resource %+v", k8sResource) + return kind, "", fmt.Errorf("there is no apiVersion specified in the k8s resource %+v", k8sResource) } apiVersion, ok = apiVersionI.(string) if !ok { - return kind, "", "", fmt.Errorf("expected apiVersion to be of type string. Actual value %+v is of type %T", apiVersionI, apiVersionI) + return kind, "", fmt.Errorf("expected apiVersion to be of type string. Actual value %+v is of type %T", apiVersionI, apiVersionI) + } + return kind, apiVersion, nil +} + +// GetInfoFromK8sResource returns some useful information given a k8s resource +func GetInfoFromK8sResource(k8sResource K8sResourceT) (kind, apiVersion, name string, err error) { + kind, apiVersion, err = GetOnlyGVKInfoFromK8sResource(k8sResource) + if err != nil { + return "", "", "", err } metadataI, ok := k8sResource["metadata"] if !ok { @@ -158,6 +166,13 @@ func GetK8sResourcesFromYaml(k8sYaml string) ([]K8sResourceT, error) { if err := yaml.Unmarshal([]byte(k8sYaml), &resourceI); err != nil { return nil, fmt.Errorf("failed to unmarshal the string '%s' as YAML. Error: %w", k8sYaml, err) } + resourceMap, ok := resourceI.(map[string]interface{}) + if !ok { + return nil, fmt.Errorf("expected the YAML to be a map[string]interface{} . Actual type %T value %+v", resourceI, resourceI) + } + if _, _, err := GetOnlyGVKInfoFromK8sResource(resourceMap); err != nil { + return nil, fmt.Errorf("failed to get the Group Version Kind info from the YAML. Error: %w", err) + } resourceJSONBytes, err := json.Marshal(resourceI) if err != nil { return nil, fmt.Errorf("failed to marshal the K8s resource as JSON. K8s resource: %+v Error: %w", resourceI, err) @@ -197,3 +212,23 @@ func GetKubernetesObjsInDir(dir string) []runtime.Object { } return objs } + +// GetGVKNFromK gets the GVK and metadata.name information for a K8s resource +func GetGVKNFromK(k K8sResourceT) (group string, version string, kind string, metadataName string, err error) { + var apiVersion string + kind, apiVersion, metadataName, err = GetInfoFromK8sResource(k) + if err != nil { + return kind, "", "", metadataName, err + } + t1s := strings.Split(apiVersion, "/") + if len(t1s) == 0 || len(t1s) > 2 { + err = fmt.Errorf("failed to get group and version from %s", apiVersion) + return kind, apiVersion, apiVersion, metadataName, err + } + if len(t1s) == 1 { + version = t1s[0] + } else if len(t1s) == 2 { + group, version = t1s[0], t1s[1] + } + return group, version, kind, metadataName, nil +} diff --git a/transformer/kubernetes/parameterizer/parameterizer.go b/transformer/kubernetes/parameterizer/parameterizer.go index 7d2b0e9c5..39f5511a6 100644 --- a/transformer/kubernetes/parameterizer/parameterizer.go +++ b/transformer/kubernetes/parameterizer/parameterizer.go @@ -78,7 +78,7 @@ func Parameterize(srcDir, outDir string, packSpecConfig ParameterizerConfigT, ps packSpecConfig.Envs = normEnvs pathedKs, err := k8sschema.GetK8sResourcesWithPaths(cleanSrcDir, false) if err != nil { - return filesWritten, err + return filesWritten, fmt.Errorf("failed to get the K8s resources in the directory '%s' . Error: %w", cleanSrcDir, err) } if packSpecConfig.Helm != "" { // helm chart with multiple values.yaml @@ -152,12 +152,12 @@ func Parameterize(srcDir, outDir string, packSpecConfig ParameterizerConfigT, ps // compute the json patch currKustPatches := map[string]map[string]PatchT{} // keyed by env and json pointer/path if err := parameterize(TargetKustomize, packSpecConfig.Envs, k, ps, nil, currKustPatches, nil); err != nil { - logrus.Errorf("Unable to parameterize %s : %s", finalKPath, err) + logrus.Errorf("failed to parameterize for Kustomize the path '%s' . Error: %q", finalKPath, err) } // patch metadata to put in kustomization.yaml - group, version, kind, metadataName, err := getGVKNFromK(k) + group, version, kind, metadataName, err := k8sschema.GetGVKNFromK(k) if err != nil { - logrus.Errorf("Unable to get GVK info for %s : %s", finalKPath, err) + logrus.Errorf("failed to get the Group Version Kind info from the YAML at path '%s' . Error: %q", finalKPath, err) continue } patchFilename := fmt.Sprintf("%s-%s-%s-%s.yaml", group, version, kind, metadataName) @@ -278,25 +278,6 @@ func Parameterize(srcDir, outDir string, packSpecConfig ParameterizerConfigT, ps // ------------------------------ // Utilities -func getGVKNFromK(k k8sschema.K8sResourceT) (group string, version string, kind string, metadataName string, err error) { - var apiVersion string - kind, apiVersion, metadataName, err = k8sschema.GetInfoFromK8sResource(k) - if err != nil { - return kind, "", "", metadataName, err - } - t1s := strings.Split(apiVersion, "/") - if len(t1s) == 0 || len(t1s) > 2 { - err = fmt.Errorf("failed to get group and version from %s", apiVersion) - return kind, apiVersion, apiVersion, metadataName, err - } - if len(t1s) == 1 { - version = t1s[0] - } else if len(t1s) == 2 { - group, version = t1s[0], t1s[1] - } - return group, version, kind, metadataName, nil -} - func getParameters(templ string) ([]string, error) { matches := stringInterpRegex.FindAllStringSubmatch(templ, -1) if len(matches) == 0 {