1
0
mirror of https://github.com/ipfs/kubo.git synced 2025-07-01 19:24:14 +08:00

refactor: use the Core in the integration test

This commit is contained in:
Brian Tiger Chow
2015-01-10 19:48:24 -08:00
parent 2c3fb43350
commit 85401d53fd
3 changed files with 35 additions and 40 deletions

View File

@ -109,8 +109,8 @@ func DirectAddCat(data []byte, conf testutil.LatencyConfig) error {
return err return err
} }
adder.Bootstrap(ctx, catter.ID()) adder.Bootstrap(ctx, catter.Peerstore.PeerInfo(catter.PeerHost.ID()))
catter.Bootstrap(ctx, adder.ID()) catter.Bootstrap(ctx, adder.Peerstore.PeerInfo(adder.PeerHost.ID()))
keyAdded, err := adder.Add(bytes.NewReader(data)) keyAdded, err := adder.Add(bytes.NewReader(data))
if err != nil { if err != nil {

View File

@ -9,7 +9,7 @@ import (
blockstore "github.com/jbenet/go-ipfs/blocks/blockstore" blockstore "github.com/jbenet/go-ipfs/blocks/blockstore"
blockservice "github.com/jbenet/go-ipfs/blockservice" blockservice "github.com/jbenet/go-ipfs/blockservice"
testutil "github.com/jbenet/go-ipfs/util/testutil" core "github.com/jbenet/go-ipfs/core"
exchange "github.com/jbenet/go-ipfs/exchange" exchange "github.com/jbenet/go-ipfs/exchange"
bitswap "github.com/jbenet/go-ipfs/exchange/bitswap" bitswap "github.com/jbenet/go-ipfs/exchange/bitswap"
bsnet "github.com/jbenet/go-ipfs/exchange/bitswap/network" bsnet "github.com/jbenet/go-ipfs/exchange/bitswap/network"
@ -25,30 +25,26 @@ import (
"github.com/jbenet/go-ipfs/util/datastore2" "github.com/jbenet/go-ipfs/util/datastore2"
delay "github.com/jbenet/go-ipfs/util/delay" delay "github.com/jbenet/go-ipfs/util/delay"
eventlog "github.com/jbenet/go-ipfs/util/eventlog" eventlog "github.com/jbenet/go-ipfs/util/eventlog"
testutil "github.com/jbenet/go-ipfs/util/testutil"
) )
var log = eventlog.Logger("epictest") var log = eventlog.Logger("epictest")
// TODO merge with core.IpfsNode // TODO merge with core.IpfsNode
type core struct { type Core struct {
repo Repo *core.IpfsNode
blockService *blockservice.BlockService
blockstore blockstore.Blockstore
dag merkledag.DAGService
id peer.ID
} }
func (c *core) ID() peer.ID { func (c *Core) ID() peer.ID {
return c.repo.ID() return c.IpfsNode.Identity
} }
func (c *core) Bootstrap(ctx context.Context, p peer.ID) error { func (c *Core) Bootstrap(ctx context.Context, p peer.PeerInfo) error {
return c.repo.Bootstrap(ctx, p) return c.IpfsNode.Bootstrap(ctx, []peer.PeerInfo{p})
} }
func (c *core) Cat(k util.Key) (io.Reader, error) { func (c *Core) Cat(k util.Key) (io.Reader, error) {
catterdag := c.dag catterdag := c.IpfsNode.DAG
nodeCatted, err := (&path.Resolver{catterdag}).ResolvePath(k.String()) nodeCatted, err := (&path.Resolver{catterdag}).ResolvePath(k.String())
if err != nil { if err != nil {
return nil, err return nil, err
@ -56,10 +52,10 @@ func (c *core) Cat(k util.Key) (io.Reader, error) {
return uio.NewDagReader(nodeCatted, catterdag) return uio.NewDagReader(nodeCatted, catterdag)
} }
func (c *core) Add(r io.Reader) (util.Key, error) { func (c *Core) Add(r io.Reader) (util.Key, error) {
nodeAdded, err := importer.BuildDagFromReader( nodeAdded, err := importer.BuildDagFromReader(
r, r,
c.dag, c.IpfsNode.DAG,
nil, nil,
chunk.DefaultSplitter, chunk.DefaultSplitter,
) )
@ -69,28 +65,26 @@ func (c *core) Add(r io.Reader) (util.Key, error) {
return nodeAdded.Key() return nodeAdded.Key()
} }
func makeCore(ctx context.Context, rf RepoFactory) (*core, error) { func makeCore(ctx context.Context, rf RepoFactory) (*Core, error) {
repo, err := rf(ctx) node, err := rf(ctx)
if err != nil { if err != nil {
return nil, err return nil, err
} }
bss, err := blockservice.New(repo.Blockstore(), repo.Exchange()) node.Blocks, err = blockservice.New(node.Blockstore, node.Exchange)
if err != nil { if err != nil {
return nil, err return nil, err
} }
dag := merkledag.NewDAGService(bss) node.DAG = merkledag.NewDAGService(node.Blocks)
// to make sure nothing is omitted, init each individual field and assign // to make sure nothing is omitted, init each individual field and assign
// all at once at the bottom. // all at once at the bottom.
return &core{ return &Core{
repo: repo, IpfsNode: node,
blockService: bss,
dag: dag,
}, nil }, nil
} }
type RepoFactory func(ctx context.Context) (Repo, error) type RepoFactory func(ctx context.Context) (*core.IpfsNode, error)
type Repo interface { type Repo interface {
ID() peer.ID ID() peer.ID
@ -132,11 +126,11 @@ func (r *repo) Exchange() exchange.Interface {
} }
func MocknetTestRepo(p peer.ID, h host.Host, conf testutil.LatencyConfig) RepoFactory { func MocknetTestRepo(p peer.ID, h host.Host, conf testutil.LatencyConfig) RepoFactory {
return func(ctx context.Context) (Repo, error) { return func(ctx context.Context) (*core.IpfsNode, error) {
const kWriteCacheElems = 100 const kWriteCacheElems = 100
const alwaysSendToPeer = true const alwaysSendToPeer = true
dsDelay := delay.Fixed(conf.BlockstoreLatency) dsDelay := delay.Fixed(conf.BlockstoreLatency)
ds := sync.MutexWrap(datastore2.WithDelay(datastore.NewMapDatastore(), dsDelay)) ds := datastore2.CloserWrap(sync.MutexWrap(datastore2.WithDelay(datastore.NewMapDatastore(), dsDelay)))
log.Debugf("MocknetTestRepo: %s %s %s", p, h.ID(), h) log.Debugf("MocknetTestRepo: %s %s %s", p, h.ID(), h)
dhtt := dht.NewDHT(ctx, h, ds) dhtt := dht.NewDHT(ctx, h, ds)
@ -146,14 +140,15 @@ func MocknetTestRepo(p peer.ID, h host.Host, conf testutil.LatencyConfig) RepoFa
return nil, err return nil, err
} }
exch := bitswap.New(ctx, p, bsn, bstore, alwaysSendToPeer) exch := bitswap.New(ctx, p, bsn, bstore, alwaysSendToPeer)
return &repo{ return &core.IpfsNode{
bitSwapNetwork: bsn, Peerstore: h.Peerstore(),
blockstore: bstore, Blockstore: bstore,
exchange: exch, Exchange: exch,
datastore: ds, Datastore: ds,
host: h, PeerHost: h,
dht: dhtt, Routing: dhtt,
id: p, Identity: p,
DHT: dhtt,
}, nil }, nil
} }
} }

View File

@ -55,9 +55,9 @@ func RunThreeLeggedCat(data []byte, conf testutil.LatencyConfig) error {
if err != nil { if err != nil {
return err return err
} }
boostrapInfo := bootstrap.Peerstore.PeerInfo(bootstrap.PeerHost.ID())
adder.Bootstrap(ctx, bootstrap.ID()) adder.Bootstrap(ctx, boostrapInfo)
catter.Bootstrap(ctx, bootstrap.ID()) catter.Bootstrap(ctx, boostrapInfo)
keyAdded, err := adder.Add(bytes.NewReader(data)) keyAdded, err := adder.Add(bytes.NewReader(data))
if err != nil { if err != nil {