blob: 36bd457a46432149c990afe5a8a6ea2e58318f7d [file] [log] [blame]
package poll
import (
"fmt"
"testing"
"time"
"gotest.tools/v3/assert"
"gotest.tools/v3/assert/cmp"
)
type fakeT struct {
failed string
}
func (t *fakeT) Fatalf(format string, args ...interface{}) {
t.failed = fmt.Sprintf(format, args...)
panic("exit wait on")
}
func (t *fakeT) Log(args ...interface{}) {}
func (t *fakeT) Logf(format string, args ...interface{}) {}
func TestWaitOn(t *testing.T) {
counter := 0
end := 4
check := func(t LogT) Result {
if counter == end {
return Success()
}
counter++
return Continue("counter is at %d not yet %d", counter-1, end)
}
WaitOn(t, check, WithDelay(0))
assert.Equal(t, end, counter)
}
func TestWaitOnWithTimeout(t *testing.T) {
fakeT := &fakeT{}
check := func(t LogT) Result {
return Continue("not done")
}
assert.Assert(t, cmp.Panics(func() {
WaitOn(fakeT, check, WithTimeout(time.Millisecond))
}))
assert.Equal(t, "timeout hit after 1ms: not done", fakeT.failed)
}
func TestWaitOnWithCheckTimeout(t *testing.T) {
fakeT := &fakeT{}
check := func(t LogT) Result {
time.Sleep(1 * time.Second)
return Continue("not done")
}
assert.Assert(t, cmp.Panics(func() { WaitOn(fakeT, check, WithTimeout(time.Millisecond)) }))
assert.Equal(t, "timeout hit after 1ms: first check never completed", fakeT.failed)
}
func TestWaitOnWithCheckError(t *testing.T) {
fakeT := &fakeT{}
check := func(t LogT) Result {
return Error(fmt.Errorf("broke"))
}
assert.Assert(t, cmp.Panics(func() { WaitOn(fakeT, check) }))
assert.Equal(t, "polling check failed: broke", fakeT.failed)
}
func TestWaitOn_WithCompare(t *testing.T) {
fakeT := &fakeT{}
check := func(t LogT) Result {
return Compare(cmp.Equal(3, 4))
}
assert.Assert(t, cmp.Panics(func() {
WaitOn(fakeT, check, WithDelay(0), WithTimeout(10*time.Millisecond))
}))
assert.Assert(t, cmp.Contains(fakeT.failed, "assertion failed: 3 (int) != 4 (int)"))
}