| package poll |
| |
| import ( |
| "fmt" |
| "testing" |
| "time" |
| |
| "github.com/pkg/errors" |
| "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(errors.New("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)")) |
| } |