mirror of
https://github.com/kaspanet/kaspad.git
synced 2025-03-30 15:08:33 +00:00

* Add stability-tests * Fix requires * Fix golint errors * Update README.md * Remove payloadHash from everywhere * don't run vet on kaspad in stability-tests/install_and_test
62 lines
1.3 KiB
Go
62 lines
1.3 KiB
Go
package main
|
|
|
|
import (
|
|
"fmt"
|
|
"os"
|
|
"time"
|
|
|
|
"github.com/pkg/errors"
|
|
|
|
"github.com/kaspanet/kaspad/stability-tests/common"
|
|
"github.com/kaspanet/kaspad/stability-tests/common/rpc"
|
|
"github.com/kaspanet/kaspad/util/profiling"
|
|
)
|
|
|
|
var timeout = 30 * time.Second
|
|
|
|
func main() {
|
|
err := parseConfig()
|
|
if err != nil {
|
|
fmt.Fprintf(os.Stderr, "Error parsing config: %+v", err)
|
|
os.Exit(1)
|
|
}
|
|
defer backendLog.Close()
|
|
common.UseLogger(backendLog, log.Level())
|
|
cfg := activeConfig()
|
|
if cfg.Profile != "" {
|
|
profiling.Start(cfg.Profile, log)
|
|
}
|
|
|
|
blocks, topBlock, err := prepareBlocks()
|
|
if err != nil {
|
|
log.Errorf("Error preparing blocks: %+v", err)
|
|
backendLog.Close()
|
|
os.Exit(1)
|
|
}
|
|
|
|
routes := connectToNode()
|
|
|
|
rpcClient, err := rpc.ConnectToRPC(&cfg.Config, cfg.NetParams())
|
|
if err != nil {
|
|
panic(errors.Wrap(err, "error connecting to JSON-RPC server"))
|
|
}
|
|
|
|
defer rpcClient.Disconnect()
|
|
err = sendBlocks(routes, blocks, topBlock)
|
|
if err != nil {
|
|
backendLog.Close()
|
|
log.Errorf("Error sending blocks: %+v", err)
|
|
os.Exit(1)
|
|
}
|
|
|
|
// Wait a second to let kaspad process orphans
|
|
<-time.After(1 * time.Second)
|
|
|
|
err = checkTopBlockIsTip(rpcClient, topBlock)
|
|
if err != nil {
|
|
log.Errorf("Error in checkTopBlockIsTip: %+v", err)
|
|
backendLog.Close()
|
|
os.Exit(1)
|
|
}
|
|
}
|