mirror of https://github.com/stretchr/testify.git
Initial buildup/teardown functionality for issue 19
parent
2b887b0d67
commit
a4c24896e3
|
@ -0,0 +1,6 @@
|
|||
// A full testing suite, to expand upon the features of Go's built-in
|
||||
// testing tool. Most importantly, this package provides interfaces
|
||||
// and structs for creating suites of related tests, and putting
|
||||
// related functionality into methods that will be run before and/or
|
||||
// after the whole suite or each individual test.
|
||||
package suite
|
|
@ -0,0 +1,34 @@
|
|||
package suite
|
||||
|
||||
import "testing"
|
||||
|
||||
// TestingSuite can store and return the current *testing.T context
|
||||
// generated by 'go test'.
|
||||
type TestingSuite interface {
|
||||
T() *testing.T
|
||||
SetT(*testing.T)
|
||||
}
|
||||
|
||||
// BeforeAllSuite has a BeforeSuite method, intended to be run before
|
||||
// the entire suite is tested.
|
||||
type BeforeAllSuite interface {
|
||||
BeforeSuite()
|
||||
}
|
||||
|
||||
// BeforeTestSuite has a BeforeTest method, intended to be run before
|
||||
// each test.
|
||||
type BeforeTestSuite interface {
|
||||
BeforeTest()
|
||||
}
|
||||
|
||||
// AfterAllSuite has an AfterSuite method, intended to be run after the
|
||||
// entire suite has been tested.
|
||||
type AfterAllSuite interface {
|
||||
AfterSuite()
|
||||
}
|
||||
|
||||
// AfterTestSuite has an AfterTest method, intended to be run after
|
||||
// each test.
|
||||
type AfterTestSuite interface {
|
||||
AfterTest()
|
||||
}
|
|
@ -0,0 +1,51 @@
|
|||
package suite
|
||||
|
||||
import (
|
||||
"testing"
|
||||
"reflect"
|
||||
"regexp"
|
||||
)
|
||||
|
||||
// Suite is a basic testing suite with methods for storing and
|
||||
// retrieving the current *testing.T context.
|
||||
type Suite struct {
|
||||
t *testing.T
|
||||
}
|
||||
|
||||
// T retrieves the current *testing.T context.
|
||||
func (suite *Suite) T() *testing.T {
|
||||
return suite.t
|
||||
}
|
||||
|
||||
// SetT sets the current *testing.T context.
|
||||
func (suite *Suite) SetT(t *testing.T) {
|
||||
suite.t = t
|
||||
}
|
||||
|
||||
// Run takes a testing suite and runs all of the tests attached
|
||||
// to it.
|
||||
func Run(t *testing.T, suite TestingSuite) {
|
||||
suite.SetT(t)
|
||||
|
||||
if beforeAllSuite, ok := suite.(BeforeAllSuite); ok {
|
||||
beforeAllSuite.BeforeSuite()
|
||||
}
|
||||
|
||||
if afterAllSuite, ok := suite.(AfterAllSuite); ok {
|
||||
defer afterAllSuite.AfterSuite()
|
||||
}
|
||||
|
||||
methodFinder := reflect.TypeOf(suite)
|
||||
for index := 0; index < methodFinder.NumMethod(); index++ {
|
||||
method := methodFinder.Method(index)
|
||||
if ok, _ := regexp.MatchString("^Test", method.Name); ok {
|
||||
if beforeTestSuite, ok := suite.(BeforeTestSuite); ok {
|
||||
beforeTestSuite.BeforeTest()
|
||||
}
|
||||
method.Func.Call([]reflect.Value{reflect.ValueOf(suite)})
|
||||
if afterTestSuite, ok := suite.(AfterTestSuite); ok {
|
||||
afterTestSuite.AfterTest()
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
|
@ -0,0 +1,71 @@
|
|||
package suite
|
||||
|
||||
import (
|
||||
"testing"
|
||||
"github.com/stretchr/testify/assert"
|
||||
)
|
||||
|
||||
// This suite is intended to store values to make sure that only
|
||||
// testing-suite-related methods are run.
|
||||
type SuiteTester struct {
|
||||
Suite
|
||||
BeforeSuiteRunCount int
|
||||
AfterSuiteRunCount int
|
||||
BeforeTestRunCount int
|
||||
AfterTestRunCount int
|
||||
TestOneRunCount int
|
||||
TestTwoRunCount int
|
||||
NonTestMethodRunCount int
|
||||
}
|
||||
|
||||
func (suite *SuiteTester) BeforeSuite() {
|
||||
suite.BeforeSuiteRunCount++
|
||||
}
|
||||
|
||||
func (suite *SuiteTester) AfterSuite() {
|
||||
suite.AfterSuiteRunCount++
|
||||
}
|
||||
|
||||
func (suite *SuiteTester) BeforeTest() {
|
||||
suite.BeforeTestRunCount++
|
||||
}
|
||||
|
||||
func (suite *SuiteTester) AfterTest() {
|
||||
suite.AfterTestRunCount++
|
||||
}
|
||||
|
||||
func (suite *SuiteTester) TestOne() {
|
||||
suite.TestOneRunCount++
|
||||
}
|
||||
|
||||
func (suite *SuiteTester) TestTwo() {
|
||||
suite.TestTwoRunCount++
|
||||
}
|
||||
|
||||
func (suite *SuiteTester) NonTestMethod() {
|
||||
suite.NonTestMethodRunCount++
|
||||
}
|
||||
|
||||
func TestSuiteLogic(t *testing.T) {
|
||||
suiteTester := new(SuiteTester)
|
||||
Run(t, suiteTester)
|
||||
|
||||
// The suite was only run once, so the BeforeSuite and AfterSuite
|
||||
// methods should have each been run only once.
|
||||
assert.Equal(t, suiteTester.BeforeSuiteRunCount, 1)
|
||||
assert.Equal(t, suiteTester.AfterSuiteRunCount, 1)
|
||||
|
||||
// There are two test methods (TestOne and TestTwo), so the
|
||||
// BeforeTest and AfterTest methods (which should be run once for
|
||||
// each test) should have been run twice.
|
||||
assert.Equal(t, suiteTester.BeforeTestRunCount, 2)
|
||||
assert.Equal(t, suiteTester.AfterTestRunCount, 2)
|
||||
|
||||
// Each test should have been run once.
|
||||
assert.Equal(t, suiteTester.TestOneRunCount, 1)
|
||||
assert.Equal(t, suiteTester.TestTwoRunCount, 1)
|
||||
|
||||
// Methods that don't match the test method identifier shouldn't
|
||||
// have been run at all.
|
||||
assert.Equal(t, suiteTester.NonTestMethodRunCount, 0)
|
||||
}
|
Loading…
Reference in New Issue