From 323bf67820ddf8e194a47ecc326e7e1ef155daed 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 | 5 +++-- 2 files changed, 14 insertions(+), 10 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..1e898cde37 100644 --- a/p2p/transport/webrtc/listener.go +++ b/p2p/transport/webrtc/listener.go @@ -38,7 +38,7 @@ const ( // sending the initial connection request message(STUN Binding request). Such peers take up a goroutine // till connection timeout. As the number of handshakes in parallel is still guarded by the resource // manager, this higher number is okay. - DefaultMaxInFlightConnections = 128 + DefaultMaxInFlightConnections = 10 ) type listener struct { @@ -126,7 +126,7 @@ func (l *listener) listen() { } return } - + fmt.Println("handshake inflight", candidate.Ufrag, len(inFlightSemaphore)) go func() { defer func() { <-inFlightSemaphore }() @@ -135,6 +135,7 @@ func (l *listener) listen() { conn, err := l.handleCandidate(ctx, candidate) if err != nil { + fmt.Println("dropped handshake inflight", candidate.Ufrag, len(inFlightSemaphore), err) l.mux.RemoveConnByUfrag(candidate.Ufrag) log.Debugf("could not accept connection: %s: %v", candidate.Ufrag, err) return