2019-10-09 15:32:15 -07:00
|
|
|
package zcash
|
|
|
|
|
|
|
|
import (
|
2019-10-12 09:42:16 -07:00
|
|
|
"context"
|
|
|
|
"net"
|
|
|
|
"os"
|
2019-10-09 15:32:15 -07:00
|
|
|
"testing"
|
|
|
|
"time"
|
|
|
|
|
2019-10-12 09:42:16 -07:00
|
|
|
"github.com/btcsuite/btcd/peer"
|
|
|
|
"github.com/btcsuite/btclog"
|
2019-10-09 15:32:15 -07:00
|
|
|
"github.com/gtank/coredns-zcash/zcash/network"
|
|
|
|
)
|
|
|
|
|
2019-10-12 09:42:16 -07:00
|
|
|
func mockLocalPeer(ctx context.Context) error {
|
|
|
|
// Configure peer to act as a regtest node that offers no services.
|
|
|
|
config, err := newSeederPeerConfig(network.Regtest, defaultPeerConfig)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
config.AllowSelfConns = true
|
|
|
|
|
|
|
|
backendLogger := btclog.NewBackend(os.Stdout)
|
|
|
|
mockPeerLogger := backendLogger.Logger("mockPeer")
|
|
|
|
//mockPeerLogger.SetLevel(btclog.LevelTrace)
|
|
|
|
peer.UseLogger(mockPeerLogger)
|
|
|
|
|
|
|
|
mockPeer := peer.NewInboundPeer(config)
|
|
|
|
|
|
|
|
listenAddr := net.JoinHostPort("127.0.0.1", config.ChainParams.DefaultPort)
|
|
|
|
listener, err := net.Listen("tcp", listenAddr)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
go func() {
|
|
|
|
conn, err := listener.Accept()
|
|
|
|
if err != nil {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
mockPeer.AssociateConnection(conn)
|
|
|
|
|
|
|
|
select {
|
|
|
|
case <-ctx.Done():
|
|
|
|
mockPeer.Disconnect()
|
|
|
|
mockPeer.WaitForDisconnect()
|
|
|
|
return
|
|
|
|
}
|
|
|
|
}()
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestOutboundPeerSync(t *testing.T) {
|
|
|
|
testContext, cancel := context.WithCancel(context.Background())
|
|
|
|
defer cancel()
|
|
|
|
|
|
|
|
if err := mockLocalPeer(testContext); err != nil {
|
|
|
|
t.Logf("error starting mock peer (%v).", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
regSeeder, err := newTestSeeder(network.Regtest)
|
2019-10-09 15:32:15 -07:00
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
|
2019-10-12 09:42:16 -07:00
|
|
|
err = regSeeder.ConnectToPeer("127.0.0.1")
|
2019-10-09 15:32:15 -07:00
|
|
|
if err != nil {
|
2019-10-12 09:42:16 -07:00
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Can we address that peer if we want to?
|
|
|
|
p, err := regSeeder.GetPeer("127.0.0.1")
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
if p.Connected() {
|
|
|
|
regSeeder.DisconnectAllPeers()
|
|
|
|
} else {
|
|
|
|
t.Error("Peer never connected")
|
|
|
|
}
|
|
|
|
|
|
|
|
// Can we STILL address a flushed peer?
|
|
|
|
p, err = regSeeder.GetPeer("127.0.0.1")
|
|
|
|
if err == nil {
|
|
|
|
t.Error("Peer should have been cleared on disconnect")
|
2019-10-09 15:32:15 -07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestOutboundPeerAsync(t *testing.T) {
|
2019-10-12 09:42:16 -07:00
|
|
|
testContext, cancel := context.WithCancel(context.Background())
|
|
|
|
defer cancel()
|
|
|
|
|
|
|
|
if err := mockLocalPeer(testContext); err != nil {
|
|
|
|
t.Logf("error starting mock peer (%v).", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
regSeeder, err := newTestSeeder(network.Regtest)
|
2019-10-09 15:32:15 -07:00
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
done := make(chan struct{})
|
|
|
|
go func() {
|
2019-10-12 09:42:16 -07:00
|
|
|
err := regSeeder.ConnectToPeer("127.0.0.1")
|
2019-10-09 15:32:15 -07:00
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
2019-10-12 09:42:16 -07:00
|
|
|
regSeeder.DisconnectAllPeers()
|
2019-10-09 15:32:15 -07:00
|
|
|
done <- struct{}{}
|
|
|
|
}()
|
|
|
|
|
|
|
|
select {
|
|
|
|
case <-done:
|
|
|
|
case <-time.After(time.Second * 1):
|
|
|
|
t.Error("timed out")
|
|
|
|
}
|
|
|
|
}
|