From 2dbbd7db456eef97e8db93d6418880aaa614246f Mon Sep 17 00:00:00 2001 From: Chris Stephenson Date: Wed, 17 Jan 2024 12:06:33 +0100 Subject: [PATCH] feat: use resource id aliases in deltas for non-default classes --- internal/humanitec/convert.go | 4 ++++ internal/humanitec/convert_test.go | 25 +++++++++++++++++++++++++ internal/humanitec/templates.go | 4 ++++ 3 files changed, 33 insertions(+) diff --git a/internal/humanitec/convert.go b/internal/humanitec/convert.go index 336606e..26b5687 100644 --- a/internal/humanitec/convert.go +++ b/internal/humanitec/convert.go @@ -323,6 +323,10 @@ func ConvertSpec(name, envID, baseDir, workloadSourceURL string, spec *score.Wor if len(res.Params) > 0 { sharedRes["params"] = ctx.SubstituteAll(res.Params) } + if class != "default" { + sharedRes["id"] = resId + resName = resName + "-class-" + class + } shared = append(shared, humanitec.UpdateAction{ Operation: "add", Path: "/" + resName, diff --git a/internal/humanitec/convert_test.go b/internal/humanitec/convert_test.go index a2ed323..7305445 100644 --- a/internal/humanitec/convert_test.go +++ b/internal/humanitec/convert_test.go @@ -255,6 +255,7 @@ func TestScoreConvert(t *testing.T) { "CONNECTION_STRING": "postgresql://${resources.db.host}:${resources.db.port}/${resources.db.name}", "DOMAIN_NAME": "${resources.dns.domain}", "EXTERNAL_RESOURCE": "${resources.external-resource.name}", + "SENSITIVE_BUCKET": "${resources.sensitive-bucket.name}", }, Files: []score.FileMountSpec{ { @@ -340,6 +341,15 @@ func TestScoreConvert(t *testing.T) { "host": "${resources.dns.host}", }, }, + "sensitive-bucket": { + Metadata: score.ResourceMeta{ + Annotations: map[string]string{ + AnnotationLabelResourceId: "shared.sensitive-bucket", + }, + }, + Type: "bucket", + Class: "sensitive", + }, }, }, Extensions: &extensions.HumanitecExtensionsSpec{ @@ -392,6 +402,7 @@ func TestScoreConvert(t *testing.T) { "CONNECTION_STRING": "postgresql://${externals.annotations-db-id.host}:${externals.annotations-db-id.port}/${externals.annotations-db-id.name}", "DOMAIN_NAME": "${shared.dns.domain}", "EXTERNAL_RESOURCE": "${modules.test-module.externals.test-resource.name}", + "SENSITIVE_BUCKET": "${shared.sensitive-bucket-class-sensitive.name}", }, "files": map[string]interface{}{ "/etc/backend/config.yaml": map[string]interface{}{ @@ -461,6 +472,15 @@ func TestScoreConvert(t *testing.T) { }, }, Shared: []humanitec.UpdateAction{ + { + Operation: "add", + Path: "/sensitive-bucket-class-sensitive", + Value: map[string]interface{}{ + "type": "bucket", + "class": "sensitive", + "id": "shared.sensitive-bucket", + }, + }, { Operation: "add", Path: "/dns", @@ -489,7 +509,12 @@ func TestScoreConvert(t *testing.T) { // On Success // assert.NoError(t, err) + expectedShared := tt.Output.Shared + tt.Output.Shared = nil + actualShared := res.Shared + res.Shared = nil assert.Equal(t, tt.Output, res) + assert.ElementsMatch(t, expectedShared, actualShared) } }) } diff --git a/internal/humanitec/templates.go b/internal/humanitec/templates.go index 9a654d6..f573ab1 100644 --- a/internal/humanitec/templates.go +++ b/internal/humanitec/templates.go @@ -152,6 +152,10 @@ func (ctx *templatesContext) mapVar(ref string) string { } // END (DEPRECATED) + if hasAnnotation && strings.HasPrefix(resId, "shared.") && (res.Class != "" && res.Class != "default") { + resId = "shared." + resName + "-class-" + res.Class + } + if resId != "" { source = resId } else {