From fb649192206dc3d7e019a6681e6ea0791c75a1fa Mon Sep 17 00:00:00 2001 From: Ben Kraft Date: Mon, 15 Aug 2022 14:54:16 -0700 Subject: [PATCH] Give a better error if package_bindings is a file The entries under the new `package_bindings` field should be packages, but it's an easy mistake to put a file path instead (most of the other fields in `genqlient.yaml` are files). Due to some bizzare behavior from `go/packages` (described in #220), if you do that you get weird broken code that gives you no clue what is wrong. Instead, let's guess if what you gave us looks like a filename, and report a nice error if so. Test plan: crossed fingers --- generate/config.go | 9 +++++++++ 1 file changed, 9 insertions(+) diff --git a/generate/config.go b/generate/config.go index d37b5cef..d06d5c1e 100644 --- a/generate/config.go +++ b/generate/config.go @@ -6,6 +6,7 @@ import ( "go/token" "os" "path/filepath" + "strings" "golang.org/x/tools/go/packages" "gopkg.in/yaml.v2" @@ -110,6 +111,14 @@ func (c *Config) ValidateAndFillDefaults(baseDir string) error { if len(c.PackageBindings) > 0 { for _, binding := range c.PackageBindings { + if strings.HasSuffix(binding.Package, ".go") { + // total heuristic -- but this is an easy mistake to make and + // results in rather bizarre behavior from go/packages. + return errorf(nil, + "package %v looks like a file, but should be a package-name", + binding.Package) + } + mode := packages.NeedImports | packages.NeedTypes | packages.NeedTypesSizes pkgs, err := packages.Load(&packages.Config{ Mode: mode,