An end-to-end scenario testing tool for HTTP/gRPC server.
scenarigo is an end-to-end scenario testing tool for HTTP/gRPC server. It is written in Go, enable to customize by the plugin package of Go. You can write test scenarios as YAML files and executes them.
title: get scenarigo repository
steps:
- title: GET https://api.github.com/repos/zoncoen/scenarigo
vars:
user: zoncoen
repo: scenarigo
protocol: http
request:
method: GET
url: "https://api.github.com/repos/{{vars.user}}/{{vars.repo}}"
expect:
code: OK
body:
name: "{{vars.repo}}"
$ scenarigo run github.yaml
package main
import (
"testing"
"github.com/zoncoen/scenarigo"
"github.com/zoncoen/scenarigo/context"
)
func TestGitHub(t *testing.T) {
r, err := scenarigo.NewRunner(
scenarigo.WithScenarios(
"testdata/github.yaml",
),
)
if err != nil {
t.Fatalf("failed to create a test runner: %s", err)
}
r.Run(context.FromT(t))
}
$ go test . -run "TestGitHub"
- provides the command-line tool and the Go package for testing
- supports HTTP and gRPC
- customization by writing Go code
Go to the releases page and download the zip file. Unpack the zip file, and put the binary to a directory in your $PATH
.
scenarigo is a scenario testing tool for APIs.
Usage:
scenarigo [command]
Available Commands:
help Help about any command
run run test scenarios
version print scenarigo version
Flags:
-h, --help help for scenarigo
Use "scenarigo [command] --help" for more information about a command.
This project uses the Makefile as a task runner.
test run tests
coverage measure test coverage
lint run lint
gen generate necessary files for testing
release release new version
changelog generate CHANGELOG.md
credits generate CREDITS
help print help