From 74744565b9f27b71c97b1b67d31c71fd864c8fa1 Mon Sep 17 00:00:00 2001 From: michaeljguarino Date: Tue, 28 May 2024 07:23:19 -0400 Subject: [PATCH] Fix filepath setup (#198) With the new mountPath spec, you can assume users specify a full/correct path in harness --- dockerfiles/harness/base.Dockerfile | 4 +++- internal/helpers/env.go | 2 +- internal/helpers/file.go | 5 +++++ pkg/harness/controller/controller.go | 2 +- pkg/harness/environment/environment.go | 4 +--- pkg/harness/tool/terraform/modifier.go | 16 +++++++--------- 6 files changed, 18 insertions(+), 15 deletions(-) diff --git a/dockerfiles/harness/base.Dockerfile b/dockerfiles/harness/base.Dockerfile index 0e87dcd8..af34dedc 100644 --- a/dockerfiles/harness/base.Dockerfile +++ b/dockerfiles/harness/base.Dockerfile @@ -49,4 +49,6 @@ COPY --chown=nonroot --from=environment /bin/sh /bin/sh COPY --chown=nonroot --from=environment /bin/sleep /bin/sleep COPY --from=builder /plural/harness /harness -ENTRYPOINT ["/harness", "--working-dir=plural"] +WORKDIR /plural + +ENTRYPOINT ["/harness", "--working-dir=/plural"] diff --git a/internal/helpers/env.go b/internal/helpers/env.go index c6f20e52..d1c8a7a7 100644 --- a/internal/helpers/env.go +++ b/internal/helpers/env.go @@ -71,7 +71,7 @@ func EnsureFileOrDie(file string) string { return f.Name() } -func IsExists(file string) bool { +func Exists(file string) bool { _, err := os.Stat(file) return err == nil } diff --git a/internal/helpers/file.go b/internal/helpers/file.go index 6ed3974f..1e901629 100644 --- a/internal/helpers/file.go +++ b/internal/helpers/file.go @@ -2,6 +2,7 @@ package helpers import ( "os" + "path/filepath" ) var ( @@ -19,5 +20,9 @@ func File() FileClient { type fileClient struct{} func (in *fileClient) Create(path, content string) error { + if err := os.MkdirAll(filepath.Dir(path), 0755); err != nil { + return err + } + return os.WriteFile(path, []byte(content), 0644) } diff --git a/pkg/harness/controller/controller.go b/pkg/harness/controller/controller.go index 12bd85a2..6762c4d2 100644 --- a/pkg/harness/controller/controller.go +++ b/pkg/harness/controller/controller.go @@ -185,7 +185,7 @@ func (in *stackRunController) prepare() error { env := environment.New( environment.WithStackRun(in.stackRun), environment.WithWorkingDir(in.dir), - environment.WithFilesDir(in.execWorkDir()), + environment.WithFilesDir(in.dir), environment.WithFetchClient(in.fetchClient), ) diff --git a/pkg/harness/environment/environment.go b/pkg/harness/environment/environment.go index 86b7a9c8..93620101 100644 --- a/pkg/harness/environment/environment.go +++ b/pkg/harness/environment/environment.go @@ -1,8 +1,6 @@ package environment import ( - "path" - "k8s.io/klog/v2" "github.com/pluralsh/deployment-operator/internal/helpers" @@ -38,7 +36,7 @@ func (in *environment) prepareFiles() error { } for _, fragment := range in.stackRun.Files { - destination := path.Join(in.filesDir, fragment.Path) + destination := fragment.Path if err := helpers.File().Create(destination, fragment.Content); err != nil { klog.ErrorS(err, "failed preparing files", "path", destination) return err diff --git a/pkg/harness/tool/terraform/modifier.go b/pkg/harness/tool/terraform/modifier.go index ce46a1a5..0aa5693b 100644 --- a/pkg/harness/tool/terraform/modifier.go +++ b/pkg/harness/tool/terraform/modifier.go @@ -4,7 +4,7 @@ import ( "fmt" "path" - "github.com/pluralsh/polly/algorithms" + "github.com/samber/lo" "github.com/pluralsh/deployment-operator/internal/helpers" ) @@ -20,9 +20,7 @@ func NewInitModifier() *InitModifier { // Args implements exec.ArgsModifier type. func (in *PlanModifier) Args(args []string) []string { - if algorithms.Index(args, func(a string) bool { - return a == "plan" - }) < 0 { + if !lo.Contains(args, "plan") { return args } @@ -34,11 +32,11 @@ func NewPlanModifier(planFileName string) *PlanModifier { } func (in *ApplyModifier) Args(args []string) []string { - if !helpers.IsExists(path.Join(in.dir, in.planFileName)) || - // This is to avoid doubling plan file arg if API already adds it - algorithms.Index(args, func(a string) bool { - return a == in.planFileName - }) >= 0 { + if !lo.Contains(args, "apply") { + return args + } + + if !helpers.Exists(path.Join(in.dir, in.planFileName)) || lo.Contains(args, in.planFileName) { return args }