lib/encoder: fix benchmarks
Some day in the past the Slash encode option was added to Onedrive encoder so it began to encode slashes in file names rather then treat them as path separators. This patch adapts benchmark test cases accordingly. Fixes #5659
This commit is contained in:
parent
f51a5eca2e
commit
e78e73eae7
1 changed files with 80 additions and 23 deletions
|
@ -267,53 +267,110 @@ const oneDrive = (Standard |
|
||||||
|
|
||||||
var benchTests = []struct {
|
var benchTests = []struct {
|
||||||
in string
|
in string
|
||||||
out string
|
outOld string
|
||||||
|
outNew string
|
||||||
}{
|
}{
|
||||||
{"", ""},
|
{
|
||||||
{"abc 123", "abc 123"},
|
"",
|
||||||
{`\*<>?:|#%".~`, `\*<>?:|#%".~`},
|
"",
|
||||||
{`\*<>?:|#%".~/\*<>?:|#%".~`, `\*<>?:|#%".~/\*<>?:|#%".~`},
|
"",
|
||||||
{" leading space", " leading space"},
|
},
|
||||||
{"~leading tilde", "~leading tilde"},
|
{
|
||||||
{"trailing dot.", "trailing dot."},
|
"abc 123",
|
||||||
{" leading space/ leading space/ leading space", " leading space/ leading space/ leading space"},
|
"abc 123",
|
||||||
{"~leading tilde/~leading tilde/~leading tilde", "~leading tilde/~leading tilde/~leading tilde"},
|
"abc 123",
|
||||||
{"leading tilde/~leading tilde", "leading tilde/~leading tilde"},
|
},
|
||||||
{"trailing dot./trailing dot./trailing dot.", "trailing dot./trailing dot./trailing dot."},
|
{
|
||||||
|
`\*<>?:|#%".~`,
|
||||||
|
`\*<>?:|#%".~`,
|
||||||
|
`\*<>?:|#%".~`,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
`\*<>?:|#%".~/\*<>?:|#%".~`,
|
||||||
|
`\*<>?:|#%".~/\*<>?:|#%".~`,
|
||||||
|
`\*<>?:|#%".~/\*<>?:|#%".~`,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
" leading space",
|
||||||
|
" leading space",
|
||||||
|
" leading space",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"~leading tilde",
|
||||||
|
"~leading tilde",
|
||||||
|
"~leading tilde",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"trailing dot.",
|
||||||
|
"trailing dot.",
|
||||||
|
"trailing dot.",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
" leading space/ leading space/ leading space",
|
||||||
|
" leading space/ leading space/ leading space",
|
||||||
|
" leading space/ leading space/ leading space",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"~leading tilde/~leading tilde/~leading tilde",
|
||||||
|
"~leading tilde/~leading tilde/~leading tilde",
|
||||||
|
"~leading tilde/~leading tilde/~leading tilde",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"leading tilde/~leading tilde",
|
||||||
|
"leading tilde/~leading tilde",
|
||||||
|
"leading tilde/~leading tilde",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"trailing dot./trailing dot./trailing dot.",
|
||||||
|
"trailing dot./trailing dot./trailing dot.",
|
||||||
|
"trailing dot./trailing dot./trailing dot.",
|
||||||
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
func benchReplace(b *testing.B, f func(string) string) {
|
func benchReplace(b *testing.B, f func(string) string, old bool) {
|
||||||
for range make([]struct{}, b.N) {
|
for range make([]struct{}, b.N) {
|
||||||
for _, test := range benchTests {
|
for _, test := range benchTests {
|
||||||
got := f(test.in)
|
got := f(test.in)
|
||||||
if got != test.out {
|
out := test.outNew
|
||||||
b.Errorf("Encode(%q) want %q got %q", test.in, test.out, got)
|
if old {
|
||||||
|
out = test.outOld
|
||||||
|
}
|
||||||
|
if got != out {
|
||||||
|
b.Errorf("Encode(%q) want %q got %q", test.in, out, got)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func benchRestore(b *testing.B, f func(string) string) {
|
func benchRestore(b *testing.B, f func(string) string, old bool) {
|
||||||
for range make([]struct{}, b.N) {
|
for range make([]struct{}, b.N) {
|
||||||
for _, test := range benchTests {
|
for _, test := range benchTests {
|
||||||
got := f(test.out)
|
out := test.outNew
|
||||||
|
if old {
|
||||||
|
out = test.outOld
|
||||||
|
}
|
||||||
|
got := f(out)
|
||||||
if got != test.in {
|
if got != test.in {
|
||||||
b.Errorf("Decode(%q) want %q got %q", got, test.in, got)
|
b.Errorf("Decode(%q) want %q got %q", out, test.in, got)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func BenchmarkOneDriveReplaceNew(b *testing.B) {
|
func BenchmarkOneDriveReplaceNew(b *testing.B) {
|
||||||
benchReplace(b, oneDrive.Encode)
|
benchReplace(b, oneDrive.Encode, false)
|
||||||
}
|
}
|
||||||
|
|
||||||
func BenchmarkOneDriveReplaceOld(b *testing.B) {
|
func BenchmarkOneDriveReplaceOld(b *testing.B) {
|
||||||
benchReplace(b, replaceReservedChars)
|
benchReplace(b, replaceReservedChars, true)
|
||||||
}
|
}
|
||||||
|
|
||||||
func BenchmarkOneDriveRestoreNew(b *testing.B) {
|
func BenchmarkOneDriveRestoreNew(b *testing.B) {
|
||||||
benchRestore(b, oneDrive.Decode)
|
benchRestore(b, oneDrive.Decode, false)
|
||||||
}
|
}
|
||||||
|
|
||||||
func BenchmarkOneDriveRestoreOld(b *testing.B) {
|
func BenchmarkOneDriveRestoreOld(b *testing.B) {
|
||||||
benchRestore(b, restoreReservedChars)
|
benchRestore(b, restoreReservedChars, true)
|
||||||
}
|
}
|
||||||
|
|
||||||
var (
|
var (
|
||||||
|
|
Loading…
Reference in a new issue