package glob import ( "testing" ) func TestLexGood(t *testing.T) { for id, test := range []struct { pattern string items []item }{ { pattern: "hello", items: []item{ item{item_text, "hello"}, item{item_eof, ""}, }, }, //{ // TODO(gobwas): this is freezing on globtest/globdraw (`]]` syntax error) //pattern: "/{rate,[0-9]]}*", //items: []item{ // item{item_text, "hello"}, // item{item_eof, ""}, //}, //}, { pattern: "hello,world", items: []item{ item{item_text, "hello,world"}, item{item_eof, ""}, }, }, { pattern: "hello\\,world", items: []item{ item{item_text, "hello,world"}, item{item_eof, ""}, }, }, { pattern: "hello\\{world", items: []item{ item{item_text, "hello{world"}, item{item_eof, ""}, }, }, { pattern: "hello?", items: []item{ item{item_text, "hello"}, item{item_single, "?"}, item{item_eof, ""}, }, }, { pattern: "hellof*", items: []item{ item{item_text, "hellof"}, item{item_any, "*"}, item{item_eof, ""}, }, }, { pattern: "hello**", items: []item{ item{item_text, "hello"}, item{item_super, "**"}, item{item_eof, ""}, }, }, { pattern: "[日-語]", items: []item{ item{item_range_open, "["}, item{item_range_lo, "日"}, item{item_range_between, "-"}, item{item_range_hi, "語"}, item{item_range_close, "]"}, item{item_eof, ""}, }, }, { pattern: "[!日-語]", items: []item{ item{item_range_open, "["}, item{item_not, "!"}, item{item_range_lo, "日"}, item{item_range_between, "-"}, item{item_range_hi, "語"}, item{item_range_close, "]"}, item{item_eof, ""}, }, }, { pattern: "[日本語]", items: []item{ item{item_range_open, "["}, item{item_text, "日本語"}, item{item_range_close, "]"}, item{item_eof, ""}, }, }, { pattern: "[!日本語]", items: []item{ item{item_range_open, "["}, item{item_not, "!"}, item{item_text, "日本語"}, item{item_range_close, "]"}, item{item_eof, ""}, }, }, { pattern: "{a,b}", items: []item{ item{item_terms_open, "{"}, item{item_text, "a"}, item{item_separator, ","}, item{item_text, "b"}, item{item_terms_close, "}"}, item{item_eof, ""}, }, }, { pattern: "/{z,ab}*", items: []item{ item{item_text, "/"}, item{item_terms_open, "{"}, item{item_text, "z"}, item{item_separator, ","}, item{item_text, "ab"}, item{item_terms_close, "}"}, item{item_any, "*"}, item{item_eof, ""}, }, }, { pattern: "{[!日-語],*,?,{a,b,\\c}}", items: []item{ item{item_terms_open, "{"}, item{item_range_open, "["}, item{item_not, "!"}, item{item_range_lo, "日"}, item{item_range_between, "-"}, item{item_range_hi, "語"}, item{item_range_close, "]"}, item{item_separator, ","}, item{item_any, "*"}, item{item_separator, ","}, item{item_single, "?"}, item{item_separator, ","}, item{item_terms_open, "{"}, item{item_text, "a"}, item{item_separator, ","}, item{item_text, "b"}, item{item_separator, ","}, item{item_text, "c"}, item{item_terms_close, "}"}, item{item_terms_close, "}"}, item{item_eof, ""}, }, }, } { lexer := newLexer(test.pattern) for i, exp := range test.items { act := lexer.nextItem() if act.t != exp.t { t.Errorf("#%d %q: wrong %d-th item type: exp: %q; act: %q\n\t(%s vs %s)", id, test.pattern, i, exp.t, act.t, exp, act) } if act.s != exp.s { t.Errorf("#%d %q: wrong %d-th item contents: exp: %q; act: %q\n\t(%s vs %s)", id, test.pattern, i, exp.s, act.s, exp, act) } } } }