Improve MineBlocksMustPost use it in PaychAPI itest
This commit is contained in:
parent
3b5b55de19
commit
2c06eb76d6
@ -10,6 +10,7 @@ import (
|
|||||||
|
|
||||||
"github.com/filecoin-project/go-bitfield"
|
"github.com/filecoin-project/go-bitfield"
|
||||||
"github.com/filecoin-project/go-state-types/abi"
|
"github.com/filecoin-project/go-state-types/abi"
|
||||||
|
"github.com/filecoin-project/go-state-types/dline"
|
||||||
"github.com/filecoin-project/lotus/api"
|
"github.com/filecoin-project/lotus/api"
|
||||||
aminer "github.com/filecoin-project/lotus/chain/actors/builtin/miner"
|
aminer "github.com/filecoin-project/lotus/chain/actors/builtin/miner"
|
||||||
"github.com/filecoin-project/lotus/chain/types"
|
"github.com/filecoin-project/lotus/chain/types"
|
||||||
@ -82,50 +83,12 @@ func (p *partitionTracker) recordIfPost(t *testing.T, bm *BlockMiner, smsg *type
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
// Like MineBlocks but refuses to mine until the window post scheduler has wdpost messages in the mempool
|
func (bm *BlockMiner) forcePoSt(ctx context.Context, ts *types.TipSet, dlinfo *dline.Info) {
|
||||||
// and everything shuts down if a post fails. It also enforces that every block mined succeeds
|
|
||||||
func (bm *BlockMiner) MineBlocksMustPost(ctx context.Context, blocktime time.Duration) {
|
|
||||||
|
|
||||||
time.Sleep(3 * time.Second)
|
|
||||||
|
|
||||||
// wrap context in a cancellable context.
|
|
||||||
ctx, bm.cancel = context.WithCancel(ctx)
|
|
||||||
bm.wg.Add(1)
|
|
||||||
go func() {
|
|
||||||
defer bm.wg.Done()
|
|
||||||
|
|
||||||
activeDeadlines := make(map[int]struct{})
|
|
||||||
_ = activeDeadlines
|
|
||||||
ts, err := bm.miner.FullNode.ChainHead(ctx)
|
|
||||||
require.NoError(bm.t, err)
|
|
||||||
wait := make(chan bool)
|
|
||||||
chg, err := bm.miner.FullNode.ChainNotify(ctx)
|
|
||||||
require.NoError(bm.t, err)
|
|
||||||
// read current out
|
|
||||||
curr := <-chg
|
|
||||||
require.Equal(bm.t, ts.Height(), curr[0].Val.Height())
|
|
||||||
for {
|
|
||||||
select {
|
|
||||||
case <-time.After(blocktime):
|
|
||||||
case <-ctx.Done():
|
|
||||||
return
|
|
||||||
}
|
|
||||||
nulls := atomic.SwapInt64(&bm.nextNulls, 0)
|
|
||||||
require.Equal(bm.t, int64(0), nulls, "Injecting > 0 null blocks while `MustPost` mining is currently unsupported")
|
|
||||||
|
|
||||||
// Wake up and figure out if we are at the end of an active deadline
|
|
||||||
ts, err := bm.miner.FullNode.ChainHead(ctx)
|
|
||||||
require.NoError(bm.t, err)
|
|
||||||
tsk := ts.Key()
|
|
||||||
|
|
||||||
dlinfo, err := bm.miner.FullNode.StateMinerProvingDeadline(ctx, bm.miner.ActorAddr, tsk)
|
|
||||||
require.NoError(bm.t, err)
|
|
||||||
if ts.Height()+1 == dlinfo.Last() { // Last epoch in dline, we need to check that miner has posted
|
|
||||||
|
|
||||||
tracker := newPartitionTracker(ctx, dlinfo.Index, bm)
|
tracker := newPartitionTracker(ctx, dlinfo.Index, bm)
|
||||||
if !tracker.done(bm.t) { // need to wait for post
|
if !tracker.done(bm.t) { // need to wait for post
|
||||||
bm.t.Logf("expect %d partitions proved but only see %d", len(tracker.partitions), tracker.count(bm.t))
|
bm.t.Logf("expect %d partitions proved but only see %d", len(tracker.partitions), tracker.count(bm.t))
|
||||||
poolEvts, err := bm.miner.FullNode.MpoolSub(ctx)
|
poolEvts, err := bm.miner.FullNode.MpoolSub(ctx) //subscribe before checking pending so we don't miss any events
|
||||||
require.NoError(bm.t, err)
|
require.NoError(bm.t, err)
|
||||||
|
|
||||||
// First check pending messages we'll mine this epoch
|
// First check pending messages we'll mine this epoch
|
||||||
@ -159,6 +122,43 @@ func (bm *BlockMiner) MineBlocksMustPost(ctx context.Context, blocktime time.Dur
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Like MineBlocks but refuses to mine until the window post scheduler has wdpost messages in the mempool
|
||||||
|
// and everything shuts down if a post fails. It also enforces that every block mined succeeds
|
||||||
|
func (bm *BlockMiner) MineBlocksMustPost(ctx context.Context, blocktime time.Duration) {
|
||||||
|
time.Sleep(time.Second)
|
||||||
|
|
||||||
|
// wrap context in a cancellable context.
|
||||||
|
ctx, bm.cancel = context.WithCancel(ctx)
|
||||||
|
bm.wg.Add(1)
|
||||||
|
go func() {
|
||||||
|
defer bm.wg.Done()
|
||||||
|
|
||||||
|
ts, err := bm.miner.FullNode.ChainHead(ctx)
|
||||||
|
require.NoError(bm.t, err)
|
||||||
|
wait := make(chan bool)
|
||||||
|
chg, err := bm.miner.FullNode.ChainNotify(ctx)
|
||||||
|
require.NoError(bm.t, err)
|
||||||
|
// read current out
|
||||||
|
curr := <-chg
|
||||||
|
require.Equal(bm.t, ts.Height(), curr[0].Val.Height(), "failed sanity check: are multiple miners mining with must post?")
|
||||||
|
for {
|
||||||
|
select {
|
||||||
|
case <-time.After(blocktime):
|
||||||
|
case <-ctx.Done():
|
||||||
|
return
|
||||||
|
}
|
||||||
|
nulls := atomic.SwapInt64(&bm.nextNulls, 0)
|
||||||
|
|
||||||
|
// Wake up and figure out if we are at the end of an active deadline
|
||||||
|
ts, err := bm.miner.FullNode.ChainHead(ctx)
|
||||||
|
require.NoError(bm.t, err)
|
||||||
|
|
||||||
|
dlinfo, err := bm.miner.FullNode.StateMinerProvingDeadline(ctx, bm.miner.ActorAddr, ts.Key())
|
||||||
|
require.NoError(bm.t, err)
|
||||||
|
if ts.Height()+1+abi.ChainEpoch(nulls) >= dlinfo.Last() { // Next block brings us past the last epoch in dline, we need to wait for miner to post
|
||||||
|
bm.forcePoSt(ctx, ts, dlinfo)
|
||||||
|
}
|
||||||
|
|
||||||
var target abi.ChainEpoch
|
var target abi.ChainEpoch
|
||||||
reportSuccessFn := func(success bool, epoch abi.ChainEpoch, err error) {
|
reportSuccessFn := func(success bool, epoch abi.ChainEpoch, err error) {
|
||||||
require.NoError(bm.t, err)
|
require.NoError(bm.t, err)
|
||||||
@ -173,6 +173,12 @@ func (bm *BlockMiner) MineBlocksMustPost(ctx context.Context, blocktime time.Dur
|
|||||||
Done: reportSuccessFn,
|
Done: reportSuccessFn,
|
||||||
})
|
})
|
||||||
success = <-wait
|
success = <-wait
|
||||||
|
if !success {
|
||||||
|
// if we are mining a new null block and it brings us past deadline boundary we need to wait for miner to post
|
||||||
|
if ts.Height()+1+abi.ChainEpoch(nulls+i) >= dlinfo.Last() {
|
||||||
|
bm.forcePoSt(ctx, ts, dlinfo)
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Wait until it shows up on the given full nodes ChainHead
|
// Wait until it shows up on the given full nodes ChainHead
|
||||||
|
@ -51,7 +51,7 @@ func TestPaymentChannelsAPI(t *testing.T) {
|
|||||||
Miner(&miner, &paymentCreator, kit.WithAllSubsystems()).
|
Miner(&miner, &paymentCreator, kit.WithAllSubsystems()).
|
||||||
Start().
|
Start().
|
||||||
InterconnectAll()
|
InterconnectAll()
|
||||||
bms := ens.BeginMining(blockTime)
|
bms := ens.BeginMiningMustPost(blockTime)
|
||||||
bm := bms[0]
|
bm := bms[0]
|
||||||
|
|
||||||
// send some funds to register the receiver
|
// send some funds to register the receiver
|
||||||
|
Loading…
Reference in New Issue
Block a user