| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278 |
- package strmatcher_test
- import (
- "reflect"
- "testing"
- "github.com/v2fly/v2ray-core/v5/common"
- . "github.com/v2fly/v2ray-core/v5/common/strmatcher"
- )
- func TestMphMatcherGroup(t *testing.T) {
- cases1 := []struct {
- pattern string
- mType Type
- input string
- output bool
- }{
- {
- pattern: "v2fly.org",
- mType: Domain,
- input: "www.v2fly.org",
- output: true,
- },
- {
- pattern: "v2fly.org",
- mType: Domain,
- input: "v2fly.org",
- output: true,
- },
- {
- pattern: "v2fly.org",
- mType: Domain,
- input: "www.v3fly.org",
- output: false,
- },
- {
- pattern: "v2fly.org",
- mType: Domain,
- input: "2fly.org",
- output: false,
- },
- {
- pattern: "v2fly.org",
- mType: Domain,
- input: "xv2fly.org",
- output: false,
- },
- {
- pattern: "v2fly.org",
- mType: Full,
- input: "v2fly.org",
- output: true,
- },
- {
- pattern: "v2fly.org",
- mType: Full,
- input: "xv2fly.org",
- output: false,
- },
- }
- for _, test := range cases1 {
- mph := NewMphMatcherGroup()
- matcher, err := test.mType.New(test.pattern)
- common.Must(err)
- common.Must(AddMatcherToGroup(mph, matcher, 0))
- mph.Build()
- if m := mph.MatchAny(test.input); m != test.output {
- t.Error("unexpected output: ", m, " for test case ", test)
- }
- }
- {
- cases2Input := []struct {
- pattern string
- mType Type
- }{
- {
- pattern: "163.com",
- mType: Domain,
- },
- {
- pattern: "m.126.com",
- mType: Full,
- },
- {
- pattern: "3.com",
- mType: Full,
- },
- }
- mph := NewMphMatcherGroup()
- for _, test := range cases2Input {
- matcher, err := test.mType.New(test.pattern)
- common.Must(err)
- common.Must(AddMatcherToGroup(mph, matcher, 0))
- }
- mph.Build()
- cases2Output := []struct {
- pattern string
- res bool
- }{
- {
- pattern: "126.com",
- res: false,
- },
- {
- pattern: "m.163.com",
- res: true,
- },
- {
- pattern: "mm163.com",
- res: false,
- },
- {
- pattern: "m.126.com",
- res: true,
- },
- {
- pattern: "163.com",
- res: true,
- },
- {
- pattern: "63.com",
- res: false,
- },
- {
- pattern: "oogle.com",
- res: false,
- },
- {
- pattern: "vvgoogle.com",
- res: false,
- },
- }
- for _, test := range cases2Output {
- if m := mph.MatchAny(test.pattern); m != test.res {
- t.Error("unexpected output: ", m, " for test case ", test)
- }
- }
- }
- {
- cases3Input := []struct {
- pattern string
- mType Type
- }{
- {
- pattern: "video.google.com",
- mType: Domain,
- },
- {
- pattern: "gle.com",
- mType: Domain,
- },
- }
- mph := NewMphMatcherGroup()
- for _, test := range cases3Input {
- matcher, err := test.mType.New(test.pattern)
- common.Must(err)
- common.Must(AddMatcherToGroup(mph, matcher, 0))
- }
- mph.Build()
- cases3Output := []struct {
- pattern string
- res bool
- }{
- {
- pattern: "google.com",
- res: false,
- },
- }
- for _, test := range cases3Output {
- if m := mph.MatchAny(test.pattern); m != test.res {
- t.Error("unexpected output: ", m, " for test case ", test)
- }
- }
- }
- }
- // See https://github.com/v2fly/v2ray-core/issues/92#issuecomment-673238489
- func TestMphMatcherGroupAsIndexMatcher(t *testing.T) {
- rules := []struct {
- Type Type
- Domain string
- }{
- // Regex not supported by MphMatcherGroup
- // {
- // Type: Regex,
- // Domain: "apis\\.us$",
- // },
- // Substr not supported by MphMatcherGroup
- // {
- // Type: Substr,
- // Domain: "apis",
- // },
- {
- Type: Domain,
- Domain: "googleapis.com",
- },
- {
- Type: Domain,
- Domain: "com",
- },
- {
- Type: Full,
- Domain: "www.baidu.com",
- },
- // Substr not supported by MphMatcherGroup, We add another matcher to preserve index
- {
- Type: Domain, // Substr,
- Domain: "example.com", // "apis",
- },
- {
- Type: Domain,
- Domain: "googleapis.com",
- },
- {
- Type: Full,
- Domain: "fonts.googleapis.com",
- },
- {
- Type: Full,
- Domain: "www.baidu.com",
- },
- { // This matcher (index 10) is swapped with matcher (index 6) to test that full matcher takes high priority.
- Type: Full,
- Domain: "example.com",
- },
- {
- Type: Domain,
- Domain: "example.com",
- },
- }
- cases := []struct {
- Input string
- Output []uint32
- }{
- {
- Input: "www.baidu.com",
- Output: []uint32{5, 9, 4},
- },
- {
- Input: "fonts.googleapis.com",
- Output: []uint32{8, 3, 7, 4 /*2, 6*/},
- },
- {
- Input: "example.googleapis.com",
- Output: []uint32{3, 7, 4 /*2, 6*/},
- },
- {
- Input: "testapis.us",
- // Output: []uint32{ /*2, 6*/ /*1,*/ },
- Output: nil,
- },
- {
- Input: "example.com",
- Output: []uint32{10, 6, 11, 4},
- },
- }
- matcherGroup := NewMphMatcherGroup()
- for i, rule := range rules {
- matcher, err := rule.Type.New(rule.Domain)
- common.Must(err)
- common.Must(AddMatcherToGroup(matcherGroup, matcher, uint32(i+3)))
- }
- matcherGroup.Build()
- for _, test := range cases {
- if m := matcherGroup.Match(test.Input); !reflect.DeepEqual(m, test.Output) {
- t.Error("unexpected output: ", m, " for test case ", test)
- }
- }
- }
- func TestEmptyMphMatcherGroup(t *testing.T) {
- g := NewMphMatcherGroup()
- g.Build()
- r := g.Match("v2fly.org")
- if len(r) != 0 {
- t.Error("Expect [], but ", r)
- }
- }
|