mirror of
https://github.com/moby/moby.git
synced 2022-11-09 12:21:53 -05:00
82 lines
2 KiB
Go
82 lines
2 KiB
Go
|
/*Package subtest provides a TestContext to subtests which handles cleanup, and
|
||
|
provides a testing.TB, and context.Context.
|
||
|
|
||
|
This package was inspired by github.com/frankban/quicktest.
|
||
|
*/
|
||
|
package subtest // import "gotest.tools/x/subtest"
|
||
|
|
||
|
import (
|
||
|
"context"
|
||
|
"testing"
|
||
|
)
|
||
|
|
||
|
type testcase struct {
|
||
|
testing.TB
|
||
|
ctx context.Context
|
||
|
cleanupFuncs []cleanupFunc
|
||
|
}
|
||
|
|
||
|
type cleanupFunc func()
|
||
|
|
||
|
func (tc *testcase) Ctx() context.Context {
|
||
|
if tc.ctx == nil {
|
||
|
var cancel func()
|
||
|
tc.ctx, cancel = context.WithCancel(context.Background())
|
||
|
tc.AddCleanup(cancel)
|
||
|
}
|
||
|
return tc.ctx
|
||
|
}
|
||
|
|
||
|
// Cleanup runs all cleanup functions. Functions are run in the opposite order
|
||
|
// in which they were added. Cleanup is called automatically before Run exits.
|
||
|
func (tc *testcase) Cleanup() {
|
||
|
for _, f := range tc.cleanupFuncs {
|
||
|
// Defer all cleanup functions so they all run even if one calls
|
||
|
// t.FailNow() or panics. Deferring them also runs them in reverse order.
|
||
|
defer f()
|
||
|
}
|
||
|
tc.cleanupFuncs = nil
|
||
|
}
|
||
|
|
||
|
func (tc *testcase) AddCleanup(f func()) {
|
||
|
tc.cleanupFuncs = append(tc.cleanupFuncs, f)
|
||
|
}
|
||
|
|
||
|
func (tc *testcase) Parallel() {
|
||
|
tp, ok := tc.TB.(parallel)
|
||
|
if !ok {
|
||
|
panic("Parallel called with a testing.B")
|
||
|
}
|
||
|
tp.Parallel()
|
||
|
}
|
||
|
|
||
|
type parallel interface {
|
||
|
Parallel()
|
||
|
}
|
||
|
|
||
|
// Run a subtest. When subtest exits, every cleanup function added with
|
||
|
// TestContext.AddCleanup will be run.
|
||
|
func Run(t *testing.T, name string, subtest func(t TestContext)) bool {
|
||
|
return t.Run(name, func(t *testing.T) {
|
||
|
tc := &testcase{TB: t}
|
||
|
defer tc.Cleanup()
|
||
|
subtest(tc)
|
||
|
})
|
||
|
}
|
||
|
|
||
|
// TestContext provides a testing.TB and a context.Context for a test case.
|
||
|
type TestContext interface {
|
||
|
testing.TB
|
||
|
// AddCleanup function which will be run when before Run returns.
|
||
|
AddCleanup(f func())
|
||
|
// Ctx returns a context for the test case. Multiple calls from the same subtest
|
||
|
// will return the same context. The context is cancelled when Run
|
||
|
// returns.
|
||
|
Ctx() context.Context
|
||
|
// Parallel calls t.Parallel on the testing.TB. Panics if testing.TB does
|
||
|
// not implement Parallel.
|
||
|
Parallel()
|
||
|
}
|
||
|
|
||
|
var _ TestContext = &testcase{}
|