mukan-consensus/consensus/ticker_test.go
Mukan Erkin Törük c6a41110d1
Some checks are pending
docker-build-cometbft / vars (push) Waiting to run
docker-build-cometbft / build-images (amd64, ubuntu-24.04) (push) Blocked by required conditions
docker-build-cometbft / build-images (arm64, ubuntu-24.04-arm) (push) Blocked by required conditions
docker-build-cometbft / merge-images (push) Blocked by required conditions
docker-build-e2e-node / vars (push) Waiting to run
docker-build-e2e-node / build-images (amd64, ubuntu-24.04) (push) Blocked by required conditions
docker-build-e2e-node / build-images (arm64, ubuntu-24.04-arm) (push) Blocked by required conditions
docker-build-e2e-node / merge-images (push) Blocked by required conditions
refactor: replace all github.com upstream refs with git.cw.tr/mukan-network
2026-05-11 03:36:20 +03:00

40 lines
1.1 KiB
Go

package consensus
import (
"testing"
"time"
"github.com/stretchr/testify/require"
"git.cw.tr/mukan-network/mukan-consensus/consensus/types"
)
func TestTimeoutTicker(t *testing.T) {
ticker := NewTimeoutTicker()
err := ticker.Start()
require.NoError(t, err)
defer func() {
err := ticker.Stop()
require.NoError(t, err)
}()
c := ticker.Chan()
for i := 1; i <= 10; i++ {
height := int64(i)
startTime := time.Now()
// Schedule a timeout for 5ms from now
negTimeout := timeoutInfo{Duration: -1 * time.Millisecond, Height: height, Round: 0, Step: types.RoundStepNewHeight}
timeout := timeoutInfo{Duration: 5 * time.Millisecond, Height: height, Round: 0, Step: types.RoundStepNewRound}
ticker.ScheduleTimeout(negTimeout)
ticker.ScheduleTimeout(timeout)
// Wait for the timeout to be received
to := <-c
endTime := time.Now()
elapsedTime := endTime.Sub(startTime)
if timeout == to {
require.True(t, elapsedTime >= timeout.Duration, "We got the 5ms timeout. However the timeout happened too quickly. Should be >= 5ms. Got %dms (start time %d end time %d)", elapsedTime.Milliseconds(), startTime.UnixMilli(), endTime.UnixMilli())
}
}
}