Documentation ¶
Overview ¶
Package testutil provides test utility functions.
Index ¶
- Variables
- func AfterTest(t *testing.T)
- func AssertEqual(t *testing.T, e, a interface{}, msg ...string)
- func AssertFalse(t *testing.T, v bool, msg ...string)
- func AssertNil(t *testing.T, v interface{})
- func AssertNotNil(t *testing.T, v interface{})
- func AssertTrue(t *testing.T, v bool, msg ...string)
- func CheckAfterTest(d time.Duration) error
- func CheckLeakedGoroutine() bool
- func ExitInShortMode(reason string)
- func FatalStack(t *testing.T, s string)
- func MustCheckLeakedGoroutine()
- func MustNewURL(t *testing.T, s string) *url.URL
- func MustNewURLs(t *testing.T, urls []string) []url.URL
- func MustTestMainWithLeakDetection(m *testing.M)
- func Poll(interval time.Duration, timeout time.Duration, condition ConditionFunc) (bool, error)
- func SkipTestIfShortMode(t testing.TB, reason string)
- func WaitSchedule()
- type Action
- type ConditionFunc
- type PauseableHandler
- type Recorder
- type RecorderBuffered
Constants ¶
This section is empty.
Variables ¶
var ( ApplyTimeout = time.Second RequestTimeout = 3 * time.Second )
Functions ¶
func AfterTest ¶
AfterTest is meant to run in a defer that executes after a test completes. It will detect common goroutine leaks, retrying in case there are goroutines not synchronously torn down, and fail the test if any goroutines are stuck.
func AssertEqual ¶
func AssertNotNil ¶
func CheckAfterTest ¶
CheckAfterTest returns an error if AfterTest would fail with an error. Waits for go-routines shutdown for 'd'.
func CheckLeakedGoroutine ¶
func CheckLeakedGoroutine() bool
CheckLeakedGoroutine verifies tests do not leave any leaky goroutines. It returns true when there are goroutines still running(leaking) after all tests.
import "github.com/btwiuse/etcd/v3/pkg/testutil" func TestMain(m *testing.M) { testutil.MustTestMainWithLeakDetection(m) } func TestSample(t *testing.T) { defer testutil.AfterTest(t) ... }
func ExitInShortMode ¶
func ExitInShortMode(reason string)
ExitInShortMode closes the current process (with 0) if the short test mode detected.
To be used in Test-main, where test context (testing.TB) is not available.
Requires custom env-variable (GOLANG_TEST_SHORT) apart of `go test --short flag`.
func FatalStack ¶
FatalStack helps to fatal the test and print out the stacks of all running goroutines.
func MustCheckLeakedGoroutine ¶
func MustCheckLeakedGoroutine()
func MustTestMainWithLeakDetection ¶
MustTestMainWithLeakDetection expands standard m.Run with leaked goroutines detection.
func Poll ¶
Poll calls a condition function repeatedly on a polling interval until it returns true, returns an error or the timeout is reached. If the condition function returns true or an error before the timeout, Poll immediately returns with the true value or the error. If the timeout is exceeded, Poll returns false.
func SkipTestIfShortMode ¶
func WaitSchedule ¶
func WaitSchedule()
WaitSchedule briefly sleeps in order to invoke the go scheduler. TODO: improve this when we are able to know the schedule or status of target go-routine.
Types ¶
type ConditionFunc ¶
ConditionFunc returns true when a condition is met.
type PauseableHandler ¶
func (*PauseableHandler) Pause ¶
func (ph *PauseableHandler) Pause()
func (*PauseableHandler) Resume ¶
func (ph *PauseableHandler) Resume()
func (*PauseableHandler) ServeHTTP ¶
func (ph *PauseableHandler) ServeHTTP(w http.ResponseWriter, r *http.Request)
type Recorder ¶
type Recorder interface { // Record publishes an Action (e.g., function call) which will // be reflected by Wait() or Chan() Record(a Action) // Wait waits until at least n Actions are available or returns with error Wait(n int) ([]Action, error) // Action returns immediately available Actions Action() []Action // Chan returns the channel for actions published by Record Chan() <-chan Action }
func NewRecorderStream ¶
func NewRecorderStream() Recorder
type RecorderBuffered ¶
RecorderBuffered appends all Actions to a slice
func (*RecorderBuffered) Action ¶
func (r *RecorderBuffered) Action() []Action
func (*RecorderBuffered) Chan ¶
func (r *RecorderBuffered) Chan() <-chan Action
func (*RecorderBuffered) Record ¶
func (r *RecorderBuffered) Record(a Action)