Print JSON instead of raw Go structs for -debug.print-events

This commit is contained in:
Joël Stemmer 2022-03-20 22:43:51 +00:00
parent 9e3af115d3
commit 26cb3d5eb3
2 changed files with 20 additions and 16 deletions

View File

@ -1,6 +1,7 @@
package main package main
import ( import (
"encoding/json"
"encoding/xml" "encoding/xml"
"flag" "flag"
"fmt" "fmt"
@ -82,8 +83,11 @@ func main() {
} }
if *printEvents { if *printEvents {
for i, ev := range parser.Events() { enc := json.NewEncoder(os.Stderr)
fmt.Printf("%02d: %#v\n", i, ev) for _, event := range parser.Events() {
if err := enc.Encode(event); err != nil {
exitf("error printing events: %v\n", err)
}
} }
} }
for i := range report.Packages { for i := range report.Packages {

View File

@ -2,24 +2,24 @@ package gotest
import "time" import "time"
// Event is a single event in a test or benchmark. // Event is a single event in a Go test or benchmark.
type Event struct { type Event struct {
Type string Type string `json:"type"`
Name string Name string `json:"name,omitempty"`
Result string Result string `json:"result,omitempty"`
Duration time.Duration Duration time.Duration `json:"duration,omitempty"`
Data string Data string `json:"data,omitempty"`
Indent int Indent int `json:"indent,omitempty"`
// Code coverage // Code coverage
CovPct float64 CovPct float64 `json:"coverage_percentage,omitempty"`
CovPackages []string CovPackages []string `json:"coverage_packages,omitempty"`
// Benchmarks // Benchmarks
Iterations int64 Iterations int64 `json:"benchmark_iterations,omitempty"`
NsPerOp float64 NsPerOp float64 `json:"benchmark_ns_per_op,omitempty"`
MBPerSec float64 MBPerSec float64 `json:"benchmark_mb_per_sec,omitempty"`
BytesPerOp int64 BytesPerOp int64 `json:"benchmark_bytes_per_op,omitempty"`
AllocsPerOp int64 AllocsPerOp int64 `json:"benchmark_allocs_per_op,omitempty"`
} }