From 533e2598402442acf747ed2b2cee9601f5a9ae0b Mon Sep 17 00:00:00 2001 From: Ana Krivokapic Date: Tue, 25 Oct 2022 12:13:38 +0200 Subject: [PATCH] Make GetPathRelativeTo() resolve symbolic links --- files/paths.go | 14 ++++++++++++-- files/paths_test.go | 7 ++++++- fixtures/files/child/.gitkeep | 0 .../other-root/sub-child/sub-sub-child/.gitkeep | 0 .../root/child/sub-child/sub-sub-child/.gitkeep | 0 fixtures/files/root/other-child/sub-child/.gitkeep | 0 6 files changed, 18 insertions(+), 3 deletions(-) create mode 100644 fixtures/files/child/.gitkeep create mode 100644 fixtures/files/other-root/sub-child/sub-sub-child/.gitkeep create mode 100644 fixtures/files/root/child/sub-child/sub-sub-child/.gitkeep create mode 100644 fixtures/files/root/other-child/sub-child/.gitkeep diff --git a/files/paths.go b/files/paths.go index 9ebe407..c930de2 100644 --- a/files/paths.go +++ b/files/paths.go @@ -77,12 +77,22 @@ func GetPathRelativeTo(path string, basePath string) (string, error) { basePath = "." } - inputFolderAbs, err := filepath.Abs(basePath) + basePathEvaluated, err := filepath.EvalSymlinks(basePath) if err != nil { return "", errors.WithStackTrace(err) } - fileAbs, err := filepath.Abs(path) + inputFolderAbs, err := filepath.Abs(basePathEvaluated) + if err != nil { + return "", errors.WithStackTrace(err) + } + + pathEvaluated, err := filepath.EvalSymlinks(path) + if err != nil { + return "", errors.WithStackTrace(err) + } + + fileAbs, err := filepath.Abs(pathEvaluated) if err != nil { return "", errors.WithStackTrace(err) } diff --git a/files/paths_test.go b/files/paths_test.go index 16e384b..fdae385 100644 --- a/files/paths_test.go +++ b/files/paths_test.go @@ -1,6 +1,7 @@ package files import ( + "path/filepath" "regexp" "testing" @@ -27,8 +28,12 @@ func TestGetPathRelativeTo(t *testing.T) { {"/root", "/other-root/sub-child/sub-sub-child", "../../../root"}, } + fixtureRoot := "../fixtures/files" + for _, testCase := range testCases { - actual, err := GetPathRelativeTo(testCase.path, testCase.basePath) + path := filepath.Join(fixtureRoot, testCase.path) + basePath := filepath.Join(fixtureRoot, testCase.basePath) + actual, err := GetPathRelativeTo(path, basePath) assert.Nil(t, err, "Unexpected error for path %s and basePath %s: %v", testCase.path, testCase.basePath, err) assert.Equal(t, testCase.expected, actual, "For path %s and basePath %s", testCase.path, testCase.basePath) } diff --git a/fixtures/files/child/.gitkeep b/fixtures/files/child/.gitkeep new file mode 100644 index 0000000..e69de29 diff --git a/fixtures/files/other-root/sub-child/sub-sub-child/.gitkeep b/fixtures/files/other-root/sub-child/sub-sub-child/.gitkeep new file mode 100644 index 0000000..e69de29 diff --git a/fixtures/files/root/child/sub-child/sub-sub-child/.gitkeep b/fixtures/files/root/child/sub-child/sub-sub-child/.gitkeep new file mode 100644 index 0000000..e69de29 diff --git a/fixtures/files/root/other-child/sub-child/.gitkeep b/fixtures/files/root/other-child/sub-child/.gitkeep new file mode 100644 index 0000000..e69de29