From 90dc647a436be7b6c4236efdf192a2368c61685a Mon Sep 17 00:00:00 2001 From: sukun Date: Thu, 5 Dec 2024 02:22:42 +0530 Subject: [PATCH] improve test name --- p2p/test/basichost/basic_host_test.go | 19 +++++++++++-------- p2p/transport/webrtc/listener.go | 1 - 2 files changed, 11 insertions(+), 9 deletions(-) diff --git a/p2p/test/basichost/basic_host_test.go b/p2p/test/basichost/basic_host_test.go index aa6ee688d0..78be7101ef 100644 --- a/p2p/test/basichost/basic_host_test.go +++ b/p2p/test/basichost/basic_host_test.go @@ -204,7 +204,7 @@ func TestAddrFactorCertHashAppend(t *testing.T) { }, 5*time.Second, 100*time.Millisecond) } -func TestWebRTCDirectDialDelay(t *testing.T) { +func TestOnlyWebRTCDirectDialNoDelay(t *testing.T) { // This tests that only webrtc-direct dials are dialled immediately // and not delayed by dial ranker. h1, err := libp2p.New( @@ -229,46 +229,49 @@ func TestWebRTCDirectDialDelay(t *testing.T) { func TestWebRTCWithQUICManyConnections(t *testing.T) { // Correctly fixes: https://github.com/libp2p/js-libp2p/issues/2805 + // The server has both /quic-v1 and /webrtc-direct listen addresses h, err := libp2p.New( libp2p.Transport(libp2pquic.NewTransport), libp2p.Transport(libp2pwebrtc.New), libp2p.ListenAddrStrings("/ip4/0.0.0.0/udp/0/quic-v1"), libp2p.ListenAddrStrings("/ip4/0.0.0.0/udp/0/webrtc-direct"), + libp2p.ResourceManager(&network.NullResourceManager{}), ) require.NoError(t, err) defer h.Close() - const N = 50 + const N = 200 + // These N dialers have both /quic-v1 and /webrtc-direct transports var dialers [N]host.Host for i := 0; i < N; i++ { dialers[i], err = libp2p.New(libp2p.NoListenAddrs) require.NoError(t, err) defer dialers[i].Close() } - // only webrtc dialer for dialing the peer later + // This dialer has only /webrtc-direct transport d, err := libp2p.New(libp2p.Transport(libp2pwebrtc.New), libp2p.NoListenAddrs) require.NoError(t, err) defer d.Close() - startDial := make(chan struct{}) var wg sync.WaitGroup wg.Add(N) for i := 0; i < N; i++ { go func() { defer wg.Done() - <-startDial ctx, cancel := context.WithTimeout(context.Background(), 5*time.Second) defer cancel() - // it is fine if the dial fails, we just want to take up all the webrtc - // listen queue + // With happy eyeballs these dialers will connect over only /quic-v1 + // and not stall the /webrtc-direct handshake goroutines. + // it is fine if the dial fails, we just want to ensure that there's space + // in the /webrtc-direct listen queue _ = dialers[i].Connect(ctx, peer.AddrInfo{ID: h.ID(), Addrs: h.Addrs()}) }() } - close(startDial) wg.Wait() ctx, cancel := context.WithTimeout(context.Background(), 5*time.Second) defer cancel() + // The webrtc only dialer should be able to connect to the peer err = d.Connect(ctx, peer.AddrInfo{ID: h.ID(), Addrs: h.Addrs()}) require.NoError(t, err) } diff --git a/p2p/transport/webrtc/listener.go b/p2p/transport/webrtc/listener.go index c3e2f29799..b9e80e4434 100644 --- a/p2p/transport/webrtc/listener.go +++ b/p2p/transport/webrtc/listener.go @@ -126,7 +126,6 @@ func (l *listener) listen() { } return } - go func() { defer func() { <-inFlightSemaphore }()