2018-08-13 02:07:37 +00:00
|
|
|
package utils
|
|
|
|
|
|
|
|
import (
|
2018-09-27 02:34:35 +00:00
|
|
|
"math"
|
2018-08-13 02:07:37 +00:00
|
|
|
"time"
|
2018-09-27 02:34:35 +00:00
|
|
|
|
|
|
|
"github.com/prysmaticlabs/prysm/beacon-chain/params"
|
2018-08-13 02:07:37 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
// 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()
|
|
|
|
}
|
2018-09-27 02:34:35 +00:00
|
|
|
|
|
|
|
// CurrentBeaconSlot based on the seconds since genesis.
|
|
|
|
func CurrentBeaconSlot() uint64 {
|
2018-09-28 06:48:39 +00:00
|
|
|
secondsSinceGenesis := time.Since(params.GetConfig().GenesisTime).Seconds()
|
2018-10-02 18:34:26 +00:00
|
|
|
return uint64(math.Floor(secondsSinceGenesis/float64(params.GetConfig().SlotDuration))) - 1
|
2018-09-27 02:34:35 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// 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)
|
|
|
|
}
|