-
Notifications
You must be signed in to change notification settings - Fork 556
Home
Welcome to GoConvey, a yummy testing tool for gophers.
- Integrates with
go test
- Readable, colorized console output
- Fully-automatic web UI
- Huge suite of regression tests
- Test code generator
View a comprehensive table of all features compared to other Go testing tools.
- In your terminal:
# make sure your GOPATH is set
cd <project path>
go get github.com/smartystreets/goconvey
go install github.com/smartystreets/goconvey/web/goconvey-server
$GOPATH/bin/goconvey-server
- In your browser:
http://localhost:8080
If you have existing Go tests, they will run automatically and the results will appear in your browser.
Open any _test.go
file and put this in it, customizing your package declaration:
package package_name
import (
"testing"
. "github.com/smartystreets/goconvey/convey"
)
func TestIntegerStuff(t *testing.T) {
var x int
Convey("Given some integer with a starting value", t, func() {
x = 1
Convey("When the integer is incremented", func() {
x++
Convey("The value should be greater by one", func() {
So(x, ShouldEqual, 2)
})
})
})
}
Save the file, then glance over at your browser window, and you'll see that the new tests have already been run.
Change the assertion (the line with So()
) to make the test fail, then see the output change in your browser.
You can also run tests from the terminal as usual, with go test
. If you want the tests to run automatically in the terminal, check out the auto-test script.
See the documentation index for details about assertions, writing tests, execution, etc.