package ldap import ( "testing" "github.com/SpruceHealth/asn1-ber" ) type compileTest struct { filterStr string filterType int } var testFilters = []compileTest{ compileTest{filterStr: "(&(sn=Miller)(givenName=Bob))", filterType: FilterAnd}, compileTest{filterStr: "(|(sn=Miller)(givenName=Bob))", filterType: FilterOr}, compileTest{filterStr: "(!(sn=Miller))", filterType: FilterNot}, compileTest{filterStr: "(sn=Miller)", filterType: FilterEqualityMatch}, compileTest{filterStr: "(sn=Mill*)", filterType: FilterSubstrings}, compileTest{filterStr: "(sn=*Mill)", filterType: FilterSubstrings}, compileTest{filterStr: "(sn=*Mill*)", filterType: FilterSubstrings}, compileTest{filterStr: "(sn>=Miller)", filterType: FilterGreaterOrEqual}, compileTest{filterStr: "(sn<=Miller)", filterType: FilterLessOrEqual}, compileTest{filterStr: "(sn=*)", filterType: FilterPresent}, compileTest{filterStr: "(sn~=Miller)", filterType: FilterApproxMatch}, // compileTest{ filterStr: "()", filterType: FilterExtensibleMatch }, } func TestFilter(t *testing.T) { // Test Compiler and Decompiler for _, i := range testFilters { filter, err := CompileFilter(i.filterStr) if err != nil { t.Errorf("Problem compiling %s - %s", i.filterStr, err.String()) } else if filter.Tag != uint8(i.filterType) { t.Errorf("%q Expected %q got %q", i.filterStr, FilterMap[uint64(i.filterType)], FilterMap[uint64(filter.Tag)]) } else { o, err := DecompileFilter(filter) if err != nil { t.Errorf("Problem compiling %s - %s", i.filterStr, err.String()) } else if i.filterStr != o { t.Errorf("%q expected, got %q", i.filterStr, o) } } } } func BenchmarkFilterCompile(b *testing.B) { b.StopTimer() filters := make([]string, len(testFilters)) // Test Compiler and Decompiler for idx, i := range testFilters { filters[idx] = i.filterStr } max_idx := len(filters) b.StartTimer() for i := 0; i < b.N; i++ { CompileFilter(filters[i%max_idx]) } } func BenchmarkFilterDecompile(b *testing.B) { b.StopTimer() filters := make([]*ber.Packet, len(testFilters)) // Test Compiler and Decompiler for idx, i := range testFilters { filters[idx], _ = CompileFilter(i.filterStr) } max_idx := len(filters) b.StartTimer() for i := 0; i < b.N; i++ { DecompileFilter(filters[i%max_idx]) } }