9e03fcab83
* Initial work supporting DDO pieces in lotus-miner * sealing: Update pipeline input to operate on UniversalPiece * sealing: Update pipeline checks/sealing states to operate on UniversalPiece * sealing: Make pipeline build with UniversalPiece * move PieceDealInfo out of api * make gen * make sealing pipeline unit tests pass * fix itest ensemble build * don't panic in SectorsStatus with deals * stop linter from complaining about checkPieces * fix sector import tests * mod tidy * sealing: Add logic for (pre)committing DDO sectors * sealing: state-types with method defs * DDO non-snap pipeline works(?), DDO Itests * DDO support in snapdeals pipeline * make gen * update actor bundles * update the gst market fix * fix: chain: use PreCommitSectorsBatch2 when setting up genesis * some bug fixes * integration working changes * update actor bundles * Make TestOnboardRawPieceSnap pass * Appease the linter * Make deadlines test pass with v12 actors * Update go-state-types, abstract market DealState * make gen * mod tidy, lint fixes * Fix some more tests * Bump version in master Bump version in master * Make gen Make gen * fix sender * fix: lotus-provider: Fix winning PoSt * fix: sql Scan cannot write to an object * Actually show miner-addrs in info-log Actually show miner-addrs in lotus-provider info-log * [WIP] feat: Add nv22 skeleton Addition of Network Version 22 skeleton * update FFI * ddo is now nv22 * make gen * temp actor bundle with ddo * use working go-state-types * gst with v13 market migration * update bundle, builtin.MethodsMiner.ProveCommitSectors2 -> 3 * actually working v13 migration, v13 migration itest * Address review * sealing: Correct DDO snap pledge math * itests: Mixed ddo itest * pipeline: Fix sectorWeight * sealing: convert market deals into PAMs in mixed sectors * sealing: make market to ddo conversion work * fix lint * update gst * Update actors and GST to lastest integ branch * commit batcher: Update ProveCommitSectors3Params builder logic * make gen * use builtin-actors master * ddo: address review * itests: Add commd assertions to ddo tests * make gen * gst with fixed types * config knobs for RequireActivationSuccess * storage: Drop obsolete flaky tasts --------- Co-authored-by: Jennifer Wang <jiayingw703@gmail.com> Co-authored-by: Aayush <arajasek94@gmail.com> Co-authored-by: Shrenuj Bansal <shrenuj.bansal@protocol.ai> Co-authored-by: Phi <orjan.roren@gmail.com> Co-authored-by: Andrew Jackson (Ajax) <snadrus@gmail.com> Co-authored-by: TippyFlits <james.bluett@protocol.ai>
111 lines
3.2 KiB
Go
111 lines
3.2 KiB
Go
// stm: #unit
|
|
package sealing_test
|
|
|
|
import (
|
|
"bytes"
|
|
"context"
|
|
"testing"
|
|
|
|
"github.com/golang/mock/gomock"
|
|
"github.com/ipfs/go-cid"
|
|
mh "github.com/multiformats/go-multihash"
|
|
"github.com/stretchr/testify/require"
|
|
|
|
"github.com/filecoin-project/go-state-types/abi"
|
|
"github.com/filecoin-project/go-state-types/cbor"
|
|
"github.com/filecoin-project/go-state-types/exitcode"
|
|
"github.com/filecoin-project/go-state-types/network"
|
|
"github.com/filecoin-project/go-statemachine"
|
|
market0 "github.com/filecoin-project/specs-actors/actors/builtin/market"
|
|
|
|
api2 "github.com/filecoin-project/lotus/api"
|
|
"github.com/filecoin-project/lotus/chain/actors/builtin/market"
|
|
"github.com/filecoin-project/lotus/chain/types"
|
|
pipeline "github.com/filecoin-project/lotus/storage/pipeline"
|
|
"github.com/filecoin-project/lotus/storage/pipeline/mocks"
|
|
"github.com/filecoin-project/lotus/storage/pipeline/piece"
|
|
)
|
|
|
|
func TestStateRecoverDealIDs(t *testing.T) {
|
|
t.Skip("Bring this back when we can correctly mock a state machine context: Issue #7867")
|
|
mockCtrl := gomock.NewController(t)
|
|
defer mockCtrl.Finish()
|
|
|
|
ctx := context.Background()
|
|
|
|
api := mocks.NewMockSealingAPI(mockCtrl)
|
|
|
|
fakeSealing := &pipeline.Sealing{
|
|
Api: api,
|
|
DealInfo: &pipeline.CurrentDealInfoManager{CDAPI: api},
|
|
}
|
|
|
|
sctx := mocks.NewMockContext(mockCtrl)
|
|
sctx.EXPECT().Context().AnyTimes().Return(ctx)
|
|
|
|
api.EXPECT().ChainHead(ctx).Times(2).Return(nil, abi.ChainEpoch(10), nil)
|
|
|
|
var dealId abi.DealID = 12
|
|
dealProposal := market.DealProposal{
|
|
PieceCID: idCid("newPieceCID"),
|
|
}
|
|
|
|
//stm: @CHAIN_STATE_MARKET_STORAGE_DEAL_001, @CHAIN_STATE_NETWORK_VERSION_001
|
|
api.EXPECT().StateMarketStorageDeal(ctx, dealId, nil).Return(&api2.MarketDeal{Proposal: dealProposal}, nil)
|
|
|
|
pc := idCid("publishCID")
|
|
|
|
// expect GetCurrentDealInfo
|
|
{
|
|
api.EXPECT().StateSearchMsg(ctx, gomock.Any(), pc, gomock.Any(), gomock.Any()).Return(&api2.MsgLookup{
|
|
Receipt: types.MessageReceipt{
|
|
ExitCode: exitcode.Ok,
|
|
Return: cborRet(&market0.PublishStorageDealsReturn{
|
|
IDs: []abi.DealID{dealId},
|
|
}),
|
|
},
|
|
}, nil)
|
|
api.EXPECT().StateNetworkVersion(ctx, nil).Return(network.Version0, nil)
|
|
api.EXPECT().StateMarketStorageDeal(ctx, dealId, nil).Return(&api2.MarketDeal{
|
|
Proposal: dealProposal,
|
|
}, nil)
|
|
|
|
}
|
|
|
|
sctx.EXPECT().Send(pipeline.SectorRemove{}).Return(nil)
|
|
|
|
// TODO sctx should satisfy an interface so it can be useable for mocking. This will fail because we are passing in an empty context now to get this to build.
|
|
// https://github.com/filecoin-project/lotus/issues/7867
|
|
err := fakeSealing.HandleRecoverDealIDs(statemachine.Context{}, pipeline.SectorInfo{
|
|
Pieces: []pipeline.SafeSectorPiece{
|
|
pipeline.SafePiece(api2.SectorPiece{
|
|
DealInfo: &piece.PieceDealInfo{
|
|
DealID: dealId,
|
|
PublishCid: &pc,
|
|
},
|
|
Piece: abi.PieceInfo{
|
|
PieceCID: idCid("oldPieceCID"),
|
|
},
|
|
}),
|
|
},
|
|
})
|
|
require.NoError(t, err)
|
|
}
|
|
|
|
func idCid(str string) cid.Cid {
|
|
builder := cid.V1Builder{Codec: cid.Raw, MhType: mh.IDENTITY}
|
|
c, err := builder.Sum([]byte(str))
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
return c
|
|
}
|
|
|
|
func cborRet(v cbor.Marshaler) []byte {
|
|
var buf bytes.Buffer
|
|
if err := v.MarshalCBOR(&buf); err != nil {
|
|
panic(err)
|
|
}
|
|
return buf.Bytes()
|
|
}
|