2020-12-21 09:24:24 +08:00
|
|
|
package webseed
|
|
|
|
|
|
|
|
import (
|
|
|
|
"net/url"
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
qt "github.com/frankban/quicktest"
|
|
|
|
)
|
|
|
|
|
2022-12-23 08:18:36 +08:00
|
|
|
func TestDefaultPathEscaper(t *testing.T) {
|
2020-12-21 09:24:24 +08:00
|
|
|
c := qt.New(t)
|
2022-12-23 08:18:36 +08:00
|
|
|
test := func(unescaped string, parts ...string) {
|
2022-12-25 15:20:23 +08:00
|
|
|
assertPartsUnescape(c, unescaped, parts...)
|
2020-12-21 09:24:24 +08:00
|
|
|
}
|
2022-12-25 15:20:23 +08:00
|
|
|
for _, tc := range defaultPathEscapeTestCases {
|
|
|
|
test(tc.escaped, tc.parts...)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// So we can manually check, and use these to seed fuzzing.
|
|
|
|
var defaultPathEscapeTestCases = []struct {
|
|
|
|
escaped string
|
|
|
|
parts []string
|
|
|
|
}{
|
|
|
|
{"/", []string{"", ""}},
|
|
|
|
{"a_b-c/d + e.f", []string{"a_b-c", "d + e.f"}},
|
|
|
|
{"a_1-b_c2/d 3. (e, f).g", []string{"a_1-b_c2", "d 3. (e, f).g"}},
|
|
|
|
{"a_b-c/d + e.f", []string{"a_b-c", "d + e.f"}},
|
|
|
|
{"a_1-b_c2/d 3. (e, f).g", []string{"a_1-b_c2", "d 3. (e, f).g"}},
|
|
|
|
{"war/and/peace", []string{"war", "and", "peace"}},
|
|
|
|
{"he//o#world/world", []string{"he//o#world", "world"}},
|
|
|
|
{`ノ┬─┬ノ ︵ ( \o°o)\`, []string{`ノ┬─┬ノ ︵ ( \o°o)\`}},
|
|
|
|
{
|
|
|
|
`%aa + %bb/Parsi Tv - سرقت و باز کردن در ماشین در کمتر از ۳ ثانیه + فیلم.webm`,
|
|
|
|
[]string{`%aa + %bb`, `Parsi Tv - سرقت و باز کردن در ماشین در کمتر از ۳ ثانیه + فیلم.webm`},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
func assertPartsUnescape(c *qt.C, unescaped string, parts ...string) {
|
|
|
|
escaped := defaultPathEscaper(parts)
|
|
|
|
pathUnescaped, err := url.PathUnescape(escaped)
|
|
|
|
c.Assert(err, qt.IsNil)
|
|
|
|
c.Assert(pathUnescaped, qt.Equals, unescaped)
|
|
|
|
queryUnescaped, err := url.QueryUnescape(escaped)
|
|
|
|
c.Assert(err, qt.IsNil)
|
|
|
|
c.Assert(queryUnescaped, qt.Equals, unescaped)
|
|
|
|
}
|
|
|
|
|
|
|
|
func FuzzDefaultPathEscaper(f *testing.F) {
|
|
|
|
for _, tc := range defaultPathEscapeTestCases {
|
|
|
|
if len(tc.parts) == 2 {
|
|
|
|
f.Add(tc.parts[0], tc.parts[1])
|
|
|
|
}
|
|
|
|
}
|
|
|
|
// I think a single separator is enough to test special handling around /. Also fuzzing doesn't
|
|
|
|
// let us take []string as an input.
|
|
|
|
f.Fuzz(func(t *testing.T, first, second string) {
|
|
|
|
assertPartsUnescape(qt.New(t), first+"/"+second, first, second)
|
|
|
|
})
|
2022-03-11 09:03:18 +08:00
|
|
|
}
|