chain: Test basinc sync on generated chain
This commit is contained in:
parent
a656aea7fe
commit
9ef5e1266e
@ -1,8 +1,14 @@
|
||||
package gen
|
||||
|
||||
import (
|
||||
"bytes"
|
||||
"context"
|
||||
|
||||
"github.com/ipfs/go-blockservice"
|
||||
"github.com/ipfs/go-car"
|
||||
offline "github.com/ipfs/go-ipfs-exchange-offline"
|
||||
"github.com/ipfs/go-merkledag"
|
||||
|
||||
"github.com/filecoin-project/go-lotus/chain/address"
|
||||
"github.com/filecoin-project/go-lotus/chain/store"
|
||||
"github.com/filecoin-project/go-lotus/chain/types"
|
||||
@ -32,7 +38,7 @@ type ChainGen struct {
|
||||
|
||||
miner address.Address
|
||||
|
||||
r repo.Repo
|
||||
r repo.Repo
|
||||
lr repo.LockedRepo
|
||||
}
|
||||
|
||||
@ -67,7 +73,7 @@ func NewGenerator() (*ChainGen, error) {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
bs := mybs{blockstore.NewBlockstore(bds)}
|
||||
bs := mybs{blockstore.NewIdStore(blockstore.NewBlockstore(bds))}
|
||||
|
||||
ks, err := lr.KeyStore()
|
||||
if err != nil {
|
||||
@ -114,7 +120,7 @@ func NewGenerator() (*ChainGen, error) {
|
||||
miner: miner,
|
||||
curBlock: genfb,
|
||||
|
||||
r: mr,
|
||||
r: mr,
|
||||
lr: lr,
|
||||
}
|
||||
|
||||
@ -125,6 +131,20 @@ func (cg *ChainGen) Genesis() *types.BlockHeader {
|
||||
return cg.genesis
|
||||
}
|
||||
|
||||
func (cg *ChainGen) GenesisCar() ([]byte, error) {
|
||||
offl := offline.Exchange(cg.bs)
|
||||
blkserv := blockservice.New(cg.bs, offl)
|
||||
dserv := merkledag.NewDAGService(blkserv)
|
||||
|
||||
out := new(bytes.Buffer)
|
||||
|
||||
if err := car.WriteCar(context.TODO(), dserv, []cid.Cid{cg.Genesis().Cid()}, out); err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
return out.Bytes(), nil
|
||||
}
|
||||
|
||||
func (cg *ChainGen) nextBlockProof() (address.Address, types.ElectionProof, []types.Ticket, error) {
|
||||
return cg.miner, []byte("cat in a box"), []types.Ticket{types.Ticket("im a ticket, promise")}, nil
|
||||
}
|
||||
|
@ -1,22 +1,22 @@
|
||||
package chain_test
|
||||
|
||||
import (
|
||||
"bytes"
|
||||
"context"
|
||||
"fmt"
|
||||
"testing"
|
||||
"time"
|
||||
|
||||
mocknet "github.com/libp2p/go-libp2p/p2p/net/mock"
|
||||
"github.com/stretchr/testify/require"
|
||||
|
||||
"github.com/filecoin-project/go-lotus/api"
|
||||
"github.com/filecoin-project/go-lotus/chain/gen"
|
||||
"github.com/filecoin-project/go-lotus/node"
|
||||
"github.com/filecoin-project/go-lotus/node/modules"
|
||||
modtest "github.com/filecoin-project/go-lotus/node/modules/testing"
|
||||
"github.com/filecoin-project/go-lotus/node/repo"
|
||||
)
|
||||
|
||||
func repoWithChain(t *testing.T, h int) repo.Repo {
|
||||
func repoWithChain(t *testing.T, h int) (repo.Repo, []byte) {
|
||||
g, err := gen.NewGenerator()
|
||||
if err != nil {
|
||||
t.Fatal(err)
|
||||
@ -24,47 +24,44 @@ func repoWithChain(t *testing.T, h int) repo.Repo {
|
||||
|
||||
for i := 0; i < h; i++ {
|
||||
b, err := g.NextBlock()
|
||||
if err != nil {
|
||||
t.Fatalf("error at H:%d, %s", i, err)
|
||||
}
|
||||
if b.Header.Height != uint64(i+1) {
|
||||
t.Fatal("wrong height")
|
||||
}
|
||||
require.NoError(t, err)
|
||||
require.Equal(t, uint64(i+1), b.Header.Height, "wrong height")
|
||||
}
|
||||
|
||||
r, err := g.YieldRepo()
|
||||
if err != nil {
|
||||
t.Fatal(err)
|
||||
}
|
||||
return r
|
||||
require.NoError(t, err)
|
||||
|
||||
genb, err := g.GenesisCar()
|
||||
require.NoError(t, err)
|
||||
|
||||
return r, genb
|
||||
}
|
||||
|
||||
func TestSyncSimple(t *testing.T) {
|
||||
ctx := context.Background()
|
||||
|
||||
var genbuf bytes.Buffer
|
||||
var source api.FullNode
|
||||
var client api.FullNode
|
||||
|
||||
mn := mocknet.New(ctx)
|
||||
|
||||
sourceRepo, genesis := repoWithChain(t, 20)
|
||||
|
||||
err := node.New(ctx,
|
||||
node.FullAPI(&source),
|
||||
node.Online(),
|
||||
node.Repo(repoWithChain(t, 20)),
|
||||
node.Repo(sourceRepo),
|
||||
node.MockHost(mn),
|
||||
|
||||
node.Override(new(modules.Genesis), modtest.MakeGenesisMem(&genbuf)),
|
||||
node.Override(new(modules.Genesis), modules.LoadGenesis(genesis)),
|
||||
)
|
||||
if err != nil {
|
||||
t.Fatal(err)
|
||||
}
|
||||
require.NoError(t, err)
|
||||
|
||||
b, err := source.ChainHead(ctx)
|
||||
if err != nil {
|
||||
t.Fatal(err)
|
||||
}
|
||||
fmt.Println(b.Height())
|
||||
require.NoError(t, err)
|
||||
|
||||
require.Equal(t, uint64(20), b.Height())
|
||||
fmt.Printf("source H: %d\n", b.Height())
|
||||
|
||||
err = node.New(ctx,
|
||||
node.FullAPI(&client),
|
||||
@ -72,10 +69,27 @@ func TestSyncSimple(t *testing.T) {
|
||||
node.Repo(repo.NewMemory(nil)),
|
||||
node.MockHost(mn),
|
||||
|
||||
node.Override(new(modules.Genesis), modules.LoadGenesis(genbuf.Bytes())),
|
||||
node.Override(new(modules.Genesis), modules.LoadGenesis(genesis)),
|
||||
)
|
||||
if err != nil {
|
||||
t.Fatal(err)
|
||||
}
|
||||
require.NoError(t, err)
|
||||
|
||||
require.NoError(t, mn.LinkAll())
|
||||
|
||||
cb, err := client.ChainHead(ctx)
|
||||
require.NoError(t, err)
|
||||
require.Equal(t, uint64(0), cb.Height())
|
||||
fmt.Printf("client H: %d\n", cb.Height())
|
||||
|
||||
sourcePI, err := source.NetAddrsListen(ctx)
|
||||
require.NoError(t, err)
|
||||
|
||||
err = client.NetConnect(ctx, sourcePI)
|
||||
require.NoError(t, err)
|
||||
|
||||
time.Sleep(time.Second)
|
||||
|
||||
cb, err = client.ChainHead(ctx)
|
||||
require.NoError(t, err)
|
||||
require.Equal(t, uint64(20), cb.Height())
|
||||
fmt.Printf("client H: %d\n", cb.Height())
|
||||
}
|
||||
|
@ -335,6 +335,7 @@ func New(ctx context.Context, opts ...Option) error {
|
||||
// on this context, and implement closing logic through lifecycles
|
||||
// correctly
|
||||
if err := app.Start(ctx); err != nil {
|
||||
// comment fx.NopLogger few lines above for easier debugging
|
||||
return err
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user