Evstigneev Denis
38c5fe8b5a
All checks were successful
test / test (push) Successful in 42s
## Pull Request template Please, go through these steps before clicking submit on this PR. 1. Give a descriptive title to your PR. 2. Provide a description of your changes. 3. Make sure you have some relevant tests. 4. Put `closes #XXXX` in your comment to auto-close the issue that your PR fixes (if applicable). **PLEASE REMOVE THIS TEMPLATE BEFORE SUBMITTING** Reviewed-on: #369 Co-authored-by: Evstigneev Denis <danteevstigneev@yandex.ru> Co-committed-by: Evstigneev Denis <danteevstigneev@yandex.ru>
63 lines
1.3 KiB
Go
63 lines
1.3 KiB
Go
package jitter
|
|
|
|
import (
|
|
"context"
|
|
"testing"
|
|
"time"
|
|
)
|
|
|
|
func TestNewTickerContext(t *testing.T) {
|
|
t.Parallel()
|
|
ctx, cancel := context.WithTimeout(context.Background(), 500*time.Millisecond)
|
|
defer cancel()
|
|
|
|
ticker := NewTickerContext(ctx, 600*time.Millisecond, 1000*time.Millisecond)
|
|
defer ticker.Stop()
|
|
loop:
|
|
for {
|
|
select {
|
|
case <-ctx.Done():
|
|
ticker.Stop()
|
|
break loop
|
|
case v, ok := <-ticker.C:
|
|
if ok {
|
|
t.Fatalf("context must be closed %s", v)
|
|
}
|
|
break loop
|
|
}
|
|
}
|
|
}
|
|
|
|
func TestTicker(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
minTime := time.Duration(10)
|
|
maxTime := time.Duration(20)
|
|
|
|
// tick can take a little longer since we're not adjusting it to account for
|
|
// processing.
|
|
precision := time.Duration(4)
|
|
|
|
rt := NewTicker(minTime*time.Millisecond, maxTime*time.Millisecond)
|
|
for i := 0; i < 5; i++ {
|
|
t0 := time.Now()
|
|
t1 := <-rt.C
|
|
td := t1.Sub(t0)
|
|
if td < minTime*time.Millisecond {
|
|
t.Fatalf("tick was shorter than expected: %s", td)
|
|
} else if td > (maxTime+precision)*time.Millisecond {
|
|
t.Fatalf("tick was longer than expected: %s", td)
|
|
}
|
|
}
|
|
rt.Stop()
|
|
time.Sleep((maxTime + precision) * time.Millisecond)
|
|
select {
|
|
case v, ok := <-rt.C:
|
|
if ok || !v.IsZero() {
|
|
t.Fatal("ticker did not shut down")
|
|
}
|
|
default:
|
|
t.Fatal("expected to receive close channel signal")
|
|
}
|
|
}
|