converge/pkg/support/throttling/throtller_test.go
Erik Brakkee 52160a368c more generalization of how time is handled in the tests.
Asynchronous variant that is easier to use and multi-thread safe.
2024-08-16 21:08:44 +02:00

60 lines
1.4 KiB
Go

package throttling
import (
"github.com/stretchr/testify/assert"
"testing"
"time"
)
func Test_throttlerImmediateNotificationAfterInitialized(t *testing.T) {
value := 0
throttler := NewThrottler[int](func(v *int) {
value = *v
}, 1.0)
t0 := time.Now()
v := 1
currentTime.now = t0
throttler.Notify(&v)
assert.Equal(t, v, value)
value = 0
// subsequent ping will not lead to a notification
currentTime.now = t0.Add(10 * time.Second)
throttler.Ping()
assert.Equal(t, 0, value)
}
func Test_TwoNotificationsInSHortSucessionSecondOneIsDeliverdWithDelay(t *testing.T) {
value := 0
delayMs := 1000
throttler := NewThrottler[int](func(v *int) {
value = *v
}, time.Duration(delayMs)*time.Millisecond)
t0 := time.Now()
v1 := 1
// v2 will not be delivered, the last value in the time interval will be
v2 := 2
v3 := 3
currentTime.now = t0
throttler.Notify(&v1)
assert.Equal(t, v1, value)
throttler.Notify(&v2)
throttler.Notify(&v3)
assert.Equal(t, v1, value)
currentTime.now = t0.Add(time.Duration(delayMs-1) * time.Millisecond)
throttler.Ping()
assert.Equal(t, v1, value)
currentTime.now = t0.Add(time.Duration(delayMs) * time.Millisecond)
throttler.Ping()
assert.Equal(t, v3, value)
// another ping won't deliver the same value again.
value = 0
currentTime.now = t0.Add(time.Duration(delayMs) * time.Millisecond)
throttler.Ping()
assert.Equal(t, 0, value)
}