|
@@ -12,29 +12,46 @@ package fs
|
|
import (
|
|
import (
|
|
"os"
|
|
"os"
|
|
"path/filepath"
|
|
"path/filepath"
|
|
|
|
+ "runtime"
|
|
"strings"
|
|
"strings"
|
|
"syscall"
|
|
"syscall"
|
|
"testing"
|
|
"testing"
|
|
)
|
|
)
|
|
|
|
|
|
func TestWindowsPaths(t *testing.T) {
|
|
func TestWindowsPaths(t *testing.T) {
|
|
- testCases := []struct {
|
|
|
|
|
|
+ type testCase struct {
|
|
input string
|
|
input string
|
|
expectedRoot string
|
|
expectedRoot string
|
|
expectedURI string
|
|
expectedURI string
|
|
- }{
|
|
|
|
|
|
+ }
|
|
|
|
+ testCases := []testCase{
|
|
|
|
+ {`e:`, `\\?\e:\`, `e:\`},
|
|
{`e:\`, `\\?\e:\`, `e:\`},
|
|
{`e:\`, `\\?\e:\`, `e:\`},
|
|
|
|
+ {`e:\\`, `\\?\e:\`, `e:\`},
|
|
|
|
+ {`\\?\e:`, `\\?\e:\`, `e:\`},
|
|
{`\\?\e:\`, `\\?\e:\`, `e:\`},
|
|
{`\\?\e:\`, `\\?\e:\`, `e:\`},
|
|
|
|
+ {`\\?\e:\\`, `\\?\e:\`, `e:\`},
|
|
|
|
+ {`e:\x`, `\\?\e:\x`, `e:\x`},
|
|
|
|
+ {`e:\x\`, `\\?\e:\x`, `e:\x`},
|
|
|
|
+ {`e:\x\\`, `\\?\e:\x`, `e:\x`},
|
|
{`\\192.0.2.22\network\share`, `\\192.0.2.22\network\share`, `\\192.0.2.22\network\share`},
|
|
{`\\192.0.2.22\network\share`, `\\192.0.2.22\network\share`, `\\192.0.2.22\network\share`},
|
|
}
|
|
}
|
|
|
|
|
|
- for _, testCase := range testCases {
|
|
|
|
|
|
+ if runtime.Version() >= "go1.20" {
|
|
|
|
+ testCases = append(testCases,
|
|
|
|
+ testCase{`\\.\e:`, `\\.\e:\`, `e:\`},
|
|
|
|
+ testCase{`\\.\e:\`, `\\.\e:\`, `e:\`},
|
|
|
|
+ testCase{`\\.\e:\\`, `\\.\e:\`, `e:\`},
|
|
|
|
+ )
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ for i, testCase := range testCases {
|
|
fs := newBasicFilesystem(testCase.input)
|
|
fs := newBasicFilesystem(testCase.input)
|
|
if fs.root != testCase.expectedRoot {
|
|
if fs.root != testCase.expectedRoot {
|
|
- t.Errorf("root %q != %q", fs.root, testCase.expectedRoot)
|
|
|
|
|
|
+ t.Errorf("test %d: root: expected `%s`, got `%s`", i, testCase.expectedRoot, fs.root)
|
|
}
|
|
}
|
|
if fs.URI() != testCase.expectedURI {
|
|
if fs.URI() != testCase.expectedURI {
|
|
- t.Errorf("uri %q != %q", fs.URI(), testCase.expectedURI)
|
|
|
|
|
|
+ t.Errorf("test %d: uri: expected `%s`, got `%s`", i, testCase.expectedURI, fs.URI())
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
@@ -195,7 +212,7 @@ func TestGetFinalPath(t *testing.T) {
|
|
}
|
|
}
|
|
|
|
|
|
func TestRemoveWindowsDirIcon(t *testing.T) {
|
|
func TestRemoveWindowsDirIcon(t *testing.T) {
|
|
- //Try to delete a folder with a custom icon with os.Remove (simulated by the readonly file attribute)
|
|
|
|
|
|
+ // Try to delete a folder with a custom icon with os.Remove (simulated by the readonly file attribute)
|
|
|
|
|
|
fs, dir := setup(t)
|
|
fs, dir := setup(t)
|
|
relativePath := "folder_with_icon"
|
|
relativePath := "folder_with_icon"
|