From 46f4fe2b7f341d25ea93d68bebe11083ef8c0445 Mon Sep 17 00:00:00 2001 From: Dustin Deus Date: Sat, 28 Oct 2023 19:41:09 +0200 Subject: [PATCH] fix: schema usage info path (#648) --- v2/examples/federation/go.mod | 14 +-- v2/examples/federation/go.sum | 8 ++ v2/pkg/engine/plan/schemausageinfo.go | 24 ++--- v2/pkg/engine/plan/schemausageinfo_test.go | 104 +++++++++++++++++++++ 4 files changed, 132 insertions(+), 18 deletions(-) diff --git a/v2/examples/federation/go.mod b/v2/examples/federation/go.mod index 2773b8bbf..bb06b3cc0 100644 --- a/v2/examples/federation/go.mod +++ b/v2/examples/federation/go.mod @@ -33,7 +33,7 @@ require ( github.com/klauspost/compress v1.14.4 // indirect github.com/logrusorgru/aurora/v3 v3.0.0 // indirect github.com/mattn/go-colorable v0.1.13 // indirect - github.com/mattn/go-isatty v0.0.16 // indirect + github.com/mattn/go-isatty v0.0.19 // indirect github.com/minio/highwayhash v1.0.2 // indirect github.com/mitchellh/copystructure v1.0.0 // indirect github.com/mitchellh/mapstructure v1.5.0 // indirect @@ -53,14 +53,14 @@ require ( github.com/urfave/cli/v2 v2.8.1 // indirect github.com/xrash/smetrics v0.0.0-20201216005158-039620a65673 // indirect go.uber.org/multierr v1.6.0 // indirect - golang.org/x/crypto v0.10.0 // indirect + golang.org/x/crypto v0.13.0 // indirect golang.org/x/exp v0.0.0-20230203172020-98cc5a0785f9 // indirect - golang.org/x/mod v0.8.0 // indirect - golang.org/x/net v0.11.0 // indirect - golang.org/x/sys v0.9.0 // indirect - golang.org/x/text v0.10.0 // indirect + golang.org/x/mod v0.12.0 // indirect + golang.org/x/net v0.15.0 // indirect + golang.org/x/sys v0.12.0 // indirect + golang.org/x/text v0.13.0 // indirect golang.org/x/time v0.0.0-20211116232009-f0f3c7e86c11 // indirect - golang.org/x/tools v0.6.0 // indirect + golang.org/x/tools v0.13.0 // indirect golang.org/x/xerrors v0.0.0-20200804184101-5ec99f83aff1 // indirect gopkg.in/cenkalti/backoff.v1 v1.1.0 // indirect gopkg.in/yaml.v3 v3.0.1 // indirect diff --git a/v2/examples/federation/go.sum b/v2/examples/federation/go.sum index 8eae43042..1aca8011e 100644 --- a/v2/examples/federation/go.sum +++ b/v2/examples/federation/go.sum @@ -102,6 +102,7 @@ github.com/mattn/go-colorable v0.1.13/go.mod h1:7S9/ev0klgBDR4GtXTXX8a3vIGJpMovk github.com/mattn/go-isatty v0.0.12/go.mod h1:cbi8OIDigv2wuxKPP5vlRcQ1OAZbq2CE4Kysco4FUpU= github.com/mattn/go-isatty v0.0.16 h1:bq3VjFmv/sOjHtdEhmkEV4x1AJtvUvOJ2PFAZ5+peKQ= github.com/mattn/go-isatty v0.0.16/go.mod h1:kYGgaQfpe5nmfYZH+SKPsOc2e4SrIfOl2e/yFXSvRLM= +github.com/mattn/go-isatty v0.0.19/go.mod h1:W+V8PltTTMOvKvAeJH7IuucS94S2C6jfK/D7dTCTo3Y= github.com/minio/highwayhash v1.0.2 h1:Aak5U0nElisjDCfPSG79Tgzkn2gl66NxOMspRrKnA/g= github.com/minio/highwayhash v1.0.2/go.mod h1:BQskDq+xkJ12lmlUUi7U0M5Swg3EWR+dLTk+kldvVxY= github.com/mitchellh/copystructure v1.0.0 h1:Laisrj+bAB6b/yJwB5Bt3ITZhGJdqmxquMKeZ+mmkFQ= @@ -188,6 +189,7 @@ golang.org/x/crypto v0.0.0-20210314154223-e6e6c4f2bb5b/go.mod h1:T9bdIzuCu7OtxOm golang.org/x/crypto v0.0.0-20210921155107-089bfa567519/go.mod h1:GvvjBRRGRdwPK5ydBHafDWAxML/pGHZbMvKqRZ5+Abc= golang.org/x/crypto v0.10.0 h1:LKqV2xt9+kDzSTfOhx4FrkEBcMrAgHSYgzywV9zcGmM= golang.org/x/crypto v0.10.0/go.mod h1:o4eNf7Ede1fv+hwOwZsTHl9EsPFO6q6ZvYR8vYfY45I= +golang.org/x/crypto v0.13.0/go.mod h1:y6Z2r+Rw4iayiXXAIxJIDAJ1zMW4yaTpebo8fPOliYc= golang.org/x/exp v0.0.0-20230203172020-98cc5a0785f9 h1:frX3nT9RkKybPnjyI+yvZh6ZucTZatCCEm9D47sZ2zo= golang.org/x/exp v0.0.0-20230203172020-98cc5a0785f9/go.mod h1:CxIveKay+FTh1D0yPZemJVgC/95VzuuOLq5Qi4xnoYc= golang.org/x/lint v0.0.0-20190930215403-16217165b5de/go.mod h1:6SW0HCj/g11FgYtHlgUYUwCkIfeOF89ocIRzGO/8vkc= @@ -197,6 +199,7 @@ golang.org/x/mod v0.6.0-dev.0.20220106191415-9b9b3d81d5e3/go.mod h1:3p9vT2HGsQu2 golang.org/x/mod v0.6.0-dev.0.20220419223038-86c51ed26bb4/go.mod h1:jJ57K6gSWd91VN4djpZkiMVwK6gcyfeH4XE8wZrZaV4= golang.org/x/mod v0.8.0 h1:LUYupSeNrTNCGzR/hVBk2NHZO4hXcVaW1k4Qx7rjPx8= golang.org/x/mod v0.8.0/go.mod h1:iBbtSCu2XBx23ZKBPSOrRkjjQPZFPuis4dIYUhu/chs= +golang.org/x/mod v0.12.0/go.mod h1:iBbtSCu2XBx23ZKBPSOrRkjjQPZFPuis4dIYUhu/chs= golang.org/x/net v0.0.0-20190311183353-d8887717615a/go.mod h1:t9HGtf8HONx5eT2rtn7q6eTqICYqUVnKs3thJo3Qplg= golang.org/x/net v0.0.0-20190404232315-eb5bcb51f2a3/go.mod h1:t9HGtf8HONx5eT2rtn7q6eTqICYqUVnKs3thJo3Qplg= golang.org/x/net v0.0.0-20190620200207-3b0461eec859/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s= @@ -206,6 +209,7 @@ golang.org/x/net v0.0.0-20211015210444-4f30a5c0130f/go.mod h1:9nx3DQGgdP8bBQD5qx golang.org/x/net v0.0.0-20220722155237-a158d28d115b/go.mod h1:XRhObCWvk6IyKnWLug+ECip1KBveYUHfp+8e9klMJ9c= golang.org/x/net v0.11.0 h1:Gi2tvZIJyBtO9SDr1q9h5hEQCp/4L2RQ+ar0qjx2oNU= golang.org/x/net v0.11.0/go.mod h1:2L/ixqYpgIVXmeoSA/4Lu7BzTG4KIyPIryS4IsOd1oQ= +golang.org/x/net v0.15.0/go.mod h1:idbUs1IY1+zTqbi8yxTbhexhEEk5ur9LInksu6HrEpk= golang.org/x/sync v0.0.0-20190423024810-112230192c58/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= golang.org/x/sync v0.0.0-20210220032951-036812b2e83c/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= golang.org/x/sync v0.0.0-20220722155255-886fb9371eb4/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= @@ -223,8 +227,10 @@ golang.org/x/sys v0.0.0-20211019181941-9d821ace8654/go.mod h1:oPkhp1MJrh7nUepCBc golang.org/x/sys v0.0.0-20220520151302-bc2c85ada10a/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= golang.org/x/sys v0.0.0-20220722155257-8c9f86f7a55f/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= golang.org/x/sys v0.0.0-20220811171246-fbc7d0a398ab/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.6.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= golang.org/x/sys v0.9.0 h1:KS/R3tvhPqvJvwcKfnBHJwwthS11LRhmM5D59eEXa0s= golang.org/x/sys v0.9.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.12.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= golang.org/x/term v0.0.0-20201126162022-7de9c90e9dd1/go.mod h1:bj7SfCRtBDWHUb9snDiAeCFNEtKQo2Wmx5Cou7ajbmo= golang.org/x/term v0.0.0-20210927222741-03fcf44c2211/go.mod h1:jbD1KX2456YbFQfuXm/mYQcufACuNUgVhRMnK/tPxf8= golang.org/x/text v0.3.0/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ= @@ -235,6 +241,7 @@ golang.org/x/text v0.3.7/go.mod h1:u+2+/6zg+i71rQMx5EYifcz6MCKuco9NR6JIITiCfzQ= golang.org/x/text v0.3.8/go.mod h1:E6s5w1FMmriuDzIBO73fBruAKo1PCIq6d2Q6DHfQ8WQ= golang.org/x/text v0.10.0 h1:UpjohKhiEgNc0CSauXmwYftY1+LlaC75SJwh0SgCX58= golang.org/x/text v0.10.0/go.mod h1:TvPlkZtksWOMsz7fbANvkp4WM8x/WCo/om8BMLbz+aE= +golang.org/x/text v0.13.0/go.mod h1:TvPlkZtksWOMsz7fbANvkp4WM8x/WCo/om8BMLbz+aE= golang.org/x/time v0.0.0-20191024005414-555d28b269f0/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ= golang.org/x/time v0.0.0-20211116232009-f0f3c7e86c11 h1:GZokNIeuVkl3aZHJchRrr13WCsols02MLUcz1U9is6M= golang.org/x/time v0.0.0-20211116232009-f0f3c7e86c11/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ= @@ -249,6 +256,7 @@ golang.org/x/tools v0.1.10/go.mod h1:Uh6Zz+xoGYZom868N8YTex3t7RhtHDBrE8Gzo9bV56E golang.org/x/tools v0.1.12/go.mod h1:hNGJHUnrk76NpqgfD5Aqm5Crs+Hm0VOH/i9J2+nxYbc= golang.org/x/tools v0.6.0 h1:BOw41kyTf3PuCW1pVQf8+Cyg8pMlkYB1oo9iJ6D/lKM= golang.org/x/tools v0.6.0/go.mod h1:Xwgl3UAJ/d3gWutnCtw505GrjyAbvKui8lOU390QaIU= +golang.org/x/tools v0.13.0/go.mod h1:HvlwmtVNQAhOuCjW7xxvovg8wbNq7LwfXh/k7wXUl58= golang.org/x/xerrors v0.0.0-20190717185122-a985d3407aa7/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= golang.org/x/xerrors v0.0.0-20191011141410-1b5146add898/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= golang.org/x/xerrors v0.0.0-20191204190536-9bdfabe68543/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= diff --git a/v2/pkg/engine/plan/schemausageinfo.go b/v2/pkg/engine/plan/schemausageinfo.go index 963833a11..8c978c546 100644 --- a/v2/pkg/engine/plan/schemausageinfo.go +++ b/v2/pkg/engine/plan/schemausageinfo.go @@ -47,19 +47,21 @@ func (p *planVisitor) visitNode(node resolve.Node, path []string) { switch t := node.(type) { case *resolve.Object: for _, field := range t.Fields { - if field.Info != nil { - p.usage.TypeFields = append(p.usage.TypeFields, TypeFieldUsageInfo{ - FieldName: field.Info.Name, - TypeNames: field.Info.ParentTypeNames, - Path: append(path, field.Info.Name), - Source: TypeFieldSource{ - IDs: field.Info.Source.IDs, - }, - }) + if field.Info == nil { + continue } - p.visitNode(field.Value, append(path, t.Path...)) + newPath := append([]string{}, append(path, field.Info.Name)...) + p.usage.TypeFields = append(p.usage.TypeFields, TypeFieldUsageInfo{ + FieldName: field.Info.Name, + TypeNames: field.Info.ParentTypeNames, + Path: newPath, + Source: TypeFieldSource{ + IDs: field.Info.Source.IDs, + }, + }) + p.visitNode(field.Value, newPath) } case *resolve.Array: - p.visitNode(t.Item, append(path, t.Path...)) + p.visitNode(t.Item, path) } } diff --git a/v2/pkg/engine/plan/schemausageinfo_test.go b/v2/pkg/engine/plan/schemausageinfo_test.go index cd612054f..bf60c3185 100644 --- a/v2/pkg/engine/plan/schemausageinfo_test.go +++ b/v2/pkg/engine/plan/schemausageinfo_test.go @@ -71,6 +71,70 @@ func TestGetSchemaUsageInfo(t *testing.T) { Source: source, }, }, + { + Name: []byte("user"), + Info: &resolve.FieldInfo{ + Name: "user", + ParentTypeNames: []string{"searchResults"}, + Source: source, + }, + Value: &resolve.Object{ + Path: []string{"user"}, + Nullable: true, + Fields: []*resolve.Field{ + { + Name: []byte("account"), + Info: &resolve.FieldInfo{ + Name: "account", + ParentTypeNames: []string{"user"}, + Source: source, + }, + Value: &resolve.Object{ + Path: []string{"account"}, + Nullable: true, + Fields: []*resolve.Field{ + { + Name: []byte("name"), + Info: &resolve.FieldInfo{ + Name: "name", + ParentTypeNames: []string{"account"}, + Source: source, + }, + Value: &resolve.String{ + Path: []string{"name"}, + }, + }, + { + Name: []byte("shippingInfo"), + Info: &resolve.FieldInfo{ + Name: "shippingInfo", + ParentTypeNames: []string{"account"}, + Source: source, + }, + Value: &resolve.Object{ + Path: []string{"shippingInfo"}, + Nullable: true, + Fields: []*resolve.Field{ + { + Name: []byte("zip"), + Info: &resolve.FieldInfo{ + Name: "zip", + ParentTypeNames: []string{"shippingInfo"}, + Source: source, + }, + Value: &resolve.String{ + Path: []string{"zip"}, + }, + }, + }, + }, + }, + }, + }, + }, + }, + }, + }, }, }, }, @@ -121,6 +185,46 @@ func TestGetSchemaUsageInfo(t *testing.T) { IDs: []string{"https://swapi.dev/api"}, }, }, + { + Path: []string{"searchResults", "user"}, + TypeNames: []string{"searchResults"}, + FieldName: "user", + Source: TypeFieldSource{ + IDs: []string{"https://swapi.dev/api"}, + }, + }, + { + Path: []string{"searchResults", "user", "account"}, + TypeNames: []string{"user"}, + FieldName: "account", + Source: TypeFieldSource{ + IDs: []string{"https://swapi.dev/api"}, + }, + }, + { + Path: []string{"searchResults", "user", "account", "name"}, + TypeNames: []string{"account"}, + FieldName: "name", + Source: TypeFieldSource{ + IDs: []string{"https://swapi.dev/api"}, + }, + }, + { + Path: []string{"searchResults", "user", "account", "shippingInfo"}, + TypeNames: []string{"account"}, + FieldName: "shippingInfo", + Source: TypeFieldSource{ + IDs: []string{"https://swapi.dev/api"}, + }, + }, + { + Path: []string{"searchResults", "user", "account", "shippingInfo", "zip"}, + TypeNames: []string{"shippingInfo"}, + FieldName: "zip", + Source: TypeFieldSource{ + IDs: []string{"https://swapi.dev/api"}, + }, + }, }, } assert.Equal(t, expected, syncUsage)