mirror of
https://github.com/ipfs/kubo.git
synced 2025-07-01 10:49:24 +08:00
feat(bitswap/testnet) impl a version of bitswap testnet that uses mockpeernet under the hood
License: MIT Signed-off-by: Brian Tiger Chow <brian@perfmode.com>
This commit is contained in:
@ -8,6 +8,7 @@ import (
|
|||||||
"testing"
|
"testing"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
|
context "github.com/jbenet/go-ipfs/Godeps/_workspace/src/code.google.com/p/go.net/context"
|
||||||
"github.com/jbenet/go-ipfs/Godeps/_workspace/src/github.com/jbenet/go-random"
|
"github.com/jbenet/go-ipfs/Godeps/_workspace/src/github.com/jbenet/go-random"
|
||||||
blockservice "github.com/jbenet/go-ipfs/blockservice"
|
blockservice "github.com/jbenet/go-ipfs/blockservice"
|
||||||
bitswap "github.com/jbenet/go-ipfs/exchange/bitswap"
|
bitswap "github.com/jbenet/go-ipfs/exchange/bitswap"
|
||||||
@ -85,15 +86,16 @@ func RandomBytes(n int64) []byte {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func AddCatBytes(data []byte, conf Config) error {
|
func AddCatBytes(data []byte, conf Config) error {
|
||||||
|
ctx := context.Background()
|
||||||
sessionGenerator := bitswap.NewSessionGenerator(
|
rs := mockrouting.NewServerWithDelay(mockrouting.DelayConfig{
|
||||||
tn.VirtualNetwork(
|
Query: delay.Fixed(conf.RoutingLatency),
|
||||||
mockrouting.NewServerWithDelay(mockrouting.DelayConfig{
|
ValueVisibility: delay.Fixed(conf.RoutingLatency),
|
||||||
Query: delay.Fixed(conf.RoutingLatency),
|
})
|
||||||
ValueVisibility: delay.Fixed(conf.RoutingLatency),
|
net, err := tn.StreamNetWithDelay(ctx, rs, delay.Fixed(conf.NetworkLatency))
|
||||||
}),
|
if err != nil {
|
||||||
delay.Fixed(conf.NetworkLatency)), // TODO rename VirtualNetwork
|
return errors.Wrap(err)
|
||||||
)
|
}
|
||||||
|
sessionGenerator := bitswap.NewSessionGenerator(net)
|
||||||
defer sessionGenerator.Close()
|
defer sessionGenerator.Close()
|
||||||
|
|
||||||
adder := sessionGenerator.Next()
|
adder := sessionGenerator.Next()
|
||||||
|
55
exchange/bitswap/testnet/peernet.go
Normal file
55
exchange/bitswap/testnet/peernet.go
Normal file
@ -0,0 +1,55 @@
|
|||||||
|
package bitswap
|
||||||
|
|
||||||
|
import (
|
||||||
|
"math"
|
||||||
|
|
||||||
|
context "github.com/jbenet/go-ipfs/Godeps/_workspace/src/code.google.com/p/go.net/context"
|
||||||
|
bsnet "github.com/jbenet/go-ipfs/exchange/bitswap/network"
|
||||||
|
mockpeernet "github.com/jbenet/go-ipfs/net/mock"
|
||||||
|
peer "github.com/jbenet/go-ipfs/peer"
|
||||||
|
mockrouting "github.com/jbenet/go-ipfs/routing/mock"
|
||||||
|
delay "github.com/jbenet/go-ipfs/util/delay"
|
||||||
|
testutil "github.com/jbenet/go-ipfs/util/testutil"
|
||||||
|
)
|
||||||
|
|
||||||
|
type peernet struct {
|
||||||
|
mockpeernet.Mocknet
|
||||||
|
routingserver mockrouting.Server
|
||||||
|
}
|
||||||
|
|
||||||
|
func StreamNetWithDelay(
|
||||||
|
ctx context.Context,
|
||||||
|
rs mockrouting.Server,
|
||||||
|
d delay.D) (Network, error) {
|
||||||
|
|
||||||
|
net := mockpeernet.New(ctx)
|
||||||
|
net.SetLinkDefaults(mockpeernet.LinkOptions{
|
||||||
|
Latency: d.Get(),
|
||||||
|
Bandwidth: math.MaxInt32, // TODO inject
|
||||||
|
})
|
||||||
|
return &peernet{net, rs}, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (pn *peernet) Adapter(p testutil.Peer) bsnet.BitSwapNetwork {
|
||||||
|
peers := pn.Mocknet.Peers()
|
||||||
|
client, err := pn.Mocknet.AddPeer(p.PrivateKey(), p.Address())
|
||||||
|
if err != nil {
|
||||||
|
panic(err.Error())
|
||||||
|
}
|
||||||
|
for _, other := range peers {
|
||||||
|
pn.Mocknet.LinkPeers(p.ID(), other)
|
||||||
|
}
|
||||||
|
routing := pn.routingserver.Client(peer.PeerInfo{ID: p.ID()})
|
||||||
|
return bsnet.NewFromIpfsNetwork(client, routing)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (pn *peernet) HasPeer(p peer.ID) bool {
|
||||||
|
for _, member := range pn.Mocknet.Peers() {
|
||||||
|
if p == member {
|
||||||
|
return true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
|
||||||
|
var _ Network = &peernet{}
|
Reference in New Issue
Block a user