| // Copyright 2025 The Fuchsia Authors. All rights reserved. |
| // Use of this source code is governed by a BSD-style license that can be |
| // found in the LICENSE file. |
| |
| package main |
| |
| import ( |
| "bytes" |
| "context" |
| "encoding/json" |
| "flag" |
| "fmt" |
| "io" |
| "os" |
| |
| "go.fuchsia.dev/fuchsia/tools/go_test_parser" |
| "go.fuchsia.dev/fuchsia/tools/lib/subprocess" |
| "go.fuchsia.dev/fuchsia/tools/testing/runtests" |
| "go.fuchsia.dev/fuchsia/tools/testing/testrunner/constants" |
| ) |
| |
| func usage() { |
| fmt.Printf(`go_test_parser [go test command] |
| |
| Reads stdout from the go test command, and writes a JSON formatted summary to stdout |
| of any error messages parsed from the logs. |
| `) |
| } |
| |
| func indentJSON(jsonBytes []byte) ([]byte, error) { |
| buffer := bytes.NewBuffer([]byte{}) |
| err := json.Indent(buffer, jsonBytes, "", "\t") |
| return buffer.Bytes(), err |
| } |
| |
| func mainImpl() error { |
| flag.Usage = usage |
| |
| // Parse any global flags (e.g. those for glog) |
| flag.Parse() |
| |
| args := flag.Args() |
| |
| var testErr error |
| stdoutForParsing := new(bytes.Buffer) |
| testStdout := io.MultiWriter(os.Stdout, stdoutForParsing) |
| r := &subprocess.Runner{Env: os.Environ()} |
| fmt.Fprintf(os.Stdout, "Running %s\n", args[0]) |
| if err := r.Run(context.Background(), args, subprocess.RunOptions{Stdout: testStdout}); err != nil { |
| testErr = fmt.Errorf("Error running test: %w", err) |
| } |
| |
| if outputSummaryPath := os.Getenv(constants.TestOutputSummaryPathEnvKey); outputSummaryPath != "" { |
| cases := go_test_parser.Parse(stdoutForParsing.Bytes()) |
| result := runtests.TestResult{ |
| Cases: cases, |
| } |
| jsonData, err := json.Marshal(result) |
| if err != nil { |
| return fmt.Errorf("Error marshaling JSON: %w", err) |
| } |
| indentedData, err := indentJSON(jsonData) |
| if err != nil { |
| return fmt.Errorf("Error indenting JSON: %w", err) |
| } |
| output, err := os.Create(outputSummaryPath) |
| if err != nil { |
| return fmt.Errorf("Error creating output path %s: %w", outputSummaryPath, err) |
| } |
| if _, err := output.Write(indentedData); err != nil { |
| return fmt.Errorf("Error writing output: %w", err) |
| } |
| } |
| return testErr |
| } |
| |
| func main() { |
| if err := mainImpl(); err != nil { |
| fmt.Fprintf(os.Stderr, "%s\n", err) |
| os.Exit(1) |
| } |
| } |