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

104 lines
2.7 KiB
Go
Raw Normal View History

2020-07-14 01:56:29 +00:00
package commands
import (
"path"
"github.com/c2h5oh/datasize"
2020-07-14 01:56:29 +00:00
"github.com/ledgerwatch/turbo-geth/cmd/utils"
"github.com/ledgerwatch/turbo-geth/ethdb"
2020-07-14 01:56:29 +00:00
"github.com/ledgerwatch/turbo-geth/internal/debug"
"github.com/ledgerwatch/turbo-geth/log"
"github.com/ledgerwatch/turbo-geth/metrics"
"github.com/ledgerwatch/turbo-geth/migrations"
2021-03-23 09:00:07 +00:00
"github.com/ledgerwatch/turbo-geth/turbo/snapshotsync"
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 turbo-geth",
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 == "" {
chaindata = path.Join(datadir, "tg", "chaindata")
}
if snapshotDir == "" {
snapshotDir = path.Join(datadir, "tg", "snapshot")
}
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
}
2021-03-23 09:00:07 +00:00
func openDatabase2(path string, applyMigrations bool, snapshotDir string, snapshotMode snapshotsync.SnapshotMode) *ethdb.ObjectDatabase {
db := ethdb.NewObjectDatabase(openKV(path, false))
if applyMigrations {
has, err := migrations.NewMigrator().HasPendingMigrations(db)
if err != nil {
panic(err)
}
if has {
log.Info("Re-Opening DB in exclusive mode to apply DB migrations")
db.Close()
db = ethdb.NewObjectDatabase(openKV(path, true))
if err := migrations.NewMigrator().Apply(db, datadir); err != nil {
panic(err)
}
db.Close()
db = ethdb.NewObjectDatabase(openKV(path, false))
}
}
2021-03-30 09:53:54 +00:00
metrics.AddCallback(db.RwKV().CollectMetrics)
return db
}
2021-03-23 09:00:07 +00:00
func openDatabase(path string, applyMigrations bool) *ethdb.ObjectDatabase {
mode, err := snapshotsync.SnapshotModeFromString(snapshotMode)
if err != nil {
panic(err)
}
return openDatabase2(path, applyMigrations, snapshotDir, mode)
}
2021-03-30 09:53:54 +00:00
func openKV(path string, exclusive bool) ethdb.RwKV {
2020-10-28 03:18:10 +00:00
if database == "mdbx" {
opts := ethdb.NewMDBX().Path(path)
if exclusive {
opts = opts.Exclusive()
2020-10-28 03:18:10 +00:00
}
if mapSizeStr != "" {
var mapSize datasize.ByteSize
must(mapSize.UnmarshalText([]byte(mapSizeStr)))
opts = opts.MapSize(mapSize)
}
if databaseVerbosity != -1 {
opts = opts.DBVerbosity(ethdb.DBVerbosityLvl(databaseVerbosity))
}
return opts.MustOpen()
}
2020-10-28 03:18:10 +00:00
opts := ethdb.NewLMDB().Path(path)
if exclusive {
opts = opts.Exclusive()
}
if mapSizeStr != "" {
var mapSize datasize.ByteSize
must(mapSize.UnmarshalText([]byte(mapSizeStr)))
opts = opts.MapSize(mapSize)
2020-10-28 03:18:10 +00:00
}
if databaseVerbosity != -1 {
opts = opts.DBVerbosity(ethdb.DBVerbosityLvl(databaseVerbosity))
}
kv := opts.MustOpen()
metrics.AddCallback(kv.CollectMetrics)
return kv
}