helmfile/pkg/state/storage_test.go

278 lines
7.5 KiB
Go

package state
import (
"fmt"
"io"
"path/filepath"
"reflect"
"testing"
"github.com/helmfile/helmfile/pkg/filesystem"
"github.com/helmfile/helmfile/pkg/helmexec"
"github.com/helmfile/helmfile/pkg/remote"
)
func TestStorage_resolveFile(t *testing.T) {
type args struct {
missingFileHandler *string
title string
path string
opts []resolveFileOption
}
cacheDir := remote.CacheDir()
infoHandler := MissingFileHandlerInfo
warnHandler := MissingFileHandlerWarn
errorHandler := MissingFileHandlerError
tests := []struct {
name string
args args
wantFiles []string
wantSkipped bool
wantErr bool
}{
{
name: "non existing file in repo produce skip",
args: args{
path: "git::https://github.com/helmfile/helmfile.git@examples/values/non-existing-file.yaml?ref=v0.145.2",
title: "values",
missingFileHandler: &infoHandler,
},
wantSkipped: true,
wantErr: false,
},
{
name: "non existing file in repo produce skip",
args: args{
path: "git::https://github.com/helmfile/helmfile.git@examples/values/non-existing-file.yaml?ref=v0.145.2",
title: "values",
missingFileHandler: &errorHandler,
},
wantSkipped: false,
wantErr: true,
},
{
name: "non existing branch in repo produce error",
args: args{
path: "git::https://github.com/helmfile/helmfile.git@examples/values/non-existing-file.yaml?ref=inexistent-branch-for-test",
title: "values",
missingFileHandler: &infoHandler,
},
wantSkipped: false,
wantErr: true,
},
{
name: "non existing branch in repo produce info when ignoreMissingGitBranch=true",
args: args{
path: "git::https://github.com/helmfile/helmfile.git@examples/values/non-existing-file.yaml?ref=inexistent-branch-for-test",
title: "values",
missingFileHandler: &infoHandler,
opts: []resolveFileOption{
ignoreMissingGitBranch(true),
},
},
wantSkipped: true,
wantErr: false,
},
{
name: "non existing branch in repo produce warn when ignoreMissingGitBranch=true",
args: args{
path: "git::https://github.com/helmfile/helmfile.git@examples/values/non-existing-file.yaml?ref=inexistent-branch-for-test",
title: "values",
missingFileHandler: &warnHandler,
opts: []resolveFileOption{
ignoreMissingGitBranch(true),
},
},
wantSkipped: true,
wantErr: false,
},
{
name: "non existing branch in repo produce error with error handler even if ignoreMissingGitBranch=true",
args: args{
path: "git::https://github.com/helmfile/helmfile.git@examples/values/non-existing-file.yaml?ref=inexistent-branch-for-test",
title: "values",
missingFileHandler: &errorHandler,
opts: []resolveFileOption{
ignoreMissingGitBranch(true),
},
},
wantSkipped: false,
wantErr: true,
},
{
name: "existing remote value fetched",
args: args{
path: "git::https://github.com/helmfile/helmfile.git@examples/values/replica-values.yaml?ref=v0.145.2",
title: "values",
missingFileHandler: &infoHandler,
},
wantFiles: []string{fmt.Sprintf("%s/%s", cacheDir, "values/https_github_com_helmfile_helmfile_git.ref=v0.145.2/examples/values/replica-values.yaml")},
wantSkipped: false,
wantErr: false,
},
{
name: "non existing remote repo produce an error",
args: args{
path: "https://github.com/helmfile/helmfiles.git@examples/values/replica-values.yaml?ref=v0.145.2",
title: "values",
missingFileHandler: &infoHandler,
},
wantSkipped: false,
wantErr: true,
},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
st := NewStorage(cacheDir, helmexec.NewLogger(io.Discard, "debug"), filesystem.DefaultFileSystem())
files, skipped, err := st.resolveFile(tt.args.missingFileHandler, tt.args.title, tt.args.path, tt.args.opts...)
if (err != nil) != tt.wantErr {
t.Errorf("resolveFile() error = %v, wantErr %v", err, tt.wantErr)
return
}
if !reflect.DeepEqual(files, tt.wantFiles) {
t.Errorf("resolveFile() files = %v, want %v", files, tt.wantFiles)
}
if skipped != tt.wantSkipped {
t.Errorf("resolveFile() skipped = %v, want %v", skipped, tt.wantSkipped)
}
})
}
}
func TestNormalizePath(t *testing.T) {
tests := []struct {
name string
base string
path string
want string
}{
{
name: "unix path relative path",
base: "/root",
path: "local/timespan-application.yml",
want: "/local/timespan-application.yml",
},
{
name: "unix path absolute path",
base: "/data",
path: "/root/data/timespan-application.yml",
want: "/root/data/timespan-application.yml",
},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
storageIns := NewStorage(tt.base, helmexec.NewLogger(io.Discard, "debug"), filesystem.DefaultFileSystem())
if got := storageIns.normalizePath(tt.path); got != tt.want {
t.Errorf("normalizePath() = %v, want %v", got, tt.want)
}
})
}
}
func TestJoinBase(t *testing.T) {
tests := []struct {
name string
base string
path string
want string
}{
{
name: "joinBase with non-root base",
base: "/root",
path: "local/timespan-application.yml",
want: "/local/timespan-application.yml",
},
{
name: "joinBase with root path",
base: "/",
path: "data/timespan-application.yml",
want: "/data/timespan-application.yml",
},
{
name: "windows joinBase",
base: "",
path: "data\\timespan-application.yml",
want: "data\\timespan-application.yml",
},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
storageIns := NewStorage(tt.base, helmexec.NewLogger(io.Discard, "debug"), filesystem.DefaultFileSystem())
if got := storageIns.JoinBase(tt.path); got != tt.want {
t.Errorf("JoinBase() = %v, want %v", got, tt.want)
}
})
}
}
func TestNormalizeSetFilePath(t *testing.T) {
st := &Storage{
basePath: "/base/path",
}
tests := []struct {
name string
path string
expected string
osGOOS string
}{
{
name: "Unix path on Unix",
path: "relative/path",
expected: "/base/path/relative/path",
osGOOS: "linux",
},
{
name: "Windows path on Windows",
path: "relative\\path",
expected: "/base/path/relative\\\\path",
osGOOS: "windows",
},
{
name: "Unix path on Windows",
path: "relative/path",
expected: "/base/path/relative/path",
osGOOS: "windows",
},
{
name: "Absolute path on Unix",
path: "/absolute/path",
expected: "/absolute/path",
osGOOS: "linux",
},
{
name: "Absolute path on Windows",
path: "C:\\absolute\\path",
expected: "C:\\\\absolute\\\\path",
osGOOS: "windows",
},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
result := st.normalizeSetFilePath(tt.path, tt.osGOOS)
if tt.osGOOS == "windows" {
if result != tt.expected {
t.Errorf("normalizeSetFilePath() = %v, want %v", result, tt.expected)
}
} else {
expectedPath := filepath.Join(st.basePath, tt.path)
if !filepath.IsAbs(tt.path) {
if result != expectedPath {
t.Errorf("normalizeSetFilePath() = %v, want %v", result, expectedPath)
}
} else {
if result != tt.path {
t.Errorf("normalizeSetFilePath() = %v, want %v", result, tt.path)
}
}
}
})
}
}