Use runtime.GOOS to identify Windows specific path tests
authorbep <bjorn.erik.pedersen@gmail.com>
Tue, 27 Jan 2015 22:01:32 +0000 (23:01 +0100)
committerbep <bjorn.erik.pedersen@gmail.com>
Tue, 27 Jan 2015 22:01:32 +0000 (23:01 +0100)
helpers/path_test.go
helpers/path_unix_test.go [deleted file]
helpers/path_windows_test.go [deleted file]

index 366ed6e4c87fd21397e24c08fbd97b86efe86a00..bc0a547901a009a627f304e18a2e7c482d3dcd94 100644 (file)
@@ -6,6 +6,7 @@ import (
        "io/ioutil"
        "os"
        "path/filepath"
+       "runtime"
        "strconv"
        "strings"
        "testing"
@@ -398,6 +399,16 @@ func TestAbsPathify(t *testing.T) {
                {"dir", filepath.FromSlash("/work"), filepath.FromSlash("/work/dir")},
        }
 
+       windowsData := []test{
+               {"c:\\banana\\..\\dir", "c:\\foo", "c:\\dir"},
+               {"\\dir", "c:\\foo", "c:\\foo\\dir"},
+               {"c:\\", "c:\\foo", "c:\\"},
+       }
+
+       unixData := []test{
+               {"/banana/../dir/", "/work", "/dir"},
+       }
+
        for i, d := range data {
                // todo see comment in AbsPathify
                viper.Set("WorkingDir", d.workingDir)
@@ -407,6 +418,27 @@ func TestAbsPathify(t *testing.T) {
                        t.Errorf("Test %d failed. Expected %q but got %q", i, d.expected, expected)
                }
        }
+       t.Logf("Running platform specific path tests for %s", runtime.GOOS)
+       if runtime.GOOS == "windows" {
+               for i, d := range windowsData {
+                       viper.Set("WorkingDir", d.workingDir)
+
+                       expected := AbsPathify(d.inPath)
+                       if d.expected != expected {
+                               t.Errorf("Test %d failed. Expected %q but got %q", i, d.expected, expected)
+                       }
+               }
+       } else {
+               for i, d := range unixData {
+                       viper.Set("WorkingDir", d.workingDir)
+
+                       expected := AbsPathify(d.inPath)
+                       if d.expected != expected {
+                               t.Errorf("Test %d failed. Expected %q but got %q", i, d.expected, expected)
+                       }
+               }
+       }
+
 }
 
 func TestFilename(t *testing.T) {
diff --git a/helpers/path_unix_test.go b/helpers/path_unix_test.go
deleted file mode 100644 (file)
index d9f73c6..0000000
+++ /dev/null
@@ -1,27 +0,0 @@
-// +build !windows
-
-package helpers
-
-import (
-       "github.com/spf13/viper"
-       "testing"
-)
-
-func TestPlatformAbsPathify(t *testing.T) {
-       type test struct {
-               inPath, workingDir, expected string
-       }
-       data := []test{
-               {"/banana/../dir/", "/work", "/dir"},
-       }
-
-       for i, d := range data {
-               // todo see comment in AbsPathify
-               viper.Set("WorkingDir", d.workingDir)
-
-               expected := AbsPathify(d.inPath)
-               if d.expected != expected {
-                       t.Errorf("Test %d failed. Expected %q but got %q", i, d.expected, expected)
-               }
-       }
-}
diff --git a/helpers/path_windows_test.go b/helpers/path_windows_test.go
deleted file mode 100644 (file)
index 22b24ce..0000000
+++ /dev/null
@@ -1,27 +0,0 @@
-package helpers
-
-import (
-       "github.com/spf13/viper"
-       "testing"
-)
-
-func TestPlatformAbsPathify(t *testing.T) {
-       type test struct {
-               inPath, workingDir, expected string
-       }
-       data := []test{
-               {"c:\\banana\\..\\dir", "c:\\foo", "c:\\dir"},
-               {"\\dir", "c:\\foo", "c:\\foo\\dir"},
-               {"c:\\", "c:\\foo", "c:\\"},
-       }
-
-       for i, d := range data {
-               // todo see comment in AbsPathify
-               viper.Set("WorkingDir", d.workingDir)
-
-               expected := AbsPathify(d.inPath)
-               if d.expected != expected {
-                       t.Errorf("Test %d failed. Expected %q but got %q", i, d.expected, expected)
-               }
-       }
-}