gecko/xputtest/main.go

98 lines
2.3 KiB
Go
Raw Normal View History

2020-03-10 12:20:34 -07:00
// (c) 2019-2020, Ava Labs, Inc. All rights reserved.
// See the file LICENSE for licensing terms.
package main
import (
"fmt"
"os"
"path"
"runtime"
"runtime/pprof"
"github.com/ava-labs/salticidae-go"
"github.com/ava-labs/gecko/genesis"
"github.com/ava-labs/gecko/ids"
"github.com/ava-labs/gecko/utils/crypto"
"github.com/ava-labs/gecko/utils/logging"
2020-03-17 13:07:33 -07:00
"github.com/ava-labs/gecko/vms/avm"
"github.com/ava-labs/gecko/vms/spchainvm"
"github.com/ava-labs/gecko/vms/spdagvm"
2020-03-10 12:20:34 -07:00
)
func main() {
if err != nil {
fmt.Printf("Failed to parse arguments: %s\n", err)
}
2020-03-17 13:07:33 -07:00
// set up logging
2020-03-10 12:20:34 -07:00
config.LoggingConfig.Directory = path.Join(config.LoggingConfig.Directory, "client")
log, err := logging.New(config.LoggingConfig)
if err != nil {
fmt.Printf("Failed to start the logger: %s\n", err)
return
}
defer log.Stop()
2020-03-17 13:07:33 -07:00
// initialize state based on CLI args
net.log = log
2020-03-10 12:20:34 -07:00
crypto.EnableCrypto = config.EnableCrypto
net.decided = make(chan ids.ID, config.MaxOutstandingTxs)
2020-03-10 12:20:34 -07:00
2020-03-17 13:07:33 -07:00
// Init the network
log.AssertNoError(net.Initialize())
2020-03-10 12:20:34 -07:00
net.net.Start()
defer net.net.Stop()
2020-03-10 12:20:34 -07:00
2020-03-17 13:07:33 -07:00
// connect to the node
serr := salticidae.NewError()
2020-03-10 12:20:34 -07:00
remoteIP := salticidae.NewNetAddrFromIPPortString(config.RemoteIP.String(), true, &serr)
if code := serr.GetCode(); code != 0 {
log.Fatal("Sync error %s", salticidae.StrError(serr.GetCode()))
return
}
net.conn = net.net.ConnectSync(remoteIP, true, &serr)
2020-03-10 12:20:34 -07:00
if serr.GetCode() != 0 {
log.Fatal("Sync error %s", salticidae.StrError(serr.GetCode()))
return
}
2020-03-17 13:07:33 -07:00
// start a cpu profile
2020-03-10 12:20:34 -07:00
file, gErr := os.Create("cpu_client.profile")
log.AssertNoError(gErr)
gErr = pprof.StartCPUProfile(file)
log.AssertNoError(gErr)
runtime.SetMutexProfileFraction(1)
defer file.Close()
defer pprof.StopCPUProfile()
net.networkID = config.NetworkID
2020-03-17 13:07:33 -07:00
// start the benchmark we want to run
2020-03-10 12:20:34 -07:00
switch config.Chain {
case spChain:
2020-04-02 20:43:02 -07:00
tx, err := genesis.VMGenesis(config.NetworkID, spchainvm.ID)
log.AssertNoError(err)
net.benchmarkSPChain(tx)
case spDAG:
2020-04-02 20:43:02 -07:00
tx, err := genesis.VMGenesis(config.NetworkID, spdagvm.ID)
log.AssertNoError(err)
net.benchmarkSPChain(tx)
case avmDAG:
2020-04-02 20:43:02 -07:00
tx, err := genesis.VMGenesis(config.NetworkID, avm.ID)
log.AssertNoError(err)
net.benchmarkSPChain(tx)
2020-03-10 12:20:34 -07:00
default:
log.Fatal("did not specify whether to test dag or chain. Exiting")
2020-03-10 12:20:34 -07:00
return
}
2020-03-17 13:07:33 -07:00
// start processing network messages
net.ec.Dispatch()
2020-03-10 12:20:34 -07:00
}