summaryrefslogtreecommitdiffstats
path: root/pkg/container/linux_container_environment_extensions_test.go
diff options
context:
space:
mode:
Diffstat (limited to 'pkg/container/linux_container_environment_extensions_test.go')
-rw-r--r--pkg/container/linux_container_environment_extensions_test.go71
1 files changed, 71 insertions, 0 deletions
diff --git a/pkg/container/linux_container_environment_extensions_test.go b/pkg/container/linux_container_environment_extensions_test.go
new file mode 100644
index 0000000..3811171
--- /dev/null
+++ b/pkg/container/linux_container_environment_extensions_test.go
@@ -0,0 +1,71 @@
+package container
+
+import (
+ "fmt"
+ "os"
+ "runtime"
+ "strings"
+ "testing"
+
+ log "github.com/sirupsen/logrus"
+ "github.com/stretchr/testify/assert"
+)
+
+func TestContainerPath(t *testing.T) {
+ type containerPathJob struct {
+ destinationPath string
+ sourcePath string
+ workDir string
+ }
+
+ linuxcontainerext := &LinuxContainerEnvironmentExtensions{}
+
+ if runtime.GOOS == "windows" {
+ cwd, err := os.Getwd()
+ if err != nil {
+ log.Error(err)
+ }
+
+ rootDrive := os.Getenv("SystemDrive")
+ rootDriveLetter := strings.ReplaceAll(strings.ToLower(rootDrive), `:`, "")
+ for _, v := range []containerPathJob{
+ {"/mnt/c/Users/act/go/src/github.com/nektos/act", "C:\\Users\\act\\go\\src\\github.com\\nektos\\act\\", ""},
+ {"/mnt/f/work/dir", `F:\work\dir`, ""},
+ {"/mnt/c/windows/to/unix", "windows\\to\\unix", fmt.Sprintf("%s\\", rootDrive)},
+ {fmt.Sprintf("/mnt/%v/act", rootDriveLetter), "act", fmt.Sprintf("%s\\", rootDrive)},
+ } {
+ if v.workDir != "" {
+ if err := os.Chdir(v.workDir); err != nil {
+ log.Error(err)
+ t.Fail()
+ }
+ }
+
+ assert.Equal(t, v.destinationPath, linuxcontainerext.ToContainerPath(v.sourcePath))
+ }
+
+ if err := os.Chdir(cwd); err != nil {
+ log.Error(err)
+ }
+ } else {
+ cwd, err := os.Getwd()
+ if err != nil {
+ log.Error(err)
+ }
+ for _, v := range []containerPathJob{
+ {"/home/act/go/src/github.com/nektos/act", "/home/act/go/src/github.com/nektos/act", ""},
+ {"/home/act", `/home/act/`, ""},
+ {cwd, ".", ""},
+ } {
+ assert.Equal(t, v.destinationPath, linuxcontainerext.ToContainerPath(v.sourcePath))
+ }
+ }
+}
+
+type typeAssertMockContainer struct {
+ Container
+ LinuxContainerEnvironmentExtensions
+}
+
+// Type assert Container + LinuxContainerEnvironmentExtensions implements ExecutionsEnvironment
+var _ ExecutionsEnvironment = &typeAssertMockContainer{}