From f31b89695fe2cb092926a5c72e90fe763b43c4f5 Mon Sep 17 00:00:00 2001 From: Patrick Zheng Date: Thu, 5 Sep 2024 08:50:14 +0800 Subject: [PATCH] fix: dir no longer panics when HOME and XDG_CONFIG_HOME are not set (#451) Signed-off-by: Patrick Zheng --- dir/fs.go | 4 ++-- dir/fs_test.go | 4 ++-- dir/path.go | 31 +++++++++++++++++++------------ dir/path_test.go | 45 +++++++++++++++++++++++++++++++++++---------- 4 files changed, 58 insertions(+), 26 deletions(-) diff --git a/dir/fs.go b/dir/fs.go index 4533a7a6..444179ce 100644 --- a/dir/fs.go +++ b/dir/fs.go @@ -51,10 +51,10 @@ func NewSysFS(root string) SysFS { // ConfigFS is the config SysFS func ConfigFS() SysFS { - return NewSysFS(UserConfigDir) + return NewSysFS(userConfigDirPath()) } // PluginFS is the plugin SysFS func PluginFS() SysFS { - return NewSysFS(filepath.Join(UserLibexecDir, PathPlugins)) + return NewSysFS(filepath.Join(userLibexecDirPath(), PathPlugins)) } diff --git a/dir/fs_test.go b/dir/fs_test.go index d2c976cf..6488e5de 100644 --- a/dir/fs_test.go +++ b/dir/fs_test.go @@ -67,7 +67,7 @@ func TestPluginFS(t *testing.T) { if err != nil { t.Fatalf("SysPath() failed. err = %v", err) } - if path != filepath.Join(UserLibexecDir, PathPlugins, "plugin") { - t.Fatalf(`SysPath() failed. got: %q, want: %q`, path, filepath.Join(UserLibexecDir, PathPlugins, "plugin")) + if path != filepath.Join(userLibexecDirPath(), PathPlugins, "plugin") { + t.Fatalf(`SysPath() failed. got: %q, want: %q`, path, filepath.Join(userLibexecDirPath(), PathPlugins, "plugin")) } } diff --git a/dir/path.go b/dir/path.go index 37aafe56..09ea88bd 100644 --- a/dir/path.go +++ b/dir/path.go @@ -73,21 +73,28 @@ const ( var userConfigDir = os.UserConfigDir // for unit test -func init() { - loadUserPath() +// userConfigDirPath returns the user level {NOTATION_CONFIG} path. +func userConfigDirPath() string { + if UserConfigDir == "" { + userDir, err := userConfigDir() + if err != nil { + // fallback to current directory + UserConfigDir = "." + notation + return UserConfigDir + } + // set user config + UserConfigDir = filepath.Join(userDir, notation) + } + return UserConfigDir } -// loadUserPath function defines UserConfigDir and UserLibexecDir. -func loadUserPath() { - // set user config - userDir, err := userConfigDir() - if err != nil { - panic(err) +// userLibexecDirPath returns the user level {NOTATION_LIBEXEC} path. +func userLibexecDirPath() string { + if UserLibexecDir == "" { + // set user libexec + UserLibexecDir = userConfigDirPath() } - UserConfigDir = filepath.Join(userDir, notation) - - // set user libexec - UserLibexecDir = UserConfigDir + return UserLibexecDir } // LocalKeyPath returns the local key and local cert relative paths. diff --git a/dir/path_test.go b/dir/path_test.go index f80b75c7..ceeafc3f 100644 --- a/dir/path_test.go +++ b/dir/path_test.go @@ -14,7 +14,7 @@ package dir import ( - "path/filepath" + "os" "testing" ) @@ -22,22 +22,45 @@ func mockGetUserConfig() (string, error) { return "/path/", nil } -func Test_loadPath(t *testing.T) { - wantDir := filepath.FromSlash("/path/notation") +func setup() { + UserConfigDir = "" + UserLibexecDir = "" +} + +func Test_UserConfigDirPath(t *testing.T) { userConfigDir = mockGetUserConfig - loadUserPath() - if UserConfigDir != wantDir { - t.Fatalf(`loadPath() UserConfigDir is incorrect. got: %q, want: %q`, UserConfigDir, wantDir) + setup() + got := userConfigDirPath() + if got != "/path/notation" { + t.Fatalf(`UserConfigDirPath() = %q, want "/path/notation"`, got) } +} - if UserLibexecDir != UserConfigDir { - t.Fatalf(`loadPath() UserLibexecDir is incorrect. got: %q, want: %q`, UserLibexecDir, wantDir) +func Test_NoHomeVariable(t *testing.T) { + t.Setenv("HOME", "") + t.Setenv("XDG_CONFIG_HOME", "") + setup() + userConfigDir = os.UserConfigDir + got := userConfigDirPath() + if got != ".notation" { + t.Fatalf(`UserConfigDirPath() = %q, want ".notation"`, UserConfigDir) + } +} + +func Test_UserLibexecDirPath(t *testing.T) { + userConfigDir = mockGetUserConfig + setup() + got := userLibexecDirPath() + if got != "/path/notation" { + t.Fatalf(`UserConfigDirPath() = %q, want "/path/notation"`, got) } } func TestLocalKeyPath(t *testing.T) { userConfigDir = mockGetUserConfig - loadUserPath() + setup() + _ = userConfigDirPath() + _ = userLibexecDirPath() gotKeyPath, gotCertPath := LocalKeyPath("web") if gotKeyPath != "localkeys/web.key" { t.Fatalf(`LocalKeyPath() gotKeyPath = %q, want "localkeys/web.key"`, gotKeyPath) @@ -49,7 +72,9 @@ func TestLocalKeyPath(t *testing.T) { func TestX509TrustStoreDir(t *testing.T) { userConfigDir = mockGetUserConfig - loadUserPath() + setup() + _ = userConfigDirPath() + _ = userLibexecDirPath() if got := X509TrustStoreDir("ca", "web"); got != "truststore/x509/ca/web" { t.Fatalf(`X509TrustStoreDir() = %q, want "truststore/x509/ca/web"`, got) }