From 42f40a770bd4db9116357707077db8cd55ff9796 Mon Sep 17 00:00:00 2001 From: Lee Hugh Date: Mon, 28 Jun 2021 16:03:47 +0800 Subject: [PATCH 1/2] Test_EnvReplacement: env of path ends in a slash --- pkg/util/command_util_test.go | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/pkg/util/command_util_test.go b/pkg/util/command_util_test.go index 616ad61e30..632ef2eb42 100644 --- a/pkg/util/command_util_test.go +++ b/pkg/util/command_util_test.go @@ -53,6 +53,14 @@ var testEnvReplacement = []struct { isFilepath: true, expectedPath: "/simple/path/", }, + { + path: "$simple", + envs: []string{ + "simple=/path/", + }, + isFilepath: true, + expectedPath: "/path/", + }, { path: "${a}/b", envs: []string{ From c0fcefc4a444f69990d0cbd34d6a186c51e09842 Mon Sep 17 00:00:00 2001 From: Lee Hugh Date: Mon, 28 Jun 2021 16:06:27 +0800 Subject: [PATCH 2/2] Fix trailing path separator --- pkg/util/command_util.go | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/pkg/util/command_util.go b/pkg/util/command_util.go index 4330d60604..615ef99fa4 100644 --- a/pkg/util/command_util.go +++ b/pkg/util/command_util.go @@ -79,9 +79,10 @@ func ResolveEnvironmentReplacement(value string, envs []string, isFilepath bool) if err != nil { return "", err } + isDir := strings.HasSuffix(fp, pathSeparator) fp = filepath.Clean(fp) - if IsDestDir(value) && !IsDestDir(fp) { - fp = fp + "/" + if isDir && !strings.HasSuffix(fp, pathSeparator) { + fp = fp + pathSeparator } return fp, nil }