erigon-pulse/cmd/integration/commands/root.go

72 lines
1.8 KiB
Go
Raw Normal View History

2020-07-14 01:56:29 +00:00
package commands
import (
"path/filepath"
"github.com/c2h5oh/datasize"
2021-07-29 11:53:13 +00:00
"github.com/ledgerwatch/erigon-lib/kv"
kv2 "github.com/ledgerwatch/erigon-lib/kv/mdbx"
"github.com/ledgerwatch/erigon/cmd/utils"
"github.com/ledgerwatch/erigon/internal/debug"
"github.com/ledgerwatch/erigon/migrations"
2021-07-29 10:23:23 +00:00
"github.com/ledgerwatch/log/v3"
2020-07-14 01:56:29 +00:00
"github.com/spf13/cobra"
)
var rootCmd = &cobra.Command{
Use: "integration",
Short: "long and heavy integration tests for Erigon",
2020-07-14 01:56:29 +00:00
PersistentPreRun: func(cmd *cobra.Command, args []string) {
2020-08-20 03:52:27 +00:00
if err := utils.SetupCobra(cmd); err != nil {
panic(err)
}
if chaindata == "" {
2022-06-07 04:00:37 +00:00
chaindata = filepath.Join(datadirCli, "chaindata")
}
2020-07-14 01:56:29 +00:00
},
2020-08-20 03:52:27 +00:00
PersistentPostRun: func(cmd *cobra.Command, args []string) {
defer utils.StopDebug()
},
2020-07-14 01:56:29 +00:00
}
func RootCommand() *cobra.Command {
utils.CobraFlags(rootCmd, append(debug.Flags, utils.MetricFlags...))
return rootCmd
2020-07-14 01:56:29 +00:00
}
func openDB(path string, logger log.Logger, applyMigrations bool) kv.RwDB {
label := kv.ChainDB
db := openKV(label, logger, path, false)
if applyMigrations {
has, err := migrations.NewMigrator(label).HasPendingMigrations(db)
if err != nil {
panic(err)
}
if has {
log.Info("Re-Opening DB in exclusive mode to apply DB migrations")
db.Close()
db = openKV(label, logger, path, true)
2022-06-07 04:00:37 +00:00
if err := migrations.NewMigrator(label).Apply(db, datadirCli); err != nil {
panic(err)
}
db.Close()
db = openKV(label, logger, path, false)
}
}
return db
}
func openKV(label kv.Label, logger log.Logger, path string, exclusive bool) kv.RwDB {
opts := kv2.NewMDBX(logger).Path(path).Label(label)
if label == kv.ChainDB {
opts = opts.MapSize(8 * datasize.TB)
}
if exclusive {
opts = opts.Exclusive()
}
if databaseVerbosity != -1 {
opts = opts.DBVerbosity(kv.DBVerbosityLvl(databaseVerbosity))
}
return opts.MustOpen()
}