summaryrefslogtreecommitdiffstats
path: root/filter_test.go
blob: c56a937661dd3e1a7f4b7b19ab0b05ca3ee6370a (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
package ldap

import (
	"github.com/tmfkams/asn1-ber"
	"testing"
)

type compile_test struct {
	filter_str  string
	filter_type int
}

var test_filters = []compile_test{
	compile_test{filter_str: "(&(sn=Miller)(givenName=Bob))", filter_type: FilterAnd},
	compile_test{filter_str: "(|(sn=Miller)(givenName=Bob))", filter_type: FilterOr},
	compile_test{filter_str: "(!(sn=Miller))", filter_type: FilterNot},
	compile_test{filter_str: "(sn=Miller)", filter_type: FilterEqualityMatch},
	compile_test{filter_str: "(sn=Mill*)", filter_type: FilterSubstrings},
	compile_test{filter_str: "(sn=*Mill)", filter_type: FilterSubstrings},
	compile_test{filter_str: "(sn=*Mill*)", filter_type: FilterSubstrings},
	compile_test{filter_str: "(sn>=Miller)", filter_type: FilterGreaterOrEqual},
	compile_test{filter_str: "(sn<=Miller)", filter_type: FilterLessOrEqual},
	compile_test{filter_str: "(sn=*)", filter_type: FilterPresent},
	compile_test{filter_str: "(sn~=Miller)", filter_type: FilterApproxMatch},
	// compile_test{ filter_str: "()", filter_type: FilterExtensibleMatch },
}

func TestFilter(t *testing.T) {
	// Test Compiler and Decompiler
	for _, i := range test_filters {
		filter, err := CompileFilter(i.filter_str)
		if err != nil {
			t.Errorf("Problem compiling %s - %s", err.String())
		} else if filter.Tag != uint8(i.filter_type) {
			t.Errorf("%q Expected %q got %q", i.filter_str, FilterMap[uint64(i.filter_type)], FilterMap[uint64(filter.Tag)])
		} else {
			o, err := DecompileFilter(filter)
			if err != nil {
				t.Errorf("Problem compiling %s - %s", i, err.String())
			} else if i.filter_str != o {
				t.Errorf("%q expected, got %q", i.filter_str, o)
			}
		}
	}
}

func BenchmarkFilterCompile(b *testing.B) {
	b.StopTimer()
	filters := make([]string, len(test_filters))

	// Test Compiler and Decompiler
	for idx, i := range test_filters {
		filters[idx] = i.filter_str
	}

	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(test_filters))

	// Test Compiler and Decompiler
	for idx, i := range test_filters {
		filters[idx], _ = CompileFilter(i.filter_str)
	}

	max_idx := len(filters)
	b.StartTimer()
	for i := 0; i < b.N; i++ {
		DecompileFilter(filters[i%max_idx])
	}
}