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")
 | 
						|
	}
 | 
						|
}
 |