|
@@ -4,6 +4,7 @@ import (
|
|
"os"
|
|
"os"
|
|
"os/user"
|
|
"os/user"
|
|
"path/filepath"
|
|
"path/filepath"
|
|
|
|
+ "runtime"
|
|
"testing"
|
|
"testing"
|
|
)
|
|
)
|
|
|
|
|
|
@@ -11,14 +12,29 @@ func TestExpandPath(t *testing.T) {
|
|
mockCurrentUser := func() (*user.User, error) {
|
|
mockCurrentUser := func() (*user.User, error) {
|
|
return &user.User{
|
|
return &user.User{
|
|
Username: "testuser",
|
|
Username: "testuser",
|
|
- HomeDir: "/home/testuser",
|
|
|
|
|
|
+ HomeDir: func() string {
|
|
|
|
+ if os.PathSeparator == '\\' {
|
|
|
|
+ return filepath.FromSlash("D:/home/testuser")
|
|
|
|
+ }
|
|
|
|
+ return "/home/testuser"
|
|
|
|
+ }(),
|
|
}, nil
|
|
}, nil
|
|
}
|
|
}
|
|
|
|
|
|
mockLookupUser := func(username string) (*user.User, error) {
|
|
mockLookupUser := func(username string) (*user.User, error) {
|
|
fakeUsers := map[string]string{
|
|
fakeUsers := map[string]string{
|
|
- "testuser": "/home/testuser",
|
|
|
|
- "anotheruser": "/home/anotheruser",
|
|
|
|
|
|
+ "testuser": func() string {
|
|
|
|
+ if os.PathSeparator == '\\' {
|
|
|
|
+ return filepath.FromSlash("D:/home/testuser")
|
|
|
|
+ }
|
|
|
|
+ return "/home/testuser"
|
|
|
|
+ }(),
|
|
|
|
+ "anotheruser": func() string {
|
|
|
|
+ if os.PathSeparator == '\\' {
|
|
|
|
+ return filepath.FromSlash("D:/home/anotheruser")
|
|
|
|
+ }
|
|
|
|
+ return "/home/anotheruser"
|
|
|
|
+ }(),
|
|
}
|
|
}
|
|
|
|
|
|
if homeDir, ok := fakeUsers[username]; ok {
|
|
if homeDir, ok := fakeUsers[username]; ok {
|
|
@@ -30,30 +46,78 @@ func TestExpandPath(t *testing.T) {
|
|
return nil, os.ErrNotExist
|
|
return nil, os.ErrNotExist
|
|
}
|
|
}
|
|
|
|
|
|
- tests := []struct {
|
|
|
|
- path string
|
|
|
|
- relativeDir string
|
|
|
|
- expected string
|
|
|
|
- windowsExpected string
|
|
|
|
- shouldErr bool
|
|
|
|
- }{
|
|
|
|
- {"~", "", "/home/testuser", "D:\\home\\testuser", false},
|
|
|
|
- {"~/myfolder/myfile.txt", "", "/home/testuser/myfolder/myfile.txt", "D:\\home\\testuser\\myfolder\\myfile.txt", false},
|
|
|
|
- {"~anotheruser/docs/file.txt", "", "/home/anotheruser/docs/file.txt", "D:\\home\\anotheruser\\docs\\file.txt", false},
|
|
|
|
- {"~nonexistentuser/file.txt", "", "", "", true},
|
|
|
|
- {"relative/path/to/file", "", filepath.Join(os.Getenv("PWD"), "relative/path/to/file"), "relative\\path\\to\\file", false},
|
|
|
|
- {"/absolute/path/to/file", "", "/absolute/path/to/file", "D:\\absolute\\path\\to\\file", false},
|
|
|
|
- {".", os.Getenv("PWD"), "", os.Getenv("PWD"), false},
|
|
|
|
- {"somefile", "somedir", filepath.Join(os.Getenv("PWD"), "somedir", "somefile"), "somedir\\somefile", false},
|
|
|
|
|
|
+ pwd, err := os.Getwd()
|
|
|
|
+ if err != nil {
|
|
|
|
+ t.Fatal(err)
|
|
}
|
|
}
|
|
|
|
|
|
- for _, test := range tests {
|
|
|
|
- result, err := expandPathImpl(test.path, test.relativeDir, mockCurrentUser, mockLookupUser)
|
|
|
|
- if (err != nil) != test.shouldErr {
|
|
|
|
- t.Errorf("expandPathImpl(%q) returned error: %v, expected error: %v", test.path, err != nil, test.shouldErr)
|
|
|
|
|
|
+ t.Run("unix tests", func(t *testing.T) {
|
|
|
|
+ if runtime.GOOS == "windows" {
|
|
|
|
+ return
|
|
}
|
|
}
|
|
- if result != test.expected && result != test.windowsExpected && !test.shouldErr {
|
|
|
|
- t.Errorf("expandPathImpl(%q) = %q, want %q", test.path, result, test.expected)
|
|
|
|
|
|
+
|
|
|
|
+ tests := []struct {
|
|
|
|
+ path string
|
|
|
|
+ relativeDir string
|
|
|
|
+ expected string
|
|
|
|
+ shouldErr bool
|
|
|
|
+ }{
|
|
|
|
+ {"~", "", "/home/testuser", false},
|
|
|
|
+ {"~/myfolder/myfile.txt", "", "/home/testuser/myfolder/myfile.txt", false},
|
|
|
|
+ {"~anotheruser/docs/file.txt", "", "/home/anotheruser/docs/file.txt", false},
|
|
|
|
+ {"~nonexistentuser/file.txt", "", "", true},
|
|
|
|
+ {"relative/path/to/file", "", filepath.Join(pwd, "relative/path/to/file"), false},
|
|
|
|
+ {"/absolute/path/to/file", "", "/absolute/path/to/file", false},
|
|
|
|
+ {"/absolute/path/to/file", "someotherdir/", "/absolute/path/to/file", false},
|
|
|
|
+ {".", pwd, pwd, false},
|
|
|
|
+ {".", "", pwd, false},
|
|
|
|
+ {"somefile", "somedir", filepath.Join(pwd, "somedir", "somefile"), false},
|
|
}
|
|
}
|
|
- }
|
|
|
|
|
|
+
|
|
|
|
+ for _, test := range tests {
|
|
|
|
+ result, err := expandPathImpl(test.path, test.relativeDir, mockCurrentUser, mockLookupUser)
|
|
|
|
+ if (err != nil) != test.shouldErr {
|
|
|
|
+ t.Errorf("expandPathImpl(%q) returned error: %v, expected error: %v", test.path, err != nil, test.shouldErr)
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ if result != test.expected && !test.shouldErr {
|
|
|
|
+ t.Errorf("expandPathImpl(%q) = %q, want %q", test.path, result, test.expected)
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ })
|
|
|
|
+
|
|
|
|
+ t.Run("windows tests", func(t *testing.T) {
|
|
|
|
+ if runtime.GOOS != "windows" {
|
|
|
|
+ return
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ tests := []struct {
|
|
|
|
+ path string
|
|
|
|
+ relativeDir string
|
|
|
|
+ expected string
|
|
|
|
+ shouldErr bool
|
|
|
|
+ }{
|
|
|
|
+ {"~", "", "D:\\home\\testuser", false},
|
|
|
|
+ {"~/myfolder/myfile.txt", "", "D:\\home\\testuser\\myfolder\\myfile.txt", false},
|
|
|
|
+ {"~anotheruser/docs/file.txt", "", "D:\\home\\anotheruser\\docs\\file.txt", false},
|
|
|
|
+ {"~nonexistentuser/file.txt", "", "", true},
|
|
|
|
+ {"relative\\path\\to\\file", "", filepath.Join(pwd, "relative\\path\\to\\file"), false},
|
|
|
|
+ {"D:\\absolute\\path\\to\\file", "", "D:\\absolute\\path\\to\\file", false},
|
|
|
|
+ {"D:\\absolute\\path\\to\\file", "someotherdir/", "D:\\absolute\\path\\to\\file", false},
|
|
|
|
+ {".", pwd, pwd, false},
|
|
|
|
+ {".", "", pwd, false},
|
|
|
|
+ {"somefile", "somedir", filepath.Join(pwd, "somedir", "somefile"), false},
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ for _, test := range tests {
|
|
|
|
+ result, err := expandPathImpl(test.path, test.relativeDir, mockCurrentUser, mockLookupUser)
|
|
|
|
+ if (err != nil) != test.shouldErr {
|
|
|
|
+ t.Errorf("expandPathImpl(%q) returned error: %v, expected error: %v", test.path, err != nil, test.shouldErr)
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ if result != test.expected && !test.shouldErr {
|
|
|
|
+ t.Errorf("expandPathImpl(%q) = %q, want %q", test.path, result, test.expected)
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ })
|
|
}
|
|
}
|