// Copyright 2020 The Go Authors. All rights reserved. // Use of this source code is governed by a BSD-style // license that can be found in the LICENSE file. package str import ( "os" "runtime" "testing" ) var foldDupTests = []struct { list []string f1, f2 string }{ {StringList("math/rand", "math/big"), "", ""}, {StringList("math", "strings"), "", ""}, {StringList("strings"), "", ""}, {StringList("strings", "strings"), "strings", "strings"}, {StringList("Rand", "rand", "math", "math/rand", "math/Rand"), "Rand", "rand"}, } func TestFoldDup(t *testing.T) { for _, tt := range foldDupTests { f1, f2 := FoldDup(tt.list) if f1 != tt.f1 || f2 != tt.f2 { t.Errorf("foldDup(%q) = %q, %q, want %q, %q", tt.list, f1, f2, tt.f1, tt.f2) } } } type trimFilePathPrefixTest struct { s, prefix, want string } func TestTrimFilePathPrefixSlash(t *testing.T) { if os.PathSeparator != '/' { t.Skipf("test requires slash-separated file paths") } tests := []trimFilePathPrefixTest{ {"/foo", "", "foo"}, {"/foo", "/", "foo"}, {"/foo", "/foo", ""}, {"/foo/bar", "/foo", "bar"}, {"/foo/bar", "/foo/", "bar"}, // if prefix is not s's prefix, return s {"/foo", "/bar", "/foo"}, {"/foo", "/foo/bar", "/foo"}, } for _, tt := range tests { if got := TrimFilePathPrefix(tt.s, tt.prefix); got != tt.want { t.Errorf("TrimFilePathPrefix(%q, %q) = %q, want %q", tt.s, tt.prefix, got, tt.want) } } } func TestTrimFilePathPrefixWindows(t *testing.T) { if runtime.GOOS != "windows" { t.Skipf("test requires Windows file paths") } tests := []trimFilePathPrefixTest{ {`C:\foo`, `C:`, `foo`}, {`C:\foo`, `C:\`, `foo`}, {`C:\foo`, `C:\foo`, ``}, {`C:\foo\bar`, `C:\foo`, `bar`}, {`C:\foo\bar`, `C:\foo\`, `bar`}, // if prefix is not s's prefix, return s {`C:\foo`, `C:\bar`, `C:\foo`}, {`C:\foo`, `C:\foo\bar`, `C:\foo`}, // if volumes are different, return s {`C:\foo`, ``, `C:\foo`}, {`C:\foo`, `\foo`, `C:\foo`}, {`C:\foo`, `D:\foo`, `C:\foo`}, //UNC path {`\\host\share\foo`, `\\host\share`, `foo`}, {`\\host\share\foo`, `\\host\share\`, `foo`}, {`\\host\share\foo`, `\\host\share\foo`, ``}, {`\\host\share\foo\bar`, `\\host\share\foo`, `bar`}, {`\\host\share\foo\bar`, `\\host\share\foo\`, `bar`}, // if prefix is not s's prefix, return s {`\\host\share\foo`, `\\host\share\bar`, `\\host\share\foo`}, {`\\host\share\foo`, `\\host\share\foo\bar`, `\\host\share\foo`}, // if either host or share name is different, return s {`\\host\share\foo`, ``, `\\host\share\foo`}, {`\\host\share\foo`, `\foo`, `\\host\share\foo`}, {`\\host\share\foo`, `\\host\other\`, `\\host\share\foo`}, {`\\host\share\foo`, `\\other\share\`, `\\host\share\foo`}, {`\\host\share\foo`, `\\host\`, `\\host\share\foo`}, {`\\host\share\foo`, `\share\`, `\\host\share\foo`}, } for _, tt := range tests { if got := TrimFilePathPrefix(tt.s, tt.prefix); got != tt.want { t.Errorf("TrimFilePathPrefix(%q, %q) = %q, want %q", tt.s, tt.prefix, got, tt.want) } } }