mirror of
https://gitlab.com/pulsechaincom/prysm-pulse.git
synced 2025-01-03 00:27:38 +00:00
Replace no-genesis-delay with custom-genesis-delay (#4678)
* Change NoGenesisDelay to CustomGenesisDelay * Implement flag * gazelle * Fix docs * Merge branch 'master' of https://github.com/prysmaticlabs/Prysm into custom-genesis-delay * Fix * Gazelle * Add case to fix bad math * Merge branch 'master' into custom-genesis-delay
This commit is contained in:
parent
07ba594023
commit
9149c2e4f4
@ -197,7 +197,7 @@ Open up two terminal windows. In the first, issue the command:
|
|||||||
|
|
||||||
```text
|
```text
|
||||||
bazel run //beacon-chain -- \
|
bazel run //beacon-chain -- \
|
||||||
--no-genesis-delay \
|
--custom-genesis-delay=0 \
|
||||||
--bootstrap-node= \
|
--bootstrap-node= \
|
||||||
--deposit-contract $(curl https://prylabs.net/contract) \
|
--deposit-contract $(curl https://prylabs.net/contract) \
|
||||||
--clear-db \
|
--clear-db \
|
||||||
|
@ -76,6 +76,7 @@ go_test(
|
|||||||
"//shared/bls:go_default_library",
|
"//shared/bls:go_default_library",
|
||||||
"//shared/bytesutil:go_default_library",
|
"//shared/bytesutil:go_default_library",
|
||||||
"//shared/event:go_default_library",
|
"//shared/event:go_default_library",
|
||||||
|
"//shared/featureconfig:go_default_library",
|
||||||
"//shared/params:go_default_library",
|
"//shared/params:go_default_library",
|
||||||
"//shared/testutil:go_default_library",
|
"//shared/testutil:go_default_library",
|
||||||
"//shared/trieutil:go_default_library",
|
"//shared/trieutil:go_default_library",
|
||||||
|
@ -240,12 +240,12 @@ func (s *Service) ProcessChainStart(genesisTime uint64, eth1BlockHash [32]byte,
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (s *Service) createGenesisTime(timeStamp uint64) uint64 {
|
func (s *Service) createGenesisTime(timeStamp uint64) uint64 {
|
||||||
if featureconfig.Get().NoGenesisDelay {
|
if featureconfig.Get().CustomGenesisDelay == 0 {
|
||||||
return timeStamp
|
return timeStamp
|
||||||
}
|
}
|
||||||
timeStampRdDown := timeStamp - timeStamp%params.BeaconConfig().MinGenesisDelay
|
timeStampRdDown := timeStamp - timeStamp%featureconfig.Get().CustomGenesisDelay
|
||||||
// genesisTime will be set to the first second of the day, two days after it was triggered.
|
// genesisTime will be set to the first second of the day, two days after it was triggered.
|
||||||
return timeStampRdDown + 2*params.BeaconConfig().MinGenesisDelay
|
return timeStampRdDown + 2*featureconfig.Get().CustomGenesisDelay
|
||||||
}
|
}
|
||||||
|
|
||||||
// processPastLogs processes all the past logs from the deposit contract and
|
// processPastLogs processes all the past logs from the deposit contract and
|
||||||
|
@ -22,6 +22,7 @@ import (
|
|||||||
"github.com/prysmaticlabs/prysm/beacon-chain/flags"
|
"github.com/prysmaticlabs/prysm/beacon-chain/flags"
|
||||||
mockPOW "github.com/prysmaticlabs/prysm/beacon-chain/powchain/testing"
|
mockPOW "github.com/prysmaticlabs/prysm/beacon-chain/powchain/testing"
|
||||||
contracts "github.com/prysmaticlabs/prysm/contracts/deposit-contract"
|
contracts "github.com/prysmaticlabs/prysm/contracts/deposit-contract"
|
||||||
|
"github.com/prysmaticlabs/prysm/shared/featureconfig"
|
||||||
"github.com/prysmaticlabs/prysm/shared/params"
|
"github.com/prysmaticlabs/prysm/shared/params"
|
||||||
"github.com/prysmaticlabs/prysm/shared/testutil"
|
"github.com/prysmaticlabs/prysm/shared/testutil"
|
||||||
"github.com/prysmaticlabs/prysm/shared/trieutil"
|
"github.com/prysmaticlabs/prysm/shared/trieutil"
|
||||||
@ -322,6 +323,10 @@ func TestProcessETH2GenesisLog_8DuplicatePubkeys(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestProcessETH2GenesisLog(t *testing.T) {
|
func TestProcessETH2GenesisLog(t *testing.T) {
|
||||||
|
config := &featureconfig.Flags{
|
||||||
|
CustomGenesisDelay: 0,
|
||||||
|
}
|
||||||
|
featureconfig.Init(config)
|
||||||
hook := logTest.NewGlobal()
|
hook := logTest.NewGlobal()
|
||||||
testAcc, err := contracts.Setup()
|
testAcc, err := contracts.Setup()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
@ -56,7 +56,6 @@ func startNewBeaconNode(t *testing.T, config *end2EndConfig, beaconNodes []*ev.B
|
|||||||
}
|
}
|
||||||
|
|
||||||
args := []string{
|
args := []string{
|
||||||
"--no-genesis-delay",
|
|
||||||
"--force-clear-db",
|
"--force-clear-db",
|
||||||
"--no-discovery",
|
"--no-discovery",
|
||||||
"--http-web3provider=http://127.0.0.1:8745",
|
"--http-web3provider=http://127.0.0.1:8745",
|
||||||
|
@ -15,7 +15,7 @@ func TestEndToEnd_DemoConfig(t *testing.T) {
|
|||||||
params.UseDemoBeaconConfig()
|
params.UseDemoBeaconConfig()
|
||||||
|
|
||||||
demoConfig := &end2EndConfig{
|
demoConfig := &end2EndConfig{
|
||||||
beaconFlags: featureconfig.E2EBeaconChainFlags,
|
beaconFlags: append(featureconfig.E2EBeaconChainFlags, "--custom-genesis-delay=60"),
|
||||||
validatorFlags: featureconfig.E2EValidatorFlags,
|
validatorFlags: featureconfig.E2EValidatorFlags,
|
||||||
epochsToRun: 5,
|
epochsToRun: 5,
|
||||||
numBeaconNodes: 2,
|
numBeaconNodes: 2,
|
||||||
|
@ -14,7 +14,7 @@ func TestEndToEnd_MinimalConfig(t *testing.T) {
|
|||||||
params.UseMinimalConfig()
|
params.UseMinimalConfig()
|
||||||
|
|
||||||
minimalConfig := &end2EndConfig{
|
minimalConfig := &end2EndConfig{
|
||||||
beaconFlags: append(featureconfig.E2EBeaconChainFlags, "--minimal-config"),
|
beaconFlags: append(featureconfig.E2EBeaconChainFlags, "--minimal-config", "--custom-genesis-delay=15"),
|
||||||
validatorFlags: append(featureconfig.E2EValidatorFlags, "--minimal-config"),
|
validatorFlags: append(featureconfig.E2EValidatorFlags, "--minimal-config"),
|
||||||
epochsToRun: 6,
|
epochsToRun: 6,
|
||||||
numBeaconNodes: 4,
|
numBeaconNodes: 4,
|
||||||
|
@ -9,6 +9,7 @@ go_library(
|
|||||||
importpath = "github.com/prysmaticlabs/prysm/shared/featureconfig",
|
importpath = "github.com/prysmaticlabs/prysm/shared/featureconfig",
|
||||||
visibility = ["//visibility:public"],
|
visibility = ["//visibility:public"],
|
||||||
deps = [
|
deps = [
|
||||||
|
"//shared/params:go_default_library",
|
||||||
"@com_github_sirupsen_logrus//:go_default_library",
|
"@com_github_sirupsen_logrus//:go_default_library",
|
||||||
"@com_github_urfave_cli//:go_default_library",
|
"@com_github_urfave_cli//:go_default_library",
|
||||||
],
|
],
|
||||||
|
@ -19,6 +19,7 @@ The process for implementing new features using this package is as follows:
|
|||||||
package featureconfig
|
package featureconfig
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"github.com/prysmaticlabs/prysm/shared/params"
|
||||||
"github.com/sirupsen/logrus"
|
"github.com/sirupsen/logrus"
|
||||||
"github.com/urfave/cli"
|
"github.com/urfave/cli"
|
||||||
)
|
)
|
||||||
@ -27,7 +28,7 @@ var log = logrus.WithField("prefix", "flags")
|
|||||||
|
|
||||||
// Flags is a struct to represent which features the client will perform on runtime.
|
// Flags is a struct to represent which features the client will perform on runtime.
|
||||||
type Flags struct {
|
type Flags struct {
|
||||||
NoGenesisDelay bool // NoGenesisDelay signals to start the chain as quickly as possible.
|
CustomGenesisDelay uint64 // CustomGenesisDelay signals how long of a delay to set to start the chain.
|
||||||
MinimalConfig bool // MinimalConfig as defined in the spec.
|
MinimalConfig bool // MinimalConfig as defined in the spec.
|
||||||
WriteSSZStateTransitions bool // WriteSSZStateTransitions to tmp directory.
|
WriteSSZStateTransitions bool // WriteSSZStateTransitions to tmp directory.
|
||||||
InitSyncNoVerify bool // InitSyncNoVerify when initial syncing w/o verifying block's contents.
|
InitSyncNoVerify bool // InitSyncNoVerify when initial syncing w/o verifying block's contents.
|
||||||
@ -76,9 +77,10 @@ func Init(c *Flags) {
|
|||||||
func ConfigureBeaconChain(ctx *cli.Context) {
|
func ConfigureBeaconChain(ctx *cli.Context) {
|
||||||
complainOnDeprecatedFlags(ctx)
|
complainOnDeprecatedFlags(ctx)
|
||||||
cfg := &Flags{}
|
cfg := &Flags{}
|
||||||
if ctx.GlobalBool(noGenesisDelayFlag.Name) {
|
if ctx.GlobalUint64(customGenesisDelayFlag.Name) != params.BeaconConfig().MinGenesisDelay {
|
||||||
log.Warn("Starting ETH2 with no genesis delay")
|
delay := ctx.GlobalUint64(customGenesisDelayFlag.Name)
|
||||||
cfg.NoGenesisDelay = true
|
log.Warnf("Starting ETH2 with genesis delay of %d seconds", delay)
|
||||||
|
cfg.CustomGenesisDelay = delay
|
||||||
}
|
}
|
||||||
if ctx.GlobalBool(minimalConfigFlag.Name) {
|
if ctx.GlobalBool(minimalConfigFlag.Name) {
|
||||||
log.Warn("Using minimal config")
|
log.Warn("Using minimal config")
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
package featureconfig
|
package featureconfig
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"github.com/prysmaticlabs/prysm/shared/params"
|
||||||
"github.com/urfave/cli"
|
"github.com/urfave/cli"
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -68,11 +69,11 @@ var (
|
|||||||
Usage: "Enables connection to a slasher service in order to retrieve slashable events. Slasher is connected to the beacon node using gRPC and " +
|
Usage: "Enables connection to a slasher service in order to retrieve slashable events. Slasher is connected to the beacon node using gRPC and " +
|
||||||
"the slasher-provider flag can be used to pass its address.",
|
"the slasher-provider flag can be used to pass its address.",
|
||||||
}
|
}
|
||||||
noGenesisDelayFlag = cli.BoolFlag{
|
customGenesisDelayFlag = cli.Uint64Flag{
|
||||||
Name: "no-genesis-delay",
|
Name: "custom-genesis-delay",
|
||||||
Usage: "Start the genesis event right away using the eth1 block timestamp which " +
|
Usage: "Start the genesis event with the configured genesis delay in seconds. " +
|
||||||
"triggered the genesis as the genesis time. This flag should be used for local " +
|
"This flag should be used for local development and testing only.",
|
||||||
"development and testing only.",
|
Value: params.BeaconConfig().MinGenesisDelay,
|
||||||
}
|
}
|
||||||
cacheFilteredBlockTreeFlag = cli.BoolFlag{
|
cacheFilteredBlockTreeFlag = cli.BoolFlag{
|
||||||
Name: "cache-filtered-block-tree",
|
Name: "cache-filtered-block-tree",
|
||||||
@ -220,7 +221,7 @@ var E2EValidatorFlags = []string{
|
|||||||
|
|
||||||
// BeaconChainFlags contains a list of all the feature flags that apply to the beacon-chain client.
|
// BeaconChainFlags contains a list of all the feature flags that apply to the beacon-chain client.
|
||||||
var BeaconChainFlags = append(deprecatedFlags, []cli.Flag{
|
var BeaconChainFlags = append(deprecatedFlags, []cli.Flag{
|
||||||
noGenesisDelayFlag,
|
customGenesisDelayFlag,
|
||||||
minimalConfigFlag,
|
minimalConfigFlag,
|
||||||
writeSSZStateTransitionsFlag,
|
writeSSZStateTransitionsFlag,
|
||||||
disableForkChoiceUnsafeFlag,
|
disableForkChoiceUnsafeFlag,
|
||||||
|
@ -10,7 +10,7 @@ import (
|
|||||||
)
|
)
|
||||||
|
|
||||||
func TestAttestationHistory_InitializesNewPubKeys(t *testing.T) {
|
func TestAttestationHistory_InitializesNewPubKeys(t *testing.T) {
|
||||||
pubkeys := [][48]byte{[48]byte{30}, [48]byte{25}, [48]byte{20}}
|
pubkeys := [][48]byte{{30}, {25}, {20}}
|
||||||
db := SetupDB(t, pubkeys)
|
db := SetupDB(t, pubkeys)
|
||||||
defer TeardownDB(t, db)
|
defer TeardownDB(t, db)
|
||||||
|
|
||||||
|
@ -11,7 +11,7 @@ import (
|
|||||||
)
|
)
|
||||||
|
|
||||||
func TestProposalHistory_InitializesNewPubKeys(t *testing.T) {
|
func TestProposalHistory_InitializesNewPubKeys(t *testing.T) {
|
||||||
pubkeys := [][48]byte{[48]byte{30}, [48]byte{25}, [48]byte{20}}
|
pubkeys := [][48]byte{{30}, {25}, {20}}
|
||||||
db := SetupDB(t, pubkeys)
|
db := SetupDB(t, pubkeys)
|
||||||
defer TeardownDB(t, db)
|
defer TeardownDB(t, db)
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user