Skip to content

Kevinello/benchvisual

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

28 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

benchvisual

Parse and visualize Golang standard Benchmark output. mainly based on regexp2 + go-echart + cobra

Motivation

benchvisual is a tool for visualizing Golang standard Benchmark output, which will show benchmark metrics in different charts, group by benchmark scenario, make it convenient for user to compare same metric of different benchmark target in a specific scenario

Features

  • piped output of go test -bench as input
  • file as input
  • custom regexp / separator for Benchmark name to recognize "target" and "scenario"
  • custom output file path
  • json output instead of visualized output for secondary development
  • baseline mode for comparing with baseline Benchmark result

Install

go install github.com/Kevinello/benchvisual@latest

⚠️ Retracted versions

Versions released erroneously, Please do not install these versions(retracted versions)

  • v0.1.0
  • v0.1.1
  • v0.1.2

Usage

benchvisual --help
Parse and visualize Golang standard Benchmark output.
benchvisual provides pipe mode and file mode, it will work in pipe mode in default, add flag -f to let it work in file mode.
there are two definitions in benchvisual -- "targets" and "scenarios", which the visualization works depends on.
"targets" means targets to generate Benchmark on, and the "scenarios" means specific Benchmark scenarios where the Benchmark run in.
In the visualization progress, we will visualize Benchmark in a concepts mapping below:
        - bench.Set(package) -> page(html)
        - metrics(ns/op...)  -> series of metrics value
        - targets            -> series name(x axis)
        - scenarios          -> dummy values in charts(group name)
benchvisual also provides json output format for your secondary development, use --json to let it output json file.

Usage:
  benchvisual [--version] [--help] [-s <separator> | -r <regexp>] [-f <benchmark path>] [-o <output path>] [--json] [--verbose] [--silent] [<args>]

Examples:
  go test -bench . | benchvisual -r '^Bench(mark)?(?<target>\\S+)/(?<scenario>\\S+)$'
  benchvisual -s '/' -f "path/to/origin/benchmark/file"

Flags:
  -f, --file string     use file mode instead of pipe mode, Read the original Benchmark output from the given file path
  -h, --help            help for benchvisual
      --json            only output parsed Benchmark result in json file
  -o, --output string   directory path to save the output file (default ".")
  -r, --regex string    regexp expression with two sub groups(target and scenario), written in '.NET-style capture groups'--(?<name>re) or (?'name're).
                        e.g., '^Bench(mark)?(?<target>\S+/\S+)/(?<scenario>\S+)$' (default "^Bench(mark)?(?<target>[A-Z]+\\S*)(?<scenario>[A-Z]+\\S*)$")
  -s, --sep string      string separator of a Benchmark string's target and scenario.
                        e.g., we got a benchmark name string 'BenchmarkFibonacci/100times' with separator '/', then the target of it is 'Fibonacci' and the scenario of it is '100times'.
                        
      --silent          disable log(only show fatal log)
      --verbose         enable debug log
  -v, --version         version for benchvisual

Project Structure

Project Structure

TODO

Contribution & Support

Feel free to send a pull request if you consider there's something which can be improved. Also, please open up an issue if you run into a problem when using benchvisual or just have a question.

About

Golang Benchmark Visualization

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages