Skip to content

Commit

Permalink
p2p/protocols, swarm/network: fix resource leak with p2p teardown
Browse files Browse the repository at this point in the history
  • Loading branch information
acud authored and nonsense committed May 10, 2019
1 parent c1213bd commit a1cd7e6
Show file tree
Hide file tree
Showing 4 changed files with 28 additions and 19 deletions.
1 change: 1 addition & 0 deletions p2p/protocols/protocol_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -269,6 +269,7 @@ func TestProtocolHook(t *testing.T) {
panic(err)
}
tester := p2ptest.NewProtocolTester(prvkey, 2, runFunc)
defer tester.Stop()
err = tester.TestExchanges(p2ptest.Exchange{
Expects: []p2ptest.Expect{
{
Expand Down
27 changes: 15 additions & 12 deletions swarm/network/hive_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -117,7 +117,7 @@ func TestHiveStatePersistance(t *testing.T) {

const peersCount = 5

startHive := func(t *testing.T, dir string) (h *Hive) {
startHive := func(t *testing.T, dir string) (h *Hive, cleanupFunc func()) {
store, err := state.NewDBStore(dir)
if err != nil {
t.Fatal(err)
Expand All @@ -137,27 +137,30 @@ func TestHiveStatePersistance(t *testing.T) {
if err := h.Start(s.Server); err != nil {
t.Fatal(err)
}
return h

cleanupFunc = func() {
err := h.Stop()
if err != nil {
t.Fatal(err)
}

s.Stop()
}
return h, cleanupFunc
}

h1 := startHive(t, dir)
h1, cleanup1 := startHive(t, dir)
peers := make(map[string]bool)
for i := 0; i < peersCount; i++ {
raddr := RandomAddr()
h1.Register(raddr)
peers[raddr.String()] = true
}
if err = h1.Stop(); err != nil {
t.Fatal(err)
}
cleanup1()

// start the hive and check that we know of all expected peers
h2 := startHive(t, dir)
defer func() {
if err = h2.Stop(); err != nil {
t.Fatal(err)
}
}()
h2, cleanup2 := startHive(t, dir)
cleanup2()

i := 0
h2.Kademlia.EachAddr(nil, 256, func(addr *BzzAddr, po int) bool {
Expand Down
4 changes: 4 additions & 0 deletions swarm/network/protocol_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -235,6 +235,7 @@ func TestBzzHandshakeNetworkIDMismatch(t *testing.T) {
if err != nil {
t.Fatal(err)
}
defer s.Stop()
node := s.Nodes[0]

err = s.testHandshake(
Expand All @@ -258,6 +259,7 @@ func TestBzzHandshakeVersionMismatch(t *testing.T) {
if err != nil {
t.Fatal(err)
}
defer s.Stop()
node := s.Nodes[0]

err = s.testHandshake(
Expand All @@ -281,6 +283,7 @@ func TestBzzHandshakeSuccess(t *testing.T) {
if err != nil {
t.Fatal(err)
}
defer s.Stop()
node := s.Nodes[0]

err = s.testHandshake(
Expand Down Expand Up @@ -312,6 +315,7 @@ func TestBzzHandshakeLightNode(t *testing.T) {
if err != nil {
t.Fatal(err)
}
defer pt.Stop()

node := pt.Nodes[0]
addr := NewAddr(node)
Expand Down
15 changes: 8 additions & 7 deletions swarm/network/stream/common_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -178,20 +178,21 @@ func newStreamerTester(registryOptions *RegistryOptions) (*p2ptest.ProtocolTeste
netStore.NewNetFetcherFunc = network.NewFetcherFactory(delivery.RequestFromPeers, true).New
intervalsStore := state.NewInmemoryStore()
streamer := NewRegistry(addr.ID(), delivery, netStore, intervalsStore, registryOptions, nil)
teardown := func() {
streamer.Close()
intervalsStore.Close()
netStore.Close()
removeDataDir()
}

prvkey, err := crypto.GenerateKey()
if err != nil {
removeDataDir()
return nil, nil, nil, nil, err
}

protocolTester := p2ptest.NewProtocolTester(prvkey, 1, streamer.runProtocol)

teardown := func() {
protocolTester.Stop()
streamer.Close()
intervalsStore.Close()
netStore.Close()
removeDataDir()
}
err = waitForPeers(streamer, 10*time.Second, 1)
if err != nil {
teardown()
Expand Down

0 comments on commit a1cd7e6

Please sign in to comment.