From c1538e7fe4637f5cf873d7877d163392c7bdfab3 Mon Sep 17 00:00:00 2001 From: Andrew Sisley Date: Mon, 11 Sep 2023 14:19:08 -0400 Subject: [PATCH] Add test for top-level aggregate with compound relational filter --- .../one_to_one/with_count_filter_test.go | 117 ++++++++++++++++++ 1 file changed, 117 insertions(+) create mode 100644 tests/integration/query/one_to_one/with_count_filter_test.go diff --git a/tests/integration/query/one_to_one/with_count_filter_test.go b/tests/integration/query/one_to_one/with_count_filter_test.go new file mode 100644 index 0000000000..59511e9bd7 --- /dev/null +++ b/tests/integration/query/one_to_one/with_count_filter_test.go @@ -0,0 +1,117 @@ +// Copyright 2023 Democratized Data Foundation +// +// Use of this software is governed by the Business Source License +// included in the file licenses/BSL.txt. +// +// As of the Change Date specified in that file, in accordance with +// the Business Source License, use of this software will be governed +// by the Apache License, Version 2.0, included in the file +// licenses/APL.txt. + +package one_to_one + +import ( + "testing" + + testUtils "github.com/sourcenetwork/defradb/tests/integration" +) + +func TestQueryOneToOneWithCountWithCompoundOrFilterThatIncludesRelation(t *testing.T) { + test := testUtils.TestCase{ + Description: "One-to-one relation with count with _or filter that includes relation", + Actions: []any{ + testUtils.SchemaUpdate{ + Schema: bookAuthorGQLSchema, + }, + testUtils.CreateDoc{ + CollectionID: 0, + // bae-fd541c25-229e-5280-b44b-e5c2af3e374d + Doc: `{ + "name": "Painted House", + "rating": 4.9 + }`, + }, + testUtils.CreateDoc{ + CollectionID: 0, + // bae-f60d6af6-92f7-5f11-9182-1d7273a5a9e8 + Doc: `{ + "name": "Some Book", + "rating": 4.0 + }`, + }, + testUtils.CreateDoc{ + CollectionID: 0, + // bae-1c890922-ddf9-5820-a888-c7f977848934 + Doc: `{ + "name": "Some Other Book", + "rating": 3.5 + }`, + }, + testUtils.CreateDoc{ + CollectionID: 0, + // bae-e8642720-08cb-5f5b-a8d6-7187c444a78d + Doc: `{ + "name": "Yet Another Book", + "rating": 3.0 + }`, + }, + testUtils.CreateDoc{ + CollectionID: 1, + // bae-41598f0c-19bc-5da6-813b-e80f14a10df3 + Doc: `{ + "name": "John Grisham", + "age": 65, + "verified": true, + "published_id": "bae-fd541c25-229e-5280-b44b-e5c2af3e374d" + }`, + }, + testUtils.CreateDoc{ + CollectionID: 1, + Doc: `{ + "name": "Some Writer", + "age": 45, + "verified": false, + "published_id": "bae-f60d6af6-92f7-5f11-9182-1d7273a5a9e8" + }`, + }, + testUtils.CreateDoc{ + CollectionID: 1, + Doc: `{ + "name": "Some Other Writer", + "age": 35, + "verified": false, + "published_id": "bae-1c890922-ddf9-5820-a888-c7f977848934" + }`, + }, + testUtils.CreateDoc{ + CollectionID: 1, + Doc: `{ + "name": "Yet Another Writer", + "age": 30, + "verified": false, + "published_id": "bae-e8642720-08cb-5f5b-a8d6-7187c444a78d" + }`, + }, + testUtils.Request{ + Request: `query { + _count(Book: {filter: {_or: [ + {_not: {author: {age: {_lt: 65}}} }, + {_not: {author: {age: {_gt: 30}}} } + ]}}) + }`, + Results: []map[string]any{ + { + "_count": "2", + }, + }, + }, + }, + } + + testUtils.AssertPanicAndSkipChangeDetection( + t, + func() { + testUtils.ExecuteTestCase(t, test) + }, + ) +}