lotus/cmd/chain-noise/main.go

112 lines
2.2 KiB
Go
Raw Permalink Normal View History

package main
import (
"context"
"fmt"
"math/rand"
"os"
"time"
"github.com/filecoin-project/go-address"
2021-04-05 19:34:03 +00:00
"github.com/filecoin-project/lotus/api/v0api"
2020-07-10 14:43:14 +00:00
"github.com/filecoin-project/lotus/build"
"github.com/filecoin-project/lotus/chain/types"
lcli "github.com/filecoin-project/lotus/cli"
"github.com/urfave/cli/v2"
)
func main() {
app := &cli.App{
Name: "chain-noise",
Usage: "Generate some spam transactions in the network",
Flags: []cli.Flag{
&cli.StringFlag{
Name: "repo",
EnvVars: []string{"LOTUS_PATH"},
Hidden: true,
Value: "~/.lotus", // TODO: Consider XDG_DATA_HOME
},
2020-12-18 11:35:11 +00:00
&cli.IntFlag{
2021-01-06 03:30:51 +00:00
Name: "limit",
Usage: "spam transaction count limit, <= 0 is no limit",
Value: 0,
2020-12-18 11:35:11 +00:00
},
&cli.IntFlag{
2021-01-06 03:30:51 +00:00
Name: "rate",
Usage: "spam transaction rate, count per second",
Value: 5,
2020-12-18 11:35:11 +00:00
},
},
Commands: []*cli.Command{runCmd},
}
if err := app.Run(os.Args); err != nil {
fmt.Println("Error: ", err)
os.Exit(1)
}
}
var runCmd = &cli.Command{
Name: "run",
Action: func(cctx *cli.Context) error {
addr, err := address.NewFromString(cctx.Args().First())
if err != nil {
return err
}
api, closer, err := lcli.GetFullNodeAPI(cctx)
if err != nil {
return err
}
defer closer()
ctx := lcli.ReqContext(cctx)
2020-12-18 11:35:11 +00:00
rate := cctx.Int("rate")
if rate <= 0 {
rate = 5
}
limit := cctx.Int("limit")
return sendSmallFundsTxs(ctx, api, addr, rate, limit)
},
}
2021-04-05 19:34:03 +00:00
func sendSmallFundsTxs(ctx context.Context, api v0api.FullNode, from address.Address, rate, limit int) error {
var sendSet []address.Address
for i := 0; i < 20; i++ {
naddr, err := api.WalletNew(ctx, types.KTSecp256k1)
if err != nil {
return err
}
sendSet = append(sendSet, naddr)
}
2020-12-18 11:35:11 +00:00
count := limit
2020-07-10 14:43:14 +00:00
tick := build.Clock.Ticker(time.Second / time.Duration(rate))
for {
2020-12-18 11:35:11 +00:00
if count <= 0 && limit > 0 {
fmt.Printf("%d messages sent.\n", limit)
return nil
}
select {
case <-tick.C:
msg := &types.Message{
From: from,
To: sendSet[rand.Intn(20)],
Value: types.NewInt(1),
}
smsg, err := api.MpoolPushMessage(ctx, msg, nil)
if err != nil {
return err
}
2020-12-18 11:35:11 +00:00
count--
fmt.Println("Message sent: ", smsg.Cid())
case <-ctx.Done():
return nil
}
}
}