prysm-pulse/shared/slotticker/slotticker_test.go

126 lines
2.7 KiB
Go

package slotticker
import (
"testing"
"time"
)
func TestSlotTicker(t *testing.T) {
ticker := SlotTicker{
c: make(chan uint64),
done: make(chan struct{}),
}
defer ticker.Done()
var sinceDuration time.Duration
since := func(time.Time) time.Duration {
return sinceDuration
}
var untilDuration time.Duration
until := func(time.Time) time.Duration {
return untilDuration
}
var tick chan time.Time
after := func(time.Duration) <-chan time.Time {
return tick
}
genesisTime := time.Date(2018, 1, 1, 0, 0, 0, 0, time.UTC)
slotDuration := uint64(8)
// Test when the ticker starts immediately after genesis time.
sinceDuration = 1 * time.Second
untilDuration = 7 * time.Second
// Make this a buffered channel to prevent a deadlock since
// the other goroutine calls a function in this goroutine.
tick = make(chan time.Time, 2)
ticker.start(genesisTime, slotDuration, since, until, after)
// Tick once
tick <- time.Now()
slot := <-ticker.C()
if slot != 1 {
t.Fatalf("Expected 1, got %d", slot)
}
// Tick twice
tick <- time.Now()
slot = <-ticker.C()
if slot != 2 {
t.Fatalf("Expected 2, got %d", slot)
}
}
func TestSlotTickerGenesis(t *testing.T) {
ticker := SlotTicker{
c: make(chan uint64),
done: make(chan struct{}),
}
defer ticker.Done()
var sinceDuration time.Duration
since := func(time.Time) time.Duration {
return sinceDuration
}
var untilDuration time.Duration
until := func(time.Time) time.Duration {
return untilDuration
}
var tick chan time.Time
after := func(time.Duration) <-chan time.Time {
return tick
}
genesisTime := time.Date(2018, 1, 1, 0, 0, 0, 0, time.UTC)
slotDuration := uint64(8)
// Test when the ticker starts before genesis time.
sinceDuration = -1 * time.Second
untilDuration = 1 * time.Second
// Make this a buffered channel to prevent a deadlock since
// the other goroutine calls a function in this goroutine.
tick = make(chan time.Time, 2)
ticker.start(genesisTime, slotDuration, since, until, after)
// Tick once
tick <- time.Now()
slot := <-ticker.C()
if slot != 0 {
t.Fatalf("Expected 0, got %d", slot)
}
// Tick twice
tick <- time.Now()
slot = <-ticker.C()
if slot != 1 {
t.Fatalf("Expected 1, got %d", slot)
}
}
func TestCurrentSlot(t *testing.T) {
// Test slot 0
genesisTime := time.Now()
slot := CurrentSlot(genesisTime, 5, time.Since)
if slot != 0 {
t.Errorf("Expected 0, got: %d", slot)
}
// Test a future genesis time
genesisTime = genesisTime.Add(3 * time.Second)
slot = CurrentSlot(genesisTime, 5, time.Since)
if slot != 0 {
t.Errorf("Expected 0, got: %d", slot)
}
// Test slot 3
genesisTime = genesisTime.Add(-18 * time.Second)
slot = CurrentSlot(genesisTime, 5, time.Since)
if slot != 3 {
t.Errorf("Expected 3, got: %d", slot)
}
}