2021-06-18 18:45:29 +00:00
|
|
|
package kit
|
2021-06-11 17:26:25 +00:00
|
|
|
|
|
|
|
import (
|
|
|
|
"github.com/filecoin-project/go-state-types/abi"
|
|
|
|
"github.com/filecoin-project/go-state-types/big"
|
|
|
|
"github.com/filecoin-project/lotus/build"
|
|
|
|
"github.com/filecoin-project/lotus/chain/types"
|
|
|
|
"github.com/filecoin-project/lotus/chain/wallet"
|
|
|
|
"github.com/filecoin-project/lotus/node"
|
|
|
|
)
|
|
|
|
|
|
|
|
// DefaultPresealsPerBootstrapMiner is the number of preseals that every
|
|
|
|
// bootstrap miner has by default. It can be overridden through the
|
|
|
|
// PresealSectors option.
|
|
|
|
const DefaultPresealsPerBootstrapMiner = 2
|
|
|
|
|
2021-06-17 12:58:35 +00:00
|
|
|
const TestSpt = abi.RegisteredSealProof_StackedDrg2KiBV1_1
|
|
|
|
|
2021-06-11 17:26:25 +00:00
|
|
|
// nodeOpts is an options accumulating struct, where functional options are
|
|
|
|
// merged into.
|
|
|
|
type nodeOpts struct {
|
|
|
|
balance abi.TokenAmount
|
|
|
|
lite bool
|
|
|
|
sectors int
|
|
|
|
rpc bool
|
|
|
|
ownerKey *wallet.Key
|
|
|
|
extraNodeOpts []node.Option
|
2021-06-18 16:40:33 +00:00
|
|
|
|
2021-06-22 09:28:23 +00:00
|
|
|
subsystems MinerSubsystem
|
|
|
|
mainMiner *TestMiner
|
|
|
|
optBuilders []OptBuilder
|
|
|
|
proofType abi.RegisteredSealProof
|
2021-06-11 17:26:25 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// DefaultNodeOpts are the default options that will be applied to test nodes.
|
|
|
|
var DefaultNodeOpts = nodeOpts{
|
2021-06-21 12:24:25 +00:00
|
|
|
balance: big.Mul(big.NewInt(100000000), types.NewInt(build.FilecoinPrecision)),
|
|
|
|
sectors: DefaultPresealsPerBootstrapMiner,
|
|
|
|
proofType: abi.RegisteredSealProof_StackedDrg2KiBV1_1, // default _concrete_ proof type for non-genesis miners (notice the _1) for new actors versions.
|
2021-06-11 17:26:25 +00:00
|
|
|
}
|
|
|
|
|
2021-06-15 09:46:32 +00:00
|
|
|
// OptBuilder is used to create an option after some other node is already
|
|
|
|
// active. Takes all active nodes as a parameter.
|
|
|
|
type OptBuilder func(activeNodes []*TestFullNode) node.Option
|
|
|
|
|
2021-06-11 17:26:25 +00:00
|
|
|
// NodeOpt is a functional option for test nodes.
|
|
|
|
type NodeOpt func(opts *nodeOpts) error
|
|
|
|
|
2021-06-18 16:40:33 +00:00
|
|
|
func WithAllSubsystems() NodeOpt {
|
|
|
|
return func(opts *nodeOpts) error {
|
|
|
|
opts.subsystems = opts.subsystems.Add(SStorageMarket)
|
|
|
|
opts.subsystems = opts.subsystems.Add(SMining)
|
|
|
|
opts.subsystems = opts.subsystems.Add(SSealing)
|
|
|
|
opts.subsystems = opts.subsystems.Add(SSectorStorage)
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func WithSubsystem(single MinerSubsystem) NodeOpt {
|
|
|
|
return func(opts *nodeOpts) error {
|
|
|
|
opts.subsystems = opts.subsystems.Add(single)
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func MainMiner(m *TestMiner) NodeOpt {
|
|
|
|
return func(opts *nodeOpts) error {
|
|
|
|
opts.mainMiner = m
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-06-11 17:26:25 +00:00
|
|
|
// OwnerBalance specifies the balance to be attributed to a miner's owner
|
|
|
|
// account. Only relevant when creating a miner.
|
|
|
|
func OwnerBalance(balance abi.TokenAmount) NodeOpt {
|
|
|
|
return func(opts *nodeOpts) error {
|
|
|
|
opts.balance = balance
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// LiteNode specifies that this node will be a lite node. Only relevant when
|
|
|
|
// creating a fullnode.
|
|
|
|
func LiteNode() NodeOpt {
|
|
|
|
return func(opts *nodeOpts) error {
|
|
|
|
opts.lite = true
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// PresealSectors specifies the amount of preseal sectors to give to a miner
|
|
|
|
// at genesis. Only relevant when creating a miner.
|
|
|
|
func PresealSectors(sectors int) NodeOpt {
|
|
|
|
return func(opts *nodeOpts) error {
|
|
|
|
opts.sectors = sectors
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// ThroughRPC makes interactions with this node throughout the test flow through
|
|
|
|
// the JSON-RPC API.
|
|
|
|
func ThroughRPC() NodeOpt {
|
|
|
|
return func(opts *nodeOpts) error {
|
|
|
|
opts.rpc = true
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// OwnerAddr sets the owner address of a miner. Only relevant when creating
|
|
|
|
// a miner.
|
|
|
|
func OwnerAddr(wk *wallet.Key) NodeOpt {
|
|
|
|
return func(opts *nodeOpts) error {
|
|
|
|
opts.ownerKey = wk
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// ConstructorOpts are Lotus node constructor options that are passed as-is to
|
|
|
|
// the node.
|
|
|
|
func ConstructorOpts(extra ...node.Option) NodeOpt {
|
|
|
|
return func(opts *nodeOpts) error {
|
|
|
|
opts.extraNodeOpts = extra
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
}
|
2021-06-15 09:46:32 +00:00
|
|
|
|
2021-06-21 12:24:25 +00:00
|
|
|
// ProofType sets the proof type for this node. If you're using new actor
|
|
|
|
// versions, this should be a _1 proof type.
|
|
|
|
func ProofType(proofType abi.RegisteredSealProof) NodeOpt {
|
2021-06-15 09:46:32 +00:00
|
|
|
return func(opts *nodeOpts) error {
|
2021-06-21 12:24:25 +00:00
|
|
|
opts.proofType = proofType
|
2021-06-15 09:46:32 +00:00
|
|
|
return nil
|
|
|
|
}
|
|
|
|
}
|