prysm-pulse/beacon-chain/utils/clock.go

38 lines
1.0 KiB
Go
Raw Normal View History

package utils
import (
"math"
"time"
"github.com/prysmaticlabs/prysm/beacon-chain/params"
)
// Clock represents a time providing interface that can be mocked for testing.
type Clock interface {
Now() time.Time
}
// RealClock represents an unmodified clock.
type RealClock struct{}
// Now represents the standard functionality of time.
func (RealClock) Now() time.Time {
return time.Now()
}
// CurrentBeaconSlot based on the seconds since genesis.
func CurrentBeaconSlot() uint64 {
secondsSinceGenesis := time.Since(params.GetConfig().GenesisTime).Seconds()
return uint64(math.Floor(secondsSinceGenesis/float64(params.GetConfig().SlotDuration))) - 1
}
// BlockingWait sleeps until a specific time is reached after
// a certain duration. For example, if the genesis block
// was at 12:00:00PM and the current time is 12:00:03PM,
// we want the next slot to tick at 12:00:08PM so we can use
// this helper method to achieve that purpose.
func BlockingWait(duration time.Duration) {
d := time.Until(time.Now().Add(duration).Truncate(duration))
time.Sleep(d)
}