From 38a5e2a4873ed8af0b759056575e09dc697a56ca Mon Sep 17 00:00:00 2001 From: Tim Holm Date: Mon, 19 Jul 2021 13:18:40 +1000 Subject: [PATCH 01/16] chore: Update contracts. --- contracts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/contracts b/contracts index b3fb50e5f..ae6424762 160000 --- a/contracts +++ b/contracts @@ -1 +1 @@ -Subproject commit b3fb50e5f22df8327245f41ffc3f052216c903f9 +Subproject commit ae64247620dfa3229491243b5466b0584425705a From c07237471ecf5770347f84d0dda9a97538e40232 Mon Sep 17 00:00:00 2001 From: Tim Holm Date: Mon, 19 Jul 2021 13:19:54 +1000 Subject: [PATCH 02/16] feat(documents): Add key to document SDK and add translation to adapters. --- pkg/adapters/grpc/document_grpc.go | 23 +++++++++++++++++++++++ pkg/sdk/document.go | 1 + 2 files changed, 24 insertions(+) diff --git a/pkg/adapters/grpc/document_grpc.go b/pkg/adapters/grpc/document_grpc.go index 14356b6cf..d22d3484d 100644 --- a/pkg/adapters/grpc/document_grpc.go +++ b/pkg/adapters/grpc/document_grpc.go @@ -118,6 +118,7 @@ func documentToWire(doc *sdk.Document) (*pb.Document, error) { return &pb.Document{ Content: valStruct, + Key: keyToWire(doc.Key), }, nil } @@ -136,6 +137,28 @@ func keyFromWire(key *pb.Key) *sdk.Key { return sdkKey } +// keyToWire - translates an SDK key to a gRPC key +func keyToWire(key *sdk.Key) *pb.Key { + return &pb.Key{ + Id: key.Id, + Collection: collectionToWire(key.Collection), + } +} + +// collectionToWire - translates a SDK collection to a gRPC collection +func collectionToWire(col *sdk.Collection) *pb.Collection { + if col.Parent != nil { + return &pb.Collection{ + Name: col.Name, + Parent: keyToWire(col.Parent), + } + } else { + return &pb.Collection{ + Name: col.Name, + } + } +} + // collectionFromWire - returns an Membrane SDK Document Collection from the protobuf wire representation // recursively calls keyFromWire if the collection is a sub-collection under another key func collectionFromWire(coll *pb.Collection) *sdk.Collection { diff --git a/pkg/sdk/document.go b/pkg/sdk/document.go index 2cbb8a7f2..a5344533a 100644 --- a/pkg/sdk/document.go +++ b/pkg/sdk/document.go @@ -37,6 +37,7 @@ func (k *Key) String() string { } type Document struct { + Key *Key Content map[string]interface{} } From b96848f753199e57acc7af1976117d9d5702208c Mon Sep 17 00:00:00 2001 From: Tim Holm Date: Mon, 19 Jul 2021 14:59:32 +1000 Subject: [PATCH 03/16] feat(documents/boltdb): Return Key on boltdb queries and gets. --- pkg/plugins/document/boltdb/boltdb.go | 31 +++++++++++++++++++++------ 1 file changed, 24 insertions(+), 7 deletions(-) diff --git a/pkg/plugins/document/boltdb/boltdb.go b/pkg/plugins/document/boltdb/boltdb.go index 323d9836d..cdcb5102d 100644 --- a/pkg/plugins/document/boltdb/boltdb.go +++ b/pkg/plugins/document/boltdb/boltdb.go @@ -16,13 +16,14 @@ package boltdb_service import ( "fmt" - "github.com/nitric-dev/membrane/pkg/plugins/document" - "github.com/nitric-dev/membrane/pkg/utils" "os" "strconv" "strings" "time" + "github.com/nitric-dev/membrane/pkg/plugins/document" + "github.com/nitric-dev/membrane/pkg/utils" + "github.com/Knetic/govaluate" "github.com/asdine/storm" "github.com/asdine/storm/q" @@ -73,7 +74,7 @@ func (s *BoltDocService) Get(key *sdk.Key) (*sdk.Document, error) { return nil, err } - return toSdkDoc(doc), nil + return toSdkDoc(key.Collection, doc), nil } func (s *BoltDocService) Set(key *sdk.Key, content map[string]interface{}) error { @@ -217,12 +218,12 @@ func (s *BoltDocService) Query(collection *sdk.Collection, expressions []sdk.Que } include := eval.(bool) if include { - sdkDoc := toSdkDoc(doc) + sdkDoc := toSdkDoc(collection, doc) documents = append(documents, *sdkDoc) } } else { - sdkDoc := toSdkDoc(doc) + sdkDoc := toSdkDoc(collection, doc) documents = append(documents, *sdkDoc) } @@ -281,7 +282,6 @@ func (s *BoltDocService) createdDb(coll sdk.Collection) (*storm.DB, error) { } func createDoc(key *sdk.Key) BoltDoc { - parentKey := key.Collection.Parent // Top Level Collection @@ -301,8 +301,25 @@ func createDoc(key *sdk.Key) BoltDoc { } } -func toSdkDoc(doc BoltDoc) *sdk.Document { +func toSdkDoc(col *sdk.Collection, doc BoltDoc) *sdk.Document { + keys := strings.Split(doc.Id, "_") + + // Translate the boltdb Id into a nitric document key Id + var id string + if len(keys) > 1 { + // sub document + id = keys[len(keys)-1] + } else { + id = doc.Id + } + return &sdk.Document{ Content: doc.Value, + Key: &sdk.Key{ + + Collection: col, + // TODO: need to split out parent key id... + Id: id, + }, } } From fd418ff39e92f39cd2d53d6108f74035e1e3a8ca Mon Sep 17 00:00:00 2001 From: Tim Holm Date: Mon, 19 Jul 2021 15:00:30 +1000 Subject: [PATCH 04/16] feat(documents/dynamodb): Add key returns to queries and gets. --- pkg/plugins/document/dynamodb/dynamodb.go | 26 +++++++++++++++++++++-- 1 file changed, 24 insertions(+), 2 deletions(-) diff --git a/pkg/plugins/document/dynamodb/dynamodb.go b/pkg/plugins/document/dynamodb/dynamodb.go index 582aebe06..70f425fe3 100644 --- a/pkg/plugins/document/dynamodb/dynamodb.go +++ b/pkg/plugins/document/dynamodb/dynamodb.go @@ -17,6 +17,7 @@ package dynamodb_service import ( "fmt" "sort" + "strings" "github.com/nitric-dev/membrane/pkg/plugins/document" "github.com/nitric-dev/membrane/pkg/utils" @@ -74,6 +75,7 @@ func (s *DynamoDocService) Get(key *sdk.Key) (*sdk.Document, error) { delete(itemMap, ATTRIB_SK) return &sdk.Document{ + Key: key, Content: itemMap, }, nil } @@ -333,7 +335,7 @@ func (s *DynamoDocService) performQuery( return fmt.Errorf("error performing query %v: %v", input, err) } - return marshalQueryResult(resp.Items, resp.LastEvaluatedKey, limit, queryResult) + return marshalQueryResult(collection, resp.Items, resp.LastEvaluatedKey, limit, queryResult) } func (s *DynamoDocService) performScan( @@ -407,10 +409,11 @@ func (s *DynamoDocService) performScan( return fmt.Errorf("error performing scan %v: %v", input, err) } - return marshalQueryResult(resp.Items, resp.LastEvaluatedKey, limit, queryResult) + return marshalQueryResult(collection, resp.Items, resp.LastEvaluatedKey, limit, queryResult) } func marshalQueryResult( + collection *sdk.Collection, items []map[string]*dynamodb.AttributeValue, lastEvaluatedKey map[string]*dynamodb.AttributeValue, limit int, @@ -425,10 +428,29 @@ func marshalQueryResult( // Strip keys & append results for _, m := range valueMaps { + // Retrieve the original ID on the result + var id string + if collection.Parent == nil { + // We know this is a root document so its key will be located in PK + pk, _ := m[ATTRIB_PK].(string) + id = pk + } else { + // We know this is a child document so its key will be located in the SK + sk, _ := m[ATTRIB_SK].(string) + idStr := strings.Split(sk, "#") + id = idStr[len(idStr)-1] + } + // Get the sort key as a string + + // Split out sort key value delete(m, ATTRIB_PK) delete(m, ATTRIB_SK) sdkDoc := sdk.Document{ + Key: &sdk.Key{ + Collection: collection, + Id: id, + }, Content: m, } queryResult.Documents = append(queryResult.Documents, sdkDoc) From a60dff8f6034842316fa34f6ca0fe6b017866343 Mon Sep 17 00:00:00 2001 From: Tim Holm Date: Mon, 19 Jul 2021 15:01:10 +1000 Subject: [PATCH 05/16] feat(documents/firestore): Add key return to gets and queries. --- pkg/plugins/document/firestore/firestore.go | 14 ++++++++++---- 1 file changed, 10 insertions(+), 4 deletions(-) diff --git a/pkg/plugins/document/firestore/firestore.go b/pkg/plugins/document/firestore/firestore.go index 5d51d77c8..6f889db7b 100644 --- a/pkg/plugins/document/firestore/firestore.go +++ b/pkg/plugins/document/firestore/firestore.go @@ -17,9 +17,10 @@ package firestore_service import ( "context" "fmt" - "github.com/nitric-dev/membrane/pkg/plugins/document" "strings" + "github.com/nitric-dev/membrane/pkg/plugins/document" + "cloud.google.com/go/firestore" "cloud.google.com/go/pubsub" "github.com/nitric-dev/membrane/pkg/sdk" @@ -49,6 +50,7 @@ func (s *FirestoreDocService) Get(key *sdk.Key) (*sdk.Document, error) { } return &sdk.Document{ + Key: key, Content: value.Data(), }, nil } @@ -155,7 +157,13 @@ func (s *FirestoreDocService) Query(collection *sdk.Collection, expressions []sd if err != nil { return nil, fmt.Errorf("error querying value: %v", err) } - sdkDoc := sdk.Document{Content: docSnp.Data()} + sdkDoc := sdk.Document{ + Content: docSnp.Data(), + Key: &sdk.Key{ + Collection: collection, + Id: docSnp.Ref.ID, + }, + } queryResult.Documents = append(queryResult.Documents, sdkDoc) // If query limit configured determine continue tokens @@ -220,14 +228,12 @@ func (s *FirestoreDocService) getQueryRoot(collection *sdk.Collection) firestore if parentKey == nil { return s.client.Collection(collection.Name).Offset(0) - } else { if parentKey.Id != "" { return s.client.Collection(parentKey.Collection.Name). Doc(parentKey.Id). Collection(collection.Name). Offset(0) - } else { // Note there is a risk of subcollection name collison // TODO: future YAML validation could help mitigate this From 5c0ad88df87c0246ec178a2ae7dc6ac871451dcb Mon Sep 17 00:00:00 2001 From: Tim Holm Date: Mon, 19 Jul 2021 15:25:28 +1000 Subject: [PATCH 06/16] test(documents): Add basic key checks to integration tests. --- tests/plugins/document/suite.go | 86 ++++++++++++++++++++++++++++++--- 1 file changed, 78 insertions(+), 8 deletions(-) diff --git a/tests/plugins/document/suite.go b/tests/plugins/document/suite.go index 1d1d7376f..2e82e85f5 100644 --- a/tests/plugins/document/suite.go +++ b/tests/plugins/document/suite.go @@ -326,6 +326,7 @@ func GetTests(docPlugin sdk.DocumentService) { doc, err := docPlugin.Get(&UserKey1) Expect(err).ShouldNot(HaveOccurred()) Expect(doc).ToNot(BeNil()) + Expect(doc.Key).To(Equal(&UserKey1)) Expect(doc.Content["email"]).To(BeEquivalentTo(UserItem1["email"])) }) }) @@ -336,6 +337,7 @@ func GetTests(docPlugin sdk.DocumentService) { doc, err := docPlugin.Get(&Customer1.Orders[0].Key) Expect(err).ShouldNot(HaveOccurred()) Expect(doc).ToNot(BeNil()) + Expect(doc.Key).To(Equal(&Customer1.Orders[0].Key)) Expect(doc.Content).To(BeEquivalentTo(Customer1.Orders[0].Content)) }) }) @@ -495,6 +497,10 @@ func QueryTests(docPlugin sdk.DocumentService) { Expect(result).ToNot(BeNil()) Expect(err).ShouldNot(HaveOccurred()) Expect(result.Documents).To(HaveLen(3)) + + for _, d := range result.Documents { + Expect(d.Key).ToNot(BeNil()) + } }) }) When("key: {customers, nil}, subcol: '', exp: []", func() { @@ -508,6 +514,10 @@ func QueryTests(docPlugin sdk.DocumentService) { Expect(result.Documents[0].Content["email"]).To(BeEquivalentTo(Customer1.Content["email"])) Expect(result.Documents[1].Content["email"]).To(BeEquivalentTo(Customer2.Content["email"])) Expect(result.PagingToken).To(BeNil()) + + for _, d := range result.Documents { + Expect(d.Key).ToNot(BeNil()) + } }) }) When("key: {customers, nil}, subcol: '', exp: [country == US]", func() { @@ -523,6 +533,10 @@ func QueryTests(docPlugin sdk.DocumentService) { Expect(result.Documents).To(HaveLen(1)) Expect(result.Documents[0].Content["email"]).To(BeEquivalentTo(Customer2.Content["email"])) Expect(result.PagingToken).To(BeNil()) + + for _, d := range result.Documents { + Expect(d.Key).ToNot(BeNil()) + } }) }) When("key: {customers, nil}, subcol: '', exp: [country == US, age > 40]", func() { @@ -554,6 +568,10 @@ func QueryTests(docPlugin sdk.DocumentService) { Expect(result.Documents[0].Content["testName"]).To(BeEquivalentTo(Customer1.Orders[0].Content["testName"])) Expect(result.Documents[1].Content["testName"]).To(BeEquivalentTo(Customer1.Orders[1].Content["testName"])) Expect(result.Documents[2].Content["testName"]).To(BeEquivalentTo(Customer1.Orders[2].Content["testName"])) + + for _, d := range result.Documents { + Expect(d.Key).ToNot(BeNil()) + } }) }) When("key: {customers, nil}, subcol: orders, exps: [number == 1]", func() { @@ -573,6 +591,10 @@ func QueryTests(docPlugin sdk.DocumentService) { Expect(result.Documents).To(HaveLen(2)) Expect(result.Documents[0].Content["testName"]).To(BeEquivalentTo(Customer1.Orders[0].Content["testName"])) Expect(result.Documents[1].Content["testName"]).To(BeEquivalentTo(Customer2.Orders[0].Content["testName"])) + + for _, d := range result.Documents { + Expect(d.Key).ToNot(BeNil()) + } }) }) When("key: {customers, key1}, subcol: orders, exps: [number == 1]", func() { @@ -591,6 +613,10 @@ func QueryTests(docPlugin sdk.DocumentService) { Expect(err).ShouldNot(HaveOccurred()) Expect(result.Documents).To(HaveLen(1)) Expect(result.Documents[0].Content["testName"]).To(BeEquivalentTo(Customer1.Orders[0].Content["testName"])) + + for _, d := range result.Documents { + Expect(d.Key).ToNot(BeNil()) + } }) }) When("key: {customers, nil}, subcol: orders, exps: [number > 1]", func() { @@ -608,6 +634,10 @@ func QueryTests(docPlugin sdk.DocumentService) { Expect(result).ToNot(BeNil()) Expect(err).ShouldNot(HaveOccurred()) Expect(result.Documents).To(HaveLen(3)) + + for _, d := range result.Documents { + Expect(d.Key).ToNot(BeNil()) + } }) }) When("key: {customers, key1}, subcol: orders, exps: [number > 1]", func() { @@ -627,6 +657,10 @@ func QueryTests(docPlugin sdk.DocumentService) { Expect(result.Documents).To(HaveLen(2)) Expect(result.Documents[0].Content["testName"]).To(BeEquivalentTo(Customer1.Orders[1].Content["testName"])) Expect(result.Documents[1].Content["testName"]).To(BeEquivalentTo(Customer1.Orders[2].Content["testName"])) + + for _, d := range result.Documents { + Expect(d.Key).ToNot(BeNil()) + } }) }) When("key: {customers, nil}, subcol: orders, exps: [number < 1]", func() { @@ -644,6 +678,10 @@ func QueryTests(docPlugin sdk.DocumentService) { Expect(result).ToNot(BeNil()) Expect(err).ShouldNot(HaveOccurred()) Expect(result.Documents).To(HaveLen(0)) + + for _, d := range result.Documents { + Expect(d.Key).ToNot(BeNil()) + } }) }) When("key: {customers, key1}, subcol: orders, exps: [number < 1]", func() { @@ -678,6 +716,10 @@ func QueryTests(docPlugin sdk.DocumentService) { Expect(result).ToNot(BeNil()) Expect(err).ShouldNot(HaveOccurred()) Expect(result.Documents).To(HaveLen(5)) + + for _, d := range result.Documents { + Expect(d.Key).ToNot(BeNil()) + } }) }) When("key: {customers, key1}, subcol: orders, exps: [number >= 1]", func() { @@ -695,6 +737,10 @@ func QueryTests(docPlugin sdk.DocumentService) { Expect(result).ToNot(BeNil()) Expect(err).ShouldNot(HaveOccurred()) Expect(result.Documents).To(HaveLen(3)) + + for _, d := range result.Documents { + Expect(d.Key).ToNot(BeNil()) + } }) }) When("key: {customers, nil}, subcol: orders, exps: [number <= 1]", func() { @@ -714,6 +760,10 @@ func QueryTests(docPlugin sdk.DocumentService) { Expect(result.Documents).To(HaveLen(2)) Expect(result.Documents[0].Content["testName"]).To(BeEquivalentTo(Customer1.Orders[0].Content["testName"])) Expect(result.Documents[1].Content["testName"]).To(BeEquivalentTo(Customer2.Orders[0].Content["testName"])) + + for _, d := range result.Documents { + Expect(d.Key).ToNot(BeNil()) + } }) }) When("key: {customers, key1}, subcol: orders, exps: [number <= 1]", func() { @@ -732,6 +782,10 @@ func QueryTests(docPlugin sdk.DocumentService) { Expect(err).ShouldNot(HaveOccurred()) Expect(result.Documents).To(HaveLen(1)) Expect(result.Documents[0].Content["testName"]).To(BeEquivalentTo(Customer1.Orders[0].Content["testName"])) + + for _, d := range result.Documents { + Expect(d.Key).ToNot(BeNil()) + } }) }) When("key {customers, nil}, subcol: orders, exps: [type startsWith scooter]", func() { @@ -751,6 +805,10 @@ func QueryTests(docPlugin sdk.DocumentService) { Expect(result.Documents).To(HaveLen(2)) Expect(result.Documents[0].Content["testName"]).To(BeEquivalentTo(Customer1.Orders[2].Content["testName"])) Expect(result.Documents[1].Content["testName"]).To(BeEquivalentTo(Customer2.Orders[1].Content["testName"])) + + for _, d := range result.Documents { + Expect(d.Key).ToNot(BeNil()) + } }) }) When("key {customers, key1}, subcol: orders, exps: [type startsWith bike/road]", func() { @@ -769,6 +827,10 @@ func QueryTests(docPlugin sdk.DocumentService) { Expect(err).ShouldNot(HaveOccurred()) Expect(result.Documents).To(HaveLen(1)) Expect(result.Documents[0].Content["testName"]).To(BeEquivalentTo(Customer1.Orders[2].Content["testName"])) + + for _, d := range result.Documents { + Expect(d.Key).ToNot(BeNil()) + } }) }) When("key: {items, nil}, subcol: '', exp: [], limit: 10", func() { @@ -786,7 +848,8 @@ func QueryTests(docPlugin sdk.DocumentService) { // Ensure values are unique dataMap := make(map[string]string) - for i := range result.Documents { + for i, d := range result.Documents { + Expect(d.Key).ToNot(BeNil()) val := fmt.Sprintf("%v", result.Documents[i].Content["letter"]) dataMap[val] = val } @@ -798,7 +861,8 @@ func QueryTests(docPlugin sdk.DocumentService) { Expect(result.PagingToken).To(BeNil()) // Ensure values are unique - for i := range result.Documents { + for i, d := range result.Documents { + Expect(d.Key).ToNot(BeNil()) val := fmt.Sprintf("%v", result.Documents[i].Content["letter"]) if _, found := dataMap[val]; found { Expect("matching value").ShouldNot(HaveOccurred()) @@ -824,7 +888,8 @@ func QueryTests(docPlugin sdk.DocumentService) { // Ensure values are unique dataMap := make(map[string]string) - for i := range result.Documents { + for i, d := range result.Documents { + Expect(d.Key).ToNot(BeNil()) val := fmt.Sprintf("%v", result.Documents[i].Content["letter"]) dataMap[val] = val } @@ -836,7 +901,8 @@ func QueryTests(docPlugin sdk.DocumentService) { Expect(result.PagingToken).ToNot(BeEmpty()) // Ensure values are unique - for i := range result.Documents { + for i, d := range result.Documents { + Expect(d.Key).ToNot(BeNil()) val := fmt.Sprintf("%v", result.Documents[i].Content["letter"]) if _, found := dataMap[val]; found { Expect("matching value").ShouldNot(HaveOccurred()) @@ -862,7 +928,8 @@ func QueryTests(docPlugin sdk.DocumentService) { // Ensure values are unique dataMap := make(map[string]string) - for i := range result.Documents { + for i, d := range result.Documents { + Expect(d.Key).ToNot(BeNil()) val := fmt.Sprintf("%v", result.Documents[i].Content["letter"]) dataMap[val] = val } @@ -874,7 +941,8 @@ func QueryTests(docPlugin sdk.DocumentService) { Expect(result.PagingToken).To(BeNil()) // Ensure values are unique - for i := range result.Documents { + for i, d := range result.Documents { + Expect(d.Key).ToNot(BeNil()) val := fmt.Sprintf("%v", result.Documents[i].Content["letter"]) if _, found := dataMap[val]; found { Expect("matching value").ShouldNot(HaveOccurred()) @@ -897,7 +965,8 @@ func QueryTests(docPlugin sdk.DocumentService) { // Ensure values are unique dataMap := make(map[string]string) - for i := range result.Documents { + for i, d := range result.Documents { + Expect(d.Key).ToNot(BeNil()) val := fmt.Sprintf("%v", result.Documents[i].Content["letter"]) dataMap[val] = val } @@ -909,7 +978,8 @@ func QueryTests(docPlugin sdk.DocumentService) { Expect(result.PagingToken).ToNot(BeEmpty()) // Ensure values are unique - for i := range result.Documents { + for i, d := range result.Documents { + Expect(d.Key).ToNot(BeNil()) val := fmt.Sprintf("%v", result.Documents[i].Content["letter"]) if _, found := dataMap[val]; found { Expect("matching value").ShouldNot(HaveOccurred()) From d8f5c3951a368b9f69b1915c437a48c40b75fe9e Mon Sep 17 00:00:00 2001 From: Tim Holm Date: Mon, 19 Jul 2021 15:47:38 +1000 Subject: [PATCH 07/16] test(documents): Add stronger document key test assertions. --- tests/plugins/document/suite.go | 69 +++++++++++++++++++++++++++++++++ 1 file changed, 69 insertions(+) diff --git a/tests/plugins/document/suite.go b/tests/plugins/document/suite.go index 2e82e85f5..d8eb67370 100644 --- a/tests/plugins/document/suite.go +++ b/tests/plugins/document/suite.go @@ -500,6 +500,9 @@ func QueryTests(docPlugin sdk.DocumentService) { for _, d := range result.Documents { Expect(d.Key).ToNot(BeNil()) + Expect(d.Key.Collection.Name).To(Equal("users")) + Expect(d.Key.Id).ToNot(Equal("")) + Expect(d.Key.Collection.Parent).To(BeNil()) } }) }) @@ -517,6 +520,9 @@ func QueryTests(docPlugin sdk.DocumentService) { for _, d := range result.Documents { Expect(d.Key).ToNot(BeNil()) + Expect(d.Key.Collection.Name).To(Equal("customers")) + Expect(d.Key.Id).ToNot(Equal("")) + Expect(d.Key.Collection.Parent).To(BeNil()) } }) }) @@ -536,6 +542,9 @@ func QueryTests(docPlugin sdk.DocumentService) { for _, d := range result.Documents { Expect(d.Key).ToNot(BeNil()) + Expect(d.Key.Collection.Name).To(Equal("customers")) + Expect(d.Key.Id).ToNot(Equal("")) + Expect(d.Key.Collection.Parent).To(BeNil()) } }) }) @@ -571,6 +580,11 @@ func QueryTests(docPlugin sdk.DocumentService) { for _, d := range result.Documents { Expect(d.Key).ToNot(BeNil()) + Expect(d.Key.Id).ToNot(Equal("")) + Expect(d.Key.Collection).To(Equal("orders")) + Expect(d.Key.Collection.Parent).ToNot(BeNil()) + Expect(d.Key.Collection.Parent.Id).ToNot(Equal("")) + Expect(d.Key.Collection.Parent.Collection.Name).To(Equal("customers")) } }) }) @@ -594,6 +608,11 @@ func QueryTests(docPlugin sdk.DocumentService) { for _, d := range result.Documents { Expect(d.Key).ToNot(BeNil()) + Expect(d.Key.Id).ToNot(Equal("")) + Expect(d.Key.Collection).To(Equal("orders")) + Expect(d.Key.Collection.Parent).ToNot(BeNil()) + Expect(d.Key.Collection.Parent.Id).ToNot(Equal("")) + Expect(d.Key.Collection.Parent.Collection.Name).To(Equal("customers")) } }) }) @@ -616,6 +635,11 @@ func QueryTests(docPlugin sdk.DocumentService) { for _, d := range result.Documents { Expect(d.Key).ToNot(BeNil()) + Expect(d.Key.Id).ToNot(Equal("")) + Expect(d.Key.Collection).To(Equal("orders")) + Expect(d.Key.Collection.Parent).ToNot(BeNil()) + Expect(d.Key.Collection.Parent.Id).ToNot(Equal("")) + Expect(d.Key.Collection.Parent.Collection.Name).To(Equal("customers")) } }) }) @@ -637,6 +661,11 @@ func QueryTests(docPlugin sdk.DocumentService) { for _, d := range result.Documents { Expect(d.Key).ToNot(BeNil()) + Expect(d.Key.Id).ToNot(Equal("")) + Expect(d.Key.Collection).To(Equal("orders")) + Expect(d.Key.Collection.Parent).ToNot(BeNil()) + Expect(d.Key.Collection.Parent.Id).ToNot(Equal("")) + Expect(d.Key.Collection.Parent.Collection.Name).To(Equal("customers")) } }) }) @@ -660,6 +689,11 @@ func QueryTests(docPlugin sdk.DocumentService) { for _, d := range result.Documents { Expect(d.Key).ToNot(BeNil()) + Expect(d.Key.Id).ToNot(Equal("")) + Expect(d.Key.Collection).To(Equal("orders")) + Expect(d.Key.Collection.Parent).ToNot(BeNil()) + Expect(d.Key.Collection.Parent.Id).ToNot(Equal("")) + Expect(d.Key.Collection.Parent.Collection.Name).To(Equal("customers")) } }) }) @@ -681,6 +715,11 @@ func QueryTests(docPlugin sdk.DocumentService) { for _, d := range result.Documents { Expect(d.Key).ToNot(BeNil()) + Expect(d.Key.Id).ToNot(Equal("")) + Expect(d.Key.Collection).To(Equal("orders")) + Expect(d.Key.Collection.Parent).ToNot(BeNil()) + Expect(d.Key.Collection.Parent.Id).ToNot(Equal("")) + Expect(d.Key.Collection.Parent.Collection.Name).To(Equal("customers")) } }) }) @@ -719,6 +758,11 @@ func QueryTests(docPlugin sdk.DocumentService) { for _, d := range result.Documents { Expect(d.Key).ToNot(BeNil()) + Expect(d.Key.Id).ToNot(Equal("")) + Expect(d.Key.Collection).To(Equal("orders")) + Expect(d.Key.Collection.Parent).ToNot(BeNil()) + Expect(d.Key.Collection.Parent.Id).ToNot(Equal("")) + Expect(d.Key.Collection.Parent.Collection.Name).To(Equal("customers")) } }) }) @@ -740,6 +784,11 @@ func QueryTests(docPlugin sdk.DocumentService) { for _, d := range result.Documents { Expect(d.Key).ToNot(BeNil()) + Expect(d.Key.Id).ToNot(Equal("")) + Expect(d.Key.Collection).To(Equal("orders")) + Expect(d.Key.Collection.Parent).ToNot(BeNil()) + Expect(d.Key.Collection.Parent.Id).ToNot(Equal("")) + Expect(d.Key.Collection.Parent.Collection.Name).To(Equal("customers")) } }) }) @@ -763,6 +812,11 @@ func QueryTests(docPlugin sdk.DocumentService) { for _, d := range result.Documents { Expect(d.Key).ToNot(BeNil()) + Expect(d.Key.Id).ToNot(Equal("")) + Expect(d.Key.Collection).To(Equal("orders")) + Expect(d.Key.Collection.Parent).ToNot(BeNil()) + Expect(d.Key.Collection.Parent.Id).ToNot(Equal("")) + Expect(d.Key.Collection.Parent.Collection.Name).To(Equal("customers")) } }) }) @@ -785,6 +839,11 @@ func QueryTests(docPlugin sdk.DocumentService) { for _, d := range result.Documents { Expect(d.Key).ToNot(BeNil()) + Expect(d.Key.Id).ToNot(Equal("")) + Expect(d.Key.Collection).To(Equal("orders")) + Expect(d.Key.Collection.Parent).ToNot(BeNil()) + Expect(d.Key.Collection.Parent.Id).ToNot(Equal("")) + Expect(d.Key.Collection.Parent.Collection.Name).To(Equal("customers")) } }) }) @@ -808,6 +867,11 @@ func QueryTests(docPlugin sdk.DocumentService) { for _, d := range result.Documents { Expect(d.Key).ToNot(BeNil()) + Expect(d.Key.Id).ToNot(Equal("")) + Expect(d.Key.Collection).To(Equal("orders")) + Expect(d.Key.Collection.Parent).ToNot(BeNil()) + Expect(d.Key.Collection.Parent.Id).ToNot(Equal("")) + Expect(d.Key.Collection.Parent.Collection.Name).To(Equal("customers")) } }) }) @@ -830,6 +894,11 @@ func QueryTests(docPlugin sdk.DocumentService) { for _, d := range result.Documents { Expect(d.Key).ToNot(BeNil()) + Expect(d.Key.Id).ToNot(Equal("")) + Expect(d.Key.Collection).To(Equal("orders")) + Expect(d.Key.Collection.Parent).ToNot(BeNil()) + Expect(d.Key.Collection.Parent.Id).ToNot(Equal("")) + Expect(d.Key.Collection.Parent.Collection.Name).To(Equal("customers")) } }) }) From d342a90fcb44fbeffbb4724ee4d36f75dc054bcc Mon Sep 17 00:00:00 2001 From: Tim Holm Date: Mon, 19 Jul 2021 15:56:48 +1000 Subject: [PATCH 08/16] test(documents): correct bad assertions. --- tests/plugins/document/suite.go | 24 ++++++++++++------------ 1 file changed, 12 insertions(+), 12 deletions(-) diff --git a/tests/plugins/document/suite.go b/tests/plugins/document/suite.go index d8eb67370..c08ef0365 100644 --- a/tests/plugins/document/suite.go +++ b/tests/plugins/document/suite.go @@ -581,7 +581,7 @@ func QueryTests(docPlugin sdk.DocumentService) { for _, d := range result.Documents { Expect(d.Key).ToNot(BeNil()) Expect(d.Key.Id).ToNot(Equal("")) - Expect(d.Key.Collection).To(Equal("orders")) + Expect(d.Key.Collection.Name).To(Equal("orders")) Expect(d.Key.Collection.Parent).ToNot(BeNil()) Expect(d.Key.Collection.Parent.Id).ToNot(Equal("")) Expect(d.Key.Collection.Parent.Collection.Name).To(Equal("customers")) @@ -609,7 +609,7 @@ func QueryTests(docPlugin sdk.DocumentService) { for _, d := range result.Documents { Expect(d.Key).ToNot(BeNil()) Expect(d.Key.Id).ToNot(Equal("")) - Expect(d.Key.Collection).To(Equal("orders")) + Expect(d.Key.Collection.Name).To(Equal("orders")) Expect(d.Key.Collection.Parent).ToNot(BeNil()) Expect(d.Key.Collection.Parent.Id).ToNot(Equal("")) Expect(d.Key.Collection.Parent.Collection.Name).To(Equal("customers")) @@ -636,7 +636,7 @@ func QueryTests(docPlugin sdk.DocumentService) { for _, d := range result.Documents { Expect(d.Key).ToNot(BeNil()) Expect(d.Key.Id).ToNot(Equal("")) - Expect(d.Key.Collection).To(Equal("orders")) + Expect(d.Key.Collection.Name).To(Equal("orders")) Expect(d.Key.Collection.Parent).ToNot(BeNil()) Expect(d.Key.Collection.Parent.Id).ToNot(Equal("")) Expect(d.Key.Collection.Parent.Collection.Name).To(Equal("customers")) @@ -662,7 +662,7 @@ func QueryTests(docPlugin sdk.DocumentService) { for _, d := range result.Documents { Expect(d.Key).ToNot(BeNil()) Expect(d.Key.Id).ToNot(Equal("")) - Expect(d.Key.Collection).To(Equal("orders")) + Expect(d.Key.Collection.Name).To(Equal("orders")) Expect(d.Key.Collection.Parent).ToNot(BeNil()) Expect(d.Key.Collection.Parent.Id).ToNot(Equal("")) Expect(d.Key.Collection.Parent.Collection.Name).To(Equal("customers")) @@ -690,7 +690,7 @@ func QueryTests(docPlugin sdk.DocumentService) { for _, d := range result.Documents { Expect(d.Key).ToNot(BeNil()) Expect(d.Key.Id).ToNot(Equal("")) - Expect(d.Key.Collection).To(Equal("orders")) + Expect(d.Key.Collection.Name).To(Equal("orders")) Expect(d.Key.Collection.Parent).ToNot(BeNil()) Expect(d.Key.Collection.Parent.Id).ToNot(Equal("")) Expect(d.Key.Collection.Parent.Collection.Name).To(Equal("customers")) @@ -716,7 +716,7 @@ func QueryTests(docPlugin sdk.DocumentService) { for _, d := range result.Documents { Expect(d.Key).ToNot(BeNil()) Expect(d.Key.Id).ToNot(Equal("")) - Expect(d.Key.Collection).To(Equal("orders")) + Expect(d.Key.Collection.Name).To(Equal("orders")) Expect(d.Key.Collection.Parent).ToNot(BeNil()) Expect(d.Key.Collection.Parent.Id).ToNot(Equal("")) Expect(d.Key.Collection.Parent.Collection.Name).To(Equal("customers")) @@ -759,7 +759,7 @@ func QueryTests(docPlugin sdk.DocumentService) { for _, d := range result.Documents { Expect(d.Key).ToNot(BeNil()) Expect(d.Key.Id).ToNot(Equal("")) - Expect(d.Key.Collection).To(Equal("orders")) + Expect(d.Key.Collection.Name).To(Equal("orders")) Expect(d.Key.Collection.Parent).ToNot(BeNil()) Expect(d.Key.Collection.Parent.Id).ToNot(Equal("")) Expect(d.Key.Collection.Parent.Collection.Name).To(Equal("customers")) @@ -785,7 +785,7 @@ func QueryTests(docPlugin sdk.DocumentService) { for _, d := range result.Documents { Expect(d.Key).ToNot(BeNil()) Expect(d.Key.Id).ToNot(Equal("")) - Expect(d.Key.Collection).To(Equal("orders")) + Expect(d.Key.Collection.Name).To(Equal("orders")) Expect(d.Key.Collection.Parent).ToNot(BeNil()) Expect(d.Key.Collection.Parent.Id).ToNot(Equal("")) Expect(d.Key.Collection.Parent.Collection.Name).To(Equal("customers")) @@ -813,7 +813,7 @@ func QueryTests(docPlugin sdk.DocumentService) { for _, d := range result.Documents { Expect(d.Key).ToNot(BeNil()) Expect(d.Key.Id).ToNot(Equal("")) - Expect(d.Key.Collection).To(Equal("orders")) + Expect(d.Key.Collection.Name).To(Equal("orders")) Expect(d.Key.Collection.Parent).ToNot(BeNil()) Expect(d.Key.Collection.Parent.Id).ToNot(Equal("")) Expect(d.Key.Collection.Parent.Collection.Name).To(Equal("customers")) @@ -840,7 +840,7 @@ func QueryTests(docPlugin sdk.DocumentService) { for _, d := range result.Documents { Expect(d.Key).ToNot(BeNil()) Expect(d.Key.Id).ToNot(Equal("")) - Expect(d.Key.Collection).To(Equal("orders")) + Expect(d.Key.Collection.Name).To(Equal("orders")) Expect(d.Key.Collection.Parent).ToNot(BeNil()) Expect(d.Key.Collection.Parent.Id).ToNot(Equal("")) Expect(d.Key.Collection.Parent.Collection.Name).To(Equal("customers")) @@ -868,7 +868,7 @@ func QueryTests(docPlugin sdk.DocumentService) { for _, d := range result.Documents { Expect(d.Key).ToNot(BeNil()) Expect(d.Key.Id).ToNot(Equal("")) - Expect(d.Key.Collection).To(Equal("orders")) + Expect(d.Key.Collection.Name).To(Equal("orders")) Expect(d.Key.Collection.Parent).ToNot(BeNil()) Expect(d.Key.Collection.Parent.Id).ToNot(Equal("")) Expect(d.Key.Collection.Parent.Collection.Name).To(Equal("customers")) @@ -895,7 +895,7 @@ func QueryTests(docPlugin sdk.DocumentService) { for _, d := range result.Documents { Expect(d.Key).ToNot(BeNil()) Expect(d.Key.Id).ToNot(Equal("")) - Expect(d.Key.Collection).To(Equal("orders")) + Expect(d.Key.Collection.Name).To(Equal("orders")) Expect(d.Key.Collection.Parent).ToNot(BeNil()) Expect(d.Key.Collection.Parent.Id).ToNot(Equal("")) Expect(d.Key.Collection.Parent.Collection.Name).To(Equal("customers")) From 26b5401b99b5dde1e4b277d1baa0fd6b10a872b6 Mon Sep 17 00:00:00 2001 From: Tim Holm Date: Mon, 19 Jul 2021 16:12:48 +1000 Subject: [PATCH 09/16] chore: Fix boltdb parent collection handling. --- pkg/plugins/document/boltdb/boltdb.go | 12 ++++++++++-- 1 file changed, 10 insertions(+), 2 deletions(-) diff --git a/pkg/plugins/document/boltdb/boltdb.go b/pkg/plugins/document/boltdb/boltdb.go index cdcb5102d..bfc71fa65 100644 --- a/pkg/plugins/document/boltdb/boltdb.go +++ b/pkg/plugins/document/boltdb/boltdb.go @@ -306,18 +306,26 @@ func toSdkDoc(col *sdk.Collection, doc BoltDoc) *sdk.Document { // Translate the boltdb Id into a nitric document key Id var id string + var c *sdk.Collection if len(keys) > 1 { // sub document id = keys[len(keys)-1] + c = &sdk.Collection{ + Name: col.Name, + Parent: &sdk.Key{ + Collection: col.Parent.Collection, + Id: keys[0], + }, + } } else { id = doc.Id + c = col } return &sdk.Document{ Content: doc.Value, Key: &sdk.Key{ - - Collection: col, + Collection: c, // TODO: need to split out parent key id... Id: id, }, From 9ee5d635fc52f056cdbdd950c87e41b468e4899a Mon Sep 17 00:00:00 2001 From: Tim Holm Date: Mon, 19 Jul 2021 16:19:52 +1000 Subject: [PATCH 10/16] chore: fix dynamodb parent collection handling. --- pkg/plugins/document/dynamodb/dynamodb.go | 14 +++++++++++++- 1 file changed, 13 insertions(+), 1 deletion(-) diff --git a/pkg/plugins/document/dynamodb/dynamodb.go b/pkg/plugins/document/dynamodb/dynamodb.go index 70f425fe3..25375d44e 100644 --- a/pkg/plugins/document/dynamodb/dynamodb.go +++ b/pkg/plugins/document/dynamodb/dynamodb.go @@ -430,15 +430,27 @@ func marshalQueryResult( for _, m := range valueMaps { // Retrieve the original ID on the result var id string + var c *sdk.Collection if collection.Parent == nil { // We know this is a root document so its key will be located in PK pk, _ := m[ATTRIB_PK].(string) id = pk + c = collection } else { // We know this is a child document so its key will be located in the SK + pk, _ := m[ATTRIB_PK].(string) sk, _ := m[ATTRIB_SK].(string) idStr := strings.Split(sk, "#") id = idStr[len(idStr)-1] + c = &sdk.Collection{ + Name: collection.Name, + Parent: &sdk.Key{ + Collection: &sdk.Collection{ + Name: collection.Parent.Collection.Name, + }, + Id: pk, + }, + } } // Get the sort key as a string @@ -448,7 +460,7 @@ func marshalQueryResult( sdkDoc := sdk.Document{ Key: &sdk.Key{ - Collection: collection, + Collection: c, Id: id, }, Content: m, From fcc7f103853a55fac15f391c9c35abd978a23d19 Mon Sep 17 00:00:00 2001 From: Tim Holm Date: Mon, 19 Jul 2021 16:31:46 +1000 Subject: [PATCH 11/16] chore: Fix firestore sub collection handling. --- pkg/plugins/document/firestore/firestore.go | 11 +++++++++++ 1 file changed, 11 insertions(+) diff --git a/pkg/plugins/document/firestore/firestore.go b/pkg/plugins/document/firestore/firestore.go index 6f889db7b..5b7d22aba 100644 --- a/pkg/plugins/document/firestore/firestore.go +++ b/pkg/plugins/document/firestore/firestore.go @@ -164,6 +164,17 @@ func (s *FirestoreDocService) Query(collection *sdk.Collection, expressions []sd Id: docSnp.Ref.ID, }, } + + if p := docSnp.Ref.Parent.Parent; p != nil { + sdkDoc.Key.Collection = &sdk.Collection{ + Name: collection.Name, + Parent: &sdk.Key{ + Collection: collection.Parent.Collection, + Id: p.ID, + }, + } + } + queryResult.Documents = append(queryResult.Documents, sdkDoc) // If query limit configured determine continue tokens From ba28ee9a56c8212726ae4fdc724a583b751a0603 Mon Sep 17 00:00:00 2001 From: Tim Holm Date: Mon, 19 Jul 2021 16:55:29 +1000 Subject: [PATCH 12/16] test(documents): Improve document integration test suite assertions for keys. --- tests/plugins/document/suite.go | 117 +++++++++----------------------- 1 file changed, 31 insertions(+), 86 deletions(-) diff --git a/tests/plugins/document/suite.go b/tests/plugins/document/suite.go index c08ef0365..821334fbc 100644 --- a/tests/plugins/document/suite.go +++ b/tests/plugins/document/suite.go @@ -515,15 +515,10 @@ func QueryTests(docPlugin sdk.DocumentService) { Expect(err).ShouldNot(HaveOccurred()) Expect(result.Documents).To(HaveLen(2)) Expect(result.Documents[0].Content["email"]).To(BeEquivalentTo(Customer1.Content["email"])) + Expect(result.Documents[0].Key).To(BeEquivalentTo(Customer1.Key)) Expect(result.Documents[1].Content["email"]).To(BeEquivalentTo(Customer2.Content["email"])) + Expect(result.Documents[1].Key).To(BeEquivalentTo(Customer2.Key)) Expect(result.PagingToken).To(BeNil()) - - for _, d := range result.Documents { - Expect(d.Key).ToNot(BeNil()) - Expect(d.Key.Collection.Name).To(Equal("customers")) - Expect(d.Key.Id).ToNot(Equal("")) - Expect(d.Key.Collection.Parent).To(BeNil()) - } }) }) When("key: {customers, nil}, subcol: '', exp: [country == US]", func() { @@ -538,14 +533,8 @@ func QueryTests(docPlugin sdk.DocumentService) { Expect(err).ShouldNot(HaveOccurred()) Expect(result.Documents).To(HaveLen(1)) Expect(result.Documents[0].Content["email"]).To(BeEquivalentTo(Customer2.Content["email"])) + Expect(result.Documents[0].Key).To(BeEquivalentTo(Customer2.Key)) Expect(result.PagingToken).To(BeNil()) - - for _, d := range result.Documents { - Expect(d.Key).ToNot(BeNil()) - Expect(d.Key.Collection.Name).To(Equal("customers")) - Expect(d.Key.Id).ToNot(Equal("")) - Expect(d.Key.Collection.Parent).To(BeNil()) - } }) }) When("key: {customers, nil}, subcol: '', exp: [country == US, age > 40]", func() { @@ -575,17 +564,14 @@ func QueryTests(docPlugin sdk.DocumentService) { Expect(err).ShouldNot(HaveOccurred()) Expect(result.Documents).To(HaveLen(3)) Expect(result.Documents[0].Content["testName"]).To(BeEquivalentTo(Customer1.Orders[0].Content["testName"])) + Expect(result.Documents[0].Key).To(BeEquivalentTo(Customer1.Orders[0].Key)) + Expect(result.Documents[0].Key.Collection.Parent).To(BeEquivalentTo(Customer1.Key)) Expect(result.Documents[1].Content["testName"]).To(BeEquivalentTo(Customer1.Orders[1].Content["testName"])) + Expect(result.Documents[1].Key).To(BeEquivalentTo(Customer1.Orders[1].Key)) + Expect(result.Documents[1].Key.Collection.Parent).To(BeEquivalentTo(Customer1.Key)) Expect(result.Documents[2].Content["testName"]).To(BeEquivalentTo(Customer1.Orders[2].Content["testName"])) - - for _, d := range result.Documents { - Expect(d.Key).ToNot(BeNil()) - Expect(d.Key.Id).ToNot(Equal("")) - Expect(d.Key.Collection.Name).To(Equal("orders")) - Expect(d.Key.Collection.Parent).ToNot(BeNil()) - Expect(d.Key.Collection.Parent.Id).ToNot(Equal("")) - Expect(d.Key.Collection.Parent.Collection.Name).To(Equal("customers")) - } + Expect(result.Documents[2].Key).To(BeEquivalentTo(Customer1.Orders[2].Key)) + Expect(result.Documents[2].Key.Collection.Parent).To(BeEquivalentTo(Customer1.Key)) }) }) When("key: {customers, nil}, subcol: orders, exps: [number == 1]", func() { @@ -604,16 +590,11 @@ func QueryTests(docPlugin sdk.DocumentService) { Expect(err).ShouldNot(HaveOccurred()) Expect(result.Documents).To(HaveLen(2)) Expect(result.Documents[0].Content["testName"]).To(BeEquivalentTo(Customer1.Orders[0].Content["testName"])) + Expect(result.Documents[0].Key).To(BeEquivalentTo(Customer1.Orders[0].Key)) + Expect(result.Documents[0].Key.Collection.Parent).To(BeEquivalentTo(Customer1.Key)) Expect(result.Documents[1].Content["testName"]).To(BeEquivalentTo(Customer2.Orders[0].Content["testName"])) - - for _, d := range result.Documents { - Expect(d.Key).ToNot(BeNil()) - Expect(d.Key.Id).ToNot(Equal("")) - Expect(d.Key.Collection.Name).To(Equal("orders")) - Expect(d.Key.Collection.Parent).ToNot(BeNil()) - Expect(d.Key.Collection.Parent.Id).ToNot(Equal("")) - Expect(d.Key.Collection.Parent.Collection.Name).To(Equal("customers")) - } + Expect(result.Documents[1].Key).To(BeEquivalentTo(Customer2.Orders[0].Key)) + Expect(result.Documents[1].Key.Collection.Parent).To(BeEquivalentTo(Customer2.Key)) }) }) When("key: {customers, key1}, subcol: orders, exps: [number == 1]", func() { @@ -632,15 +613,8 @@ func QueryTests(docPlugin sdk.DocumentService) { Expect(err).ShouldNot(HaveOccurred()) Expect(result.Documents).To(HaveLen(1)) Expect(result.Documents[0].Content["testName"]).To(BeEquivalentTo(Customer1.Orders[0].Content["testName"])) - - for _, d := range result.Documents { - Expect(d.Key).ToNot(BeNil()) - Expect(d.Key.Id).ToNot(Equal("")) - Expect(d.Key.Collection.Name).To(Equal("orders")) - Expect(d.Key.Collection.Parent).ToNot(BeNil()) - Expect(d.Key.Collection.Parent.Id).ToNot(Equal("")) - Expect(d.Key.Collection.Parent.Collection.Name).To(Equal("customers")) - } + Expect(result.Documents[0].Key).To(BeEquivalentTo(Customer1.Orders[0].Key)) + Expect(result.Documents[0].Key.Collection.Parent).To(BeEquivalentTo(Customer1.Key)) }) }) When("key: {customers, nil}, subcol: orders, exps: [number > 1]", func() { @@ -685,16 +659,11 @@ func QueryTests(docPlugin sdk.DocumentService) { Expect(err).ShouldNot(HaveOccurred()) Expect(result.Documents).To(HaveLen(2)) Expect(result.Documents[0].Content["testName"]).To(BeEquivalentTo(Customer1.Orders[1].Content["testName"])) + Expect(result.Documents[0].Key).To(BeEquivalentTo(Customer1.Orders[1].Key)) + Expect(result.Documents[0].Key.Collection.Parent).To(BeEquivalentTo(Customer1.Key)) Expect(result.Documents[1].Content["testName"]).To(BeEquivalentTo(Customer1.Orders[2].Content["testName"])) - - for _, d := range result.Documents { - Expect(d.Key).ToNot(BeNil()) - Expect(d.Key.Id).ToNot(Equal("")) - Expect(d.Key.Collection.Name).To(Equal("orders")) - Expect(d.Key.Collection.Parent).ToNot(BeNil()) - Expect(d.Key.Collection.Parent.Id).ToNot(Equal("")) - Expect(d.Key.Collection.Parent.Collection.Name).To(Equal("customers")) - } + Expect(result.Documents[1].Key).To(BeEquivalentTo(Customer1.Orders[2].Key)) + Expect(result.Documents[1].Key.Collection.Parent).To(BeEquivalentTo(Customer1.Key)) }) }) When("key: {customers, nil}, subcol: orders, exps: [number < 1]", func() { @@ -808,16 +777,11 @@ func QueryTests(docPlugin sdk.DocumentService) { Expect(err).ShouldNot(HaveOccurred()) Expect(result.Documents).To(HaveLen(2)) Expect(result.Documents[0].Content["testName"]).To(BeEquivalentTo(Customer1.Orders[0].Content["testName"])) + Expect(result.Documents[0].Key).To(BeEquivalentTo(Customer1.Orders[0].Key)) + Expect(result.Documents[0].Key.Collection.Parent).To(BeEquivalentTo(Customer1.Key)) Expect(result.Documents[1].Content["testName"]).To(BeEquivalentTo(Customer2.Orders[0].Content["testName"])) - - for _, d := range result.Documents { - Expect(d.Key).ToNot(BeNil()) - Expect(d.Key.Id).ToNot(Equal("")) - Expect(d.Key.Collection.Name).To(Equal("orders")) - Expect(d.Key.Collection.Parent).ToNot(BeNil()) - Expect(d.Key.Collection.Parent.Id).ToNot(Equal("")) - Expect(d.Key.Collection.Parent.Collection.Name).To(Equal("customers")) - } + Expect(result.Documents[1].Key).To(BeEquivalentTo(Customer2.Orders[0].Key)) + Expect(result.Documents[1].Key.Collection.Parent).To(BeEquivalentTo(Customer2.Key)) }) }) When("key: {customers, key1}, subcol: orders, exps: [number <= 1]", func() { @@ -836,15 +800,8 @@ func QueryTests(docPlugin sdk.DocumentService) { Expect(err).ShouldNot(HaveOccurred()) Expect(result.Documents).To(HaveLen(1)) Expect(result.Documents[0].Content["testName"]).To(BeEquivalentTo(Customer1.Orders[0].Content["testName"])) - - for _, d := range result.Documents { - Expect(d.Key).ToNot(BeNil()) - Expect(d.Key.Id).ToNot(Equal("")) - Expect(d.Key.Collection.Name).To(Equal("orders")) - Expect(d.Key.Collection.Parent).ToNot(BeNil()) - Expect(d.Key.Collection.Parent.Id).ToNot(Equal("")) - Expect(d.Key.Collection.Parent.Collection.Name).To(Equal("customers")) - } + Expect(result.Documents[0].Key.Id).To(Equal(Customer1.Orders[0].Key.Id)) + Expect(result.Documents[0].Key.Collection.Parent.Id).To(Equal(Customer1.Key)) }) }) When("key {customers, nil}, subcol: orders, exps: [type startsWith scooter]", func() { @@ -864,15 +821,10 @@ func QueryTests(docPlugin sdk.DocumentService) { Expect(result.Documents).To(HaveLen(2)) Expect(result.Documents[0].Content["testName"]).To(BeEquivalentTo(Customer1.Orders[2].Content["testName"])) Expect(result.Documents[1].Content["testName"]).To(BeEquivalentTo(Customer2.Orders[1].Content["testName"])) - - for _, d := range result.Documents { - Expect(d.Key).ToNot(BeNil()) - Expect(d.Key.Id).ToNot(Equal("")) - Expect(d.Key.Collection.Name).To(Equal("orders")) - Expect(d.Key.Collection.Parent).ToNot(BeNil()) - Expect(d.Key.Collection.Parent.Id).ToNot(Equal("")) - Expect(d.Key.Collection.Parent.Collection.Name).To(Equal("customers")) - } + Expect(result.Documents[0].Key.Collection.Parent.Id).To(Equal(Customer1.Key.Id)) + Expect(result.Documents[0].Key.Id).To(Equal(Customer1.Orders[2].Key.Id)) + Expect(result.Documents[1].Key.Collection.Parent.Id).To(Equal(Customer2.Key.Id)) + Expect(result.Documents[1].Key.Id).To(Equal(Customer2.Orders[1].Key.Id)) }) }) When("key {customers, key1}, subcol: orders, exps: [type startsWith bike/road]", func() { @@ -891,15 +843,8 @@ func QueryTests(docPlugin sdk.DocumentService) { Expect(err).ShouldNot(HaveOccurred()) Expect(result.Documents).To(HaveLen(1)) Expect(result.Documents[0].Content["testName"]).To(BeEquivalentTo(Customer1.Orders[2].Content["testName"])) - - for _, d := range result.Documents { - Expect(d.Key).ToNot(BeNil()) - Expect(d.Key.Id).ToNot(Equal("")) - Expect(d.Key.Collection.Name).To(Equal("orders")) - Expect(d.Key.Collection.Parent).ToNot(BeNil()) - Expect(d.Key.Collection.Parent.Id).ToNot(Equal("")) - Expect(d.Key.Collection.Parent.Collection.Name).To(Equal("customers")) - } + Expect(result.Documents[0].Key).To(BeEquivalentTo(Customer1.Orders[2].Key)) + Expect(result.Documents[0].Key.Collection.Parent).To(BeEquivalentTo(Customer1.Key)) }) }) When("key: {items, nil}, subcol: '', exp: [], limit: 10", func() { From bd8c821f6d30d68c7d8fd513aca362ab33ffac29 Mon Sep 17 00:00:00 2001 From: Tim Holm Date: Mon, 19 Jul 2021 17:04:53 +1000 Subject: [PATCH 13/16] chore: dereference keys for equality checks. --- tests/plugins/document/suite.go | 62 ++++++++++++++++----------------- 1 file changed, 31 insertions(+), 31 deletions(-) diff --git a/tests/plugins/document/suite.go b/tests/plugins/document/suite.go index 821334fbc..1e999c122 100644 --- a/tests/plugins/document/suite.go +++ b/tests/plugins/document/suite.go @@ -515,9 +515,9 @@ func QueryTests(docPlugin sdk.DocumentService) { Expect(err).ShouldNot(HaveOccurred()) Expect(result.Documents).To(HaveLen(2)) Expect(result.Documents[0].Content["email"]).To(BeEquivalentTo(Customer1.Content["email"])) - Expect(result.Documents[0].Key).To(BeEquivalentTo(Customer1.Key)) + Expect(*result.Documents[0].Key).To(BeEquivalentTo(Customer1.Key)) Expect(result.Documents[1].Content["email"]).To(BeEquivalentTo(Customer2.Content["email"])) - Expect(result.Documents[1].Key).To(BeEquivalentTo(Customer2.Key)) + Expect(*result.Documents[1].Key).To(BeEquivalentTo(Customer2.Key)) Expect(result.PagingToken).To(BeNil()) }) }) @@ -533,7 +533,7 @@ func QueryTests(docPlugin sdk.DocumentService) { Expect(err).ShouldNot(HaveOccurred()) Expect(result.Documents).To(HaveLen(1)) Expect(result.Documents[0].Content["email"]).To(BeEquivalentTo(Customer2.Content["email"])) - Expect(result.Documents[0].Key).To(BeEquivalentTo(Customer2.Key)) + Expect(*result.Documents[0].Key).To(BeEquivalentTo(Customer2.Key)) Expect(result.PagingToken).To(BeNil()) }) }) @@ -564,14 +564,14 @@ func QueryTests(docPlugin sdk.DocumentService) { Expect(err).ShouldNot(HaveOccurred()) Expect(result.Documents).To(HaveLen(3)) Expect(result.Documents[0].Content["testName"]).To(BeEquivalentTo(Customer1.Orders[0].Content["testName"])) - Expect(result.Documents[0].Key).To(BeEquivalentTo(Customer1.Orders[0].Key)) - Expect(result.Documents[0].Key.Collection.Parent).To(BeEquivalentTo(Customer1.Key)) + Expect(*result.Documents[0].Key).To(BeEquivalentTo(Customer1.Orders[0].Key)) + Expect(*result.Documents[0].Key.Collection.Parent).To(BeEquivalentTo(Customer1.Key)) Expect(result.Documents[1].Content["testName"]).To(BeEquivalentTo(Customer1.Orders[1].Content["testName"])) - Expect(result.Documents[1].Key).To(BeEquivalentTo(Customer1.Orders[1].Key)) - Expect(result.Documents[1].Key.Collection.Parent).To(BeEquivalentTo(Customer1.Key)) + Expect(*result.Documents[1].Key).To(BeEquivalentTo(Customer1.Orders[1].Key)) + Expect(*result.Documents[1].Key.Collection.Parent).To(BeEquivalentTo(Customer1.Key)) Expect(result.Documents[2].Content["testName"]).To(BeEquivalentTo(Customer1.Orders[2].Content["testName"])) - Expect(result.Documents[2].Key).To(BeEquivalentTo(Customer1.Orders[2].Key)) - Expect(result.Documents[2].Key.Collection.Parent).To(BeEquivalentTo(Customer1.Key)) + Expect(*result.Documents[2].Key).To(BeEquivalentTo(Customer1.Orders[2].Key)) + Expect(*result.Documents[2].Key.Collection.Parent).To(BeEquivalentTo(Customer1.Key)) }) }) When("key: {customers, nil}, subcol: orders, exps: [number == 1]", func() { @@ -590,11 +590,11 @@ func QueryTests(docPlugin sdk.DocumentService) { Expect(err).ShouldNot(HaveOccurred()) Expect(result.Documents).To(HaveLen(2)) Expect(result.Documents[0].Content["testName"]).To(BeEquivalentTo(Customer1.Orders[0].Content["testName"])) - Expect(result.Documents[0].Key).To(BeEquivalentTo(Customer1.Orders[0].Key)) - Expect(result.Documents[0].Key.Collection.Parent).To(BeEquivalentTo(Customer1.Key)) + Expect(*result.Documents[0].Key).To(BeEquivalentTo(Customer1.Orders[0].Key)) + Expect(*result.Documents[0].Key.Collection.Parent).To(BeEquivalentTo(Customer1.Key)) Expect(result.Documents[1].Content["testName"]).To(BeEquivalentTo(Customer2.Orders[0].Content["testName"])) - Expect(result.Documents[1].Key).To(BeEquivalentTo(Customer2.Orders[0].Key)) - Expect(result.Documents[1].Key.Collection.Parent).To(BeEquivalentTo(Customer2.Key)) + Expect(*result.Documents[1].Key).To(BeEquivalentTo(Customer2.Orders[0].Key)) + Expect(*result.Documents[1].Key.Collection.Parent).To(BeEquivalentTo(Customer2.Key)) }) }) When("key: {customers, key1}, subcol: orders, exps: [number == 1]", func() { @@ -613,8 +613,8 @@ func QueryTests(docPlugin sdk.DocumentService) { Expect(err).ShouldNot(HaveOccurred()) Expect(result.Documents).To(HaveLen(1)) Expect(result.Documents[0].Content["testName"]).To(BeEquivalentTo(Customer1.Orders[0].Content["testName"])) - Expect(result.Documents[0].Key).To(BeEquivalentTo(Customer1.Orders[0].Key)) - Expect(result.Documents[0].Key.Collection.Parent).To(BeEquivalentTo(Customer1.Key)) + Expect(*result.Documents[0].Key).To(BeEquivalentTo(Customer1.Orders[0].Key)) + Expect(*result.Documents[0].Key.Collection.Parent).To(BeEquivalentTo(Customer1.Key)) }) }) When("key: {customers, nil}, subcol: orders, exps: [number > 1]", func() { @@ -659,11 +659,11 @@ func QueryTests(docPlugin sdk.DocumentService) { Expect(err).ShouldNot(HaveOccurred()) Expect(result.Documents).To(HaveLen(2)) Expect(result.Documents[0].Content["testName"]).To(BeEquivalentTo(Customer1.Orders[1].Content["testName"])) - Expect(result.Documents[0].Key).To(BeEquivalentTo(Customer1.Orders[1].Key)) - Expect(result.Documents[0].Key.Collection.Parent).To(BeEquivalentTo(Customer1.Key)) + Expect(*result.Documents[0].Key).To(BeEquivalentTo(Customer1.Orders[1].Key)) + Expect(*result.Documents[0].Key.Collection.Parent).To(BeEquivalentTo(Customer1.Key)) Expect(result.Documents[1].Content["testName"]).To(BeEquivalentTo(Customer1.Orders[2].Content["testName"])) - Expect(result.Documents[1].Key).To(BeEquivalentTo(Customer1.Orders[2].Key)) - Expect(result.Documents[1].Key.Collection.Parent).To(BeEquivalentTo(Customer1.Key)) + Expect(*result.Documents[1].Key).To(BeEquivalentTo(Customer1.Orders[2].Key)) + Expect(*result.Documents[1].Key.Collection.Parent).To(BeEquivalentTo(Customer1.Key)) }) }) When("key: {customers, nil}, subcol: orders, exps: [number < 1]", func() { @@ -777,11 +777,11 @@ func QueryTests(docPlugin sdk.DocumentService) { Expect(err).ShouldNot(HaveOccurred()) Expect(result.Documents).To(HaveLen(2)) Expect(result.Documents[0].Content["testName"]).To(BeEquivalentTo(Customer1.Orders[0].Content["testName"])) - Expect(result.Documents[0].Key).To(BeEquivalentTo(Customer1.Orders[0].Key)) - Expect(result.Documents[0].Key.Collection.Parent).To(BeEquivalentTo(Customer1.Key)) + Expect(*result.Documents[0].Key).To(BeEquivalentTo(Customer1.Orders[0].Key)) + Expect(*result.Documents[0].Key.Collection.Parent).To(BeEquivalentTo(Customer1.Key)) Expect(result.Documents[1].Content["testName"]).To(BeEquivalentTo(Customer2.Orders[0].Content["testName"])) - Expect(result.Documents[1].Key).To(BeEquivalentTo(Customer2.Orders[0].Key)) - Expect(result.Documents[1].Key.Collection.Parent).To(BeEquivalentTo(Customer2.Key)) + Expect(*result.Documents[1].Key).To(BeEquivalentTo(Customer2.Orders[0].Key)) + Expect(*result.Documents[1].Key.Collection.Parent).To(BeEquivalentTo(Customer2.Key)) }) }) When("key: {customers, key1}, subcol: orders, exps: [number <= 1]", func() { @@ -800,8 +800,8 @@ func QueryTests(docPlugin sdk.DocumentService) { Expect(err).ShouldNot(HaveOccurred()) Expect(result.Documents).To(HaveLen(1)) Expect(result.Documents[0].Content["testName"]).To(BeEquivalentTo(Customer1.Orders[0].Content["testName"])) - Expect(result.Documents[0].Key.Id).To(Equal(Customer1.Orders[0].Key.Id)) - Expect(result.Documents[0].Key.Collection.Parent.Id).To(Equal(Customer1.Key)) + Expect(*result.Documents[0].Key).To(BeEquivalentTo(Customer1.Orders[0].Key.Id)) + Expect(*result.Documents[0].Key.Collection.Parent).To(BeEquivalentTo(Customer1.Key)) }) }) When("key {customers, nil}, subcol: orders, exps: [type startsWith scooter]", func() { @@ -821,10 +821,10 @@ func QueryTests(docPlugin sdk.DocumentService) { Expect(result.Documents).To(HaveLen(2)) Expect(result.Documents[0].Content["testName"]).To(BeEquivalentTo(Customer1.Orders[2].Content["testName"])) Expect(result.Documents[1].Content["testName"]).To(BeEquivalentTo(Customer2.Orders[1].Content["testName"])) - Expect(result.Documents[0].Key.Collection.Parent.Id).To(Equal(Customer1.Key.Id)) - Expect(result.Documents[0].Key.Id).To(Equal(Customer1.Orders[2].Key.Id)) - Expect(result.Documents[1].Key.Collection.Parent.Id).To(Equal(Customer2.Key.Id)) - Expect(result.Documents[1].Key.Id).To(Equal(Customer2.Orders[1].Key.Id)) + Expect(*result.Documents[0].Key.Collection.Parent).To(BeEquivalentTo(Customer1.Key)) + Expect(*result.Documents[0].Key).To(BeEquivalentTo(Customer1.Orders[2].Key)) + Expect(*result.Documents[1].Key.Collection.Parent).To(BeEquivalentTo(Customer2.Key)) + Expect(*result.Documents[1].Key).To(BeEquivalentTo(Customer2.Orders[1].Key)) }) }) When("key {customers, key1}, subcol: orders, exps: [type startsWith bike/road]", func() { @@ -843,8 +843,8 @@ func QueryTests(docPlugin sdk.DocumentService) { Expect(err).ShouldNot(HaveOccurred()) Expect(result.Documents).To(HaveLen(1)) Expect(result.Documents[0].Content["testName"]).To(BeEquivalentTo(Customer1.Orders[2].Content["testName"])) - Expect(result.Documents[0].Key).To(BeEquivalentTo(Customer1.Orders[2].Key)) - Expect(result.Documents[0].Key.Collection.Parent).To(BeEquivalentTo(Customer1.Key)) + Expect(*result.Documents[0].Key).To(BeEquivalentTo(Customer1.Orders[2].Key)) + Expect(*result.Documents[0].Key.Collection.Parent).To(BeEquivalentTo(Customer1.Key)) }) }) When("key: {items, nil}, subcol: '', exp: [], limit: 10", func() { From 184f4a8a11ded95abe751ff3fbebda7223a62d0d Mon Sep 17 00:00:00 2001 From: Tim Holm Date: Mon, 19 Jul 2021 17:08:25 +1000 Subject: [PATCH 14/16] chore: Fix incorrect assertion. --- tests/plugins/document/suite.go | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/tests/plugins/document/suite.go b/tests/plugins/document/suite.go index 1e999c122..6d13d41c7 100644 --- a/tests/plugins/document/suite.go +++ b/tests/plugins/document/suite.go @@ -800,7 +800,7 @@ func QueryTests(docPlugin sdk.DocumentService) { Expect(err).ShouldNot(HaveOccurred()) Expect(result.Documents).To(HaveLen(1)) Expect(result.Documents[0].Content["testName"]).To(BeEquivalentTo(Customer1.Orders[0].Content["testName"])) - Expect(*result.Documents[0].Key).To(BeEquivalentTo(Customer1.Orders[0].Key.Id)) + Expect(*result.Documents[0].Key).To(BeEquivalentTo(Customer1.Orders[0].Key)) Expect(*result.Documents[0].Key.Collection.Parent).To(BeEquivalentTo(Customer1.Key)) }) }) From 5788c7ffe21fee198f75d8b07056b842bd6a0aa4 Mon Sep 17 00:00:00 2001 From: Tim Holm Date: Tue, 20 Jul 2021 10:34:41 +1000 Subject: [PATCH 15/16] chore: Address review comments. --- pkg/plugins/document/boltdb/boltdb.go | 3 +-- pkg/plugins/document/dynamodb/dynamodb.go | 1 - 2 files changed, 1 insertion(+), 3 deletions(-) diff --git a/pkg/plugins/document/boltdb/boltdb.go b/pkg/plugins/document/boltdb/boltdb.go index bfc71fa65..a164379a2 100644 --- a/pkg/plugins/document/boltdb/boltdb.go +++ b/pkg/plugins/document/boltdb/boltdb.go @@ -326,8 +326,7 @@ func toSdkDoc(col *sdk.Collection, doc BoltDoc) *sdk.Document { Content: doc.Value, Key: &sdk.Key{ Collection: c, - // TODO: need to split out parent key id... - Id: id, + Id: id, }, } } diff --git a/pkg/plugins/document/dynamodb/dynamodb.go b/pkg/plugins/document/dynamodb/dynamodb.go index 25375d44e..8f2fc3c7a 100644 --- a/pkg/plugins/document/dynamodb/dynamodb.go +++ b/pkg/plugins/document/dynamodb/dynamodb.go @@ -452,7 +452,6 @@ func marshalQueryResult( }, } } - // Get the sort key as a string // Split out sort key value delete(m, ATTRIB_PK) From ff5352d53ef4f0968fb1c67b1da8ba3ddfeda224 Mon Sep 17 00:00:00 2001 From: Jye Cusch Date: Thu, 22 Jul 2021 10:27:44 +1000 Subject: [PATCH 16/16] fix: boltdb miscounting records with failed matchers --- pkg/plugins/document/boltdb/boltdb.go | 23 +++++++---------------- 1 file changed, 7 insertions(+), 16 deletions(-) diff --git a/pkg/plugins/document/boltdb/boltdb.go b/pkg/plugins/document/boltdb/boltdb.go index a164379a2..1ba794dc2 100644 --- a/pkg/plugins/document/boltdb/boltdb.go +++ b/pkg/plugins/document/boltdb/boltdb.go @@ -206,28 +206,19 @@ func (s *BoltDocService) Query(collection *sdk.Collection, expressions []sdk.Que documents := make([]sdk.Document, 0) scanCount := 0 for _, doc := range docs { + scanCount += 1 if filterExp != nil { - eval, err := filterExp.Evaluate(doc.Value) - if err != nil { - //return nil, err - //fmt.Printf("failed to evaluate query expression for document. Details: %v\n\tExpression: %v\n\tDocument: %v\n", err, filterExp.String(), doc.Value) + include, err := filterExp.Evaluate(doc.Value) + if err != nil || !(include.(bool)) { // TODO: determine if skipping failed evaluations is always appropriate. - // Treat a failed eval as a mismatch, since it's usually a datatype mismatch or a missing key/prop on the doc, which is essentially a failed match. + // errors are usually a datatype mismatch or a missing key/prop on the doc, which is essentially a failed match. + // Treat a failed or false eval as a mismatch continue } - include := eval.(bool) - if include { - sdkDoc := toSdkDoc(collection, doc) - documents = append(documents, *sdkDoc) - } - - } else { - sdkDoc := toSdkDoc(collection, doc) - documents = append(documents, *sdkDoc) } - - scanCount += 1 + sdkDoc := toSdkDoc(collection, doc) + documents = append(documents, *sdkDoc) // Break if greater than fetch limit if limit > 0 && len(documents) == limit {