From 5ca26ef8972ef1848bf9d72f308511c7242abbf4 Mon Sep 17 00:00:00 2001 From: Richard Ramos Date: Thu, 6 Jul 2023 17:47:25 -0400 Subject: [PATCH] fix: allow wakunodes to be restarted without error --- waku/v2/discovery_connector.go | 2 ++ waku/v2/node/wakunode2.go | 5 ++-- waku/v2/node/wakunode2_test.go | 43 ++++++++++++++++++++++++++++++++++ 3 files changed, 48 insertions(+), 2 deletions(-) diff --git a/waku/v2/discovery_connector.go b/waku/v2/discovery_connector.go index f7facd0d..44b0bcb6 100644 --- a/waku/v2/discovery_connector.go +++ b/waku/v2/discovery_connector.go @@ -117,6 +117,8 @@ func (c *PeerConnectionStrategy) Stop() { close(c.peerCh) close(c.dialCh) + + c.cancel = nil } func (c *PeerConnectionStrategy) isPaused() bool { diff --git a/waku/v2/node/wakunode2.go b/waku/v2/node/wakunode2.go index 08d2a1c2..09d95417 100644 --- a/waku/v2/node/wakunode2.go +++ b/waku/v2/node/wakunode2.go @@ -334,9 +334,10 @@ func (w *WakuNode) Start(ctx context.Context) error { ctx, cancel := context.WithCancel(ctx) w.cancel = cancel - w.opts.libP2POpts = append(w.opts.libP2POpts, libp2p.ConnectionGater(connGater)) - host, err := libp2p.New(w.opts.libP2POpts...) + libP2POpts := append(w.opts.libP2POpts, libp2p.ConnectionGater(connGater)) + + host, err := libp2p.New(libP2POpts...) if err != nil { return err } diff --git a/waku/v2/node/wakunode2_test.go b/waku/v2/node/wakunode2_test.go index 3c8278c8..b7c48a15 100644 --- a/waku/v2/node/wakunode2_test.go +++ b/waku/v2/node/wakunode2_test.go @@ -10,15 +10,18 @@ import ( "time" "github.com/ethereum/go-ethereum/crypto" + "github.com/ethereum/go-ethereum/p2p/enode" "github.com/stretchr/testify/require" "github.com/waku-org/go-waku/tests" "github.com/waku-org/go-waku/waku/persistence" "github.com/waku-org/go-waku/waku/persistence/sqlite" + "github.com/waku-org/go-waku/waku/v2/dnsdisc" "github.com/waku-org/go-waku/waku/v2/protocol/legacy_filter" "github.com/waku-org/go-waku/waku/v2/protocol/pb" "github.com/waku-org/go-waku/waku/v2/protocol/relay" "github.com/waku-org/go-waku/waku/v2/protocol/store" "github.com/waku-org/go-waku/waku/v2/utils" + "go.uber.org/zap" ) func createTestMsg(version uint32) *pb.WakuMessage { @@ -59,6 +62,46 @@ func int2Bytes(i int) []byte { return append(big.NewInt(int64(i)).Bytes(), byte(0)) } +func TestUpAndDown(t *testing.T) { + ctx, cancel := context.WithTimeout(context.Background(), 120*time.Second) + defer cancel() + + hostAddr1, _ := net.ResolveTCPAddr("tcp", "0.0.0.0:0") + key1, _ := tests.RandomHex(32) + prvKey1, _ := crypto.HexToECDSA(key1) + + nodes, err := dnsdisc.RetrieveNodes(context.Background(), "enrtree://AOGECG2SPND25EEFMAJ5WF3KSGJNSGV356DSTL2YVLLZWIV6SAYBM@prod.waku.nodes.status.im") + require.NoError(t, err) + + var bootnodes []*enode.Node + for _, n := range nodes { + if n.ENR != nil { + bootnodes = append(bootnodes, n.ENR) + } + } + + wakuNode1, err := New( + WithPrivateKey(prvKey1), + WithHostAddress(hostAddr1), + WithWakuRelay(), + WithDiscoveryV5(0, bootnodes, true), + ) + require.NoError(t, err) + + for i := 0; i < 5; i++ { + utils.Logger().Info("Starting...", zap.Int("iteration", i)) + err = wakuNode1.Start(ctx) + require.NoError(t, err) + err = wakuNode1.DiscV5().Start(ctx) + require.NoError(t, err) + utils.Logger().Info("Started!", zap.Int("iteration", i)) + time.Sleep(3 * time.Second) + utils.Logger().Info("Stopping...", zap.Int("iteration", i)) + wakuNode1.Stop() + utils.Logger().Info("Stopped!", zap.Int("iteration", i)) + } +} + func Test500(t *testing.T) { maxMsgs := 500 maxMsgBytes := int2Bytes(maxMsgs)