diff --git a/cmd/helm/repo_add.go b/cmd/helm/repo_add.go index 4ddf013c5..e13df7ad8 100644 --- a/cmd/helm/repo_add.go +++ b/cmd/helm/repo_add.go @@ -119,7 +119,7 @@ func (o *repoAddOptions) run(out io.Writer) error { repoFileExt := filepath.Ext(o.repoFile) var lockPath string if len(repoFileExt) > 0 && len(repoFileExt) < len(o.repoFile) { - lockPath = strings.Replace(o.repoFile, repoFileExt, ".lock", 1) + lockPath = strings.TrimSuffix(o.repoFile, repoFileExt) + ".lock" } else { lockPath = o.repoFile + ".lock" } diff --git a/cmd/helm/repo_add_test.go b/cmd/helm/repo_add_test.go index dabfb2a88..f9b0cab00 100644 --- a/cmd/helm/repo_add_test.go +++ b/cmd/helm/repo_add_test.go @@ -48,7 +48,11 @@ func TestRepoAddCmd(t *testing.T) { } defer srv2.Stop() - tmpdir := ensure.TempDir(t) + tmpdir := filepath.Join(ensure.TempDir(t), "path-component.yaml/data") + err = os.MkdirAll(tmpdir, 0777) + if err != nil { + t.Fatal(err) + } repoFile := filepath.Join(tmpdir, "repositories.yaml") tests := []cmdTestCase{