From 06d091cc609e90974f8da7e7ae153f3c2a83ee46 Mon Sep 17 00:00:00 2001 From: JP Appel Date: Fri, 13 Jun 2025 18:33:34 -0400 Subject: Add only child optimization to query parser --- pkg/query/parser_test.go | 50 ++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 50 insertions(+) (limited to 'pkg/query/parser_test.go') diff --git a/pkg/query/parser_test.go b/pkg/query/parser_test.go index 7ee4987..c1f25d4 100644 --- a/pkg/query/parser_test.go +++ b/pkg/query/parser_test.go @@ -18,6 +18,26 @@ func TestClause_Flatten(t *testing.T) { &query.Clause{}, query.Clause{}, }, + { + "empty with child", + &query.Clause{ + Operator: query.COP_OR, + Clauses: []*query.Clause{ + { + Operator: query.COP_AND, + Statements: []query.Statement{ + {Category: query.CAT_AUTHOR, Operator: query.OP_AP, Value: query.StringValue{"jp"}}, + }, + }, + }, + }, + query.Clause{ + Operator: query.COP_AND, + Statements: []query.Statement{ + {Category: query.CAT_AUTHOR, Operator: query.OP_AP, Value: query.StringValue{"jp"}}, + }, + }, + }, { "already flat", &query.Clause{ @@ -170,3 +190,33 @@ func TestClause_Flatten(t *testing.T) { }) } } + +func TestParse(t *testing.T) { + tests := []struct { + name string // description of this test case + // Named input parameters for target function. + tokens []query.Token + want *query.Clause + wantErr bool + }{ + // TODO: Add test cases. + } + for _, tt := range tests { + t.Run(tt.name, func(t *testing.T) { + got, gotErr := query.Parse(tt.tokens) + if gotErr != nil { + if !tt.wantErr { + t.Errorf("Parse() failed: %v", gotErr) + } + return + } + if tt.wantErr { + t.Fatal("Parse() succeeded unexpectedly") + } + // TODO: update the condition below to compare got with tt.want. + if true { + t.Errorf("Parse() = %v, want %v", got, tt.want) + } + }) + } +} -- cgit v1.2.3