summaryrefslogtreecommitdiffhomepage
path: root/tools/go_marshal/main.go
diff options
context:
space:
mode:
authorRahat Mahmood <rahat@google.com>2020-09-29 17:27:16 -0700
committergVisor bot <gvisor-bot@google.com>2020-09-29 17:29:08 -0700
commitfee2c0772811d1c6de5fc9d3a754108994f4c4ab (patch)
tree78cadb5871e4f15be17f52cb4a49c863ad0d06e6 /tools/go_marshal/main.go
parent6ae83404afcfdcc02966487973eef354969984f5 (diff)
go-marshal tests should respect build tags.
Previously, the go-marshal-generated tests did not respect build tags. This can cause the test to unbuildable under some build configurations, as the original types the tests refer to may not be defined. This CL copies the build tags from the input files to the test, similar to the generated library; however test packages have an additional constraint. A test package cannot be totally empty (i.e. have no test/example/benchmark defined), otherwise the go compiler returns an error. To ensure the generated test package always contains a testable entity under all build configurations, we now emit an extra test file with no build tags that contains a single no-op example. PiperOrigin-RevId: 334496821
Diffstat (limited to 'tools/go_marshal/main.go')
-rw-r--r--tools/go_marshal/main.go11
1 files changed, 6 insertions, 5 deletions
diff --git a/tools/go_marshal/main.go b/tools/go_marshal/main.go
index f74be5c29..6e4a3e8c4 100644
--- a/tools/go_marshal/main.go
+++ b/tools/go_marshal/main.go
@@ -31,10 +31,11 @@ import (
)
var (
- pkg = flag.String("pkg", "", "output package")
- output = flag.String("output", "", "output file")
- outputTest = flag.String("output_test", "", "output file for tests")
- imports = flag.String("imports", "", "comma-separated list of extra packages to import in generated code")
+ pkg = flag.String("pkg", "", "output package")
+ output = flag.String("output", "", "output file")
+ outputTest = flag.String("output_test", "", "output file for tests")
+ outputTestUnconditional = flag.String("output_test_unconditional", "", "output file for unconditional tests")
+ imports = flag.String("imports", "", "comma-separated list of extra packages to import in generated code")
)
func main() {
@@ -61,7 +62,7 @@ func main() {
// as an import.
extraImports = strings.Split(*imports, ",")
}
- g, err := gomarshal.NewGenerator(flag.Args(), *output, *outputTest, *pkg, extraImports)
+ g, err := gomarshal.NewGenerator(flag.Args(), *output, *outputTest, *outputTestUnconditional, *pkg, extraImports)
if err != nil {
panic(err)
}