From fd3ed652c951bc5b2f5b643a6ee05be5a4f90907 Mon Sep 17 00:00:00 2001 From: Marco Munizaga Date: Wed, 12 Apr 2023 11:08:01 -0700 Subject: [PATCH] Revert "Dedupe addrs" This reverts commit b63155f4a3997d7adfebc337d0262defca329c15. --- p2p/host/basic/basic_host.go | 12 ------------ p2p/host/basic/basic_host_test.go | 15 --------------- 2 files changed, 27 deletions(-) diff --git a/p2p/host/basic/basic_host.go b/p2p/host/basic/basic_host.go index 7799676ff1..e498dd22e2 100644 --- a/p2p/host/basic/basic_host.go +++ b/p2p/host/basic/basic_host.go @@ -1029,15 +1029,10 @@ func inferWebtransportAddrsFromQuic(in []ma.Multiaddr) []ma.Multiaddr { quicAddrCount++ } } - seenAddr := make(map[string]struct{}, len(in)) quicOrWebtransportAddrs := make(map[string]struct{}, quicAddrCount) webtransportAddrs := make(map[string]struct{}, quicAddrCount) foundSameListeningAddr := false for _, addr := range in { - if _, ok := seenAddr[addr.String()]; ok { - continue - } - seenAddr[addr.String()] = struct{}{} isWebtransport, numCertHashes := libp2pwebtransport.IsWebtransportMultiaddr(addr) if isWebtransport { for i := 0; i < numCertHashes; i++ { @@ -1069,15 +1064,8 @@ func inferWebtransportAddrsFromQuic(in []ma.Multiaddr) []ma.Multiaddr { return in } - // Dedup the output, because why not - seenAddr = make(map[string]struct{}, len(in)) out := make([]ma.Multiaddr, 0, len(in)+(quicAddrCount-len(webtransportAddrs))) for _, addr := range in { - if _, ok := seenAddr[addr.String()]; ok { - continue - } - seenAddr[addr.String()] = struct{}{} - // Add all the original addresses out = append(out, addr) if _, lastComponent := ma.SplitLast(addr); lastComponent.Protocol().Code == ma.P_QUIC_V1 { diff --git a/p2p/host/basic/basic_host_test.go b/p2p/host/basic/basic_host_test.go index 66ab2bbbcf..19ea2bd02f 100644 --- a/p2p/host/basic/basic_host_test.go +++ b/p2p/host/basic/basic_host_test.go @@ -864,21 +864,6 @@ func TestInferWebtransportAddrsFromQuic(t *testing.T) { in: []string{"/ip4/0.0.0.0/udp/9999/quic-v1", "/ip4/0.0.0.0/udp/9999/quic-v1/webtransport", "/ip4/1.2.3.4/udp/9999/quic-v1"}, out: []string{"/ip4/0.0.0.0/udp/9999/quic-v1", "/ip4/0.0.0.0/udp/9999/quic-v1/webtransport", "/ip4/1.2.3.4/udp/9999/quic-v1", "/ip4/1.2.3.4/udp/9999/quic-v1/webtransport"}, }, - { - name: "Happy Path with Dupes", - in: []string{"/ip4/0.0.0.0/udp/9999/quic-v1", "/ip4/0.0.0.0/udp/9999/quic-v1/webtransport", "/ip4/1.2.3.4/udp/9999/quic-v1", "/ip4/1.2.3.4/udp/9999/quic-v1"}, - out: []string{"/ip4/0.0.0.0/udp/9999/quic-v1", "/ip4/0.0.0.0/udp/9999/quic-v1/webtransport", "/ip4/1.2.3.4/udp/9999/quic-v1", "/ip4/1.2.3.4/udp/9999/quic-v1/webtransport"}, - }, - { - name: "Doesn't dedupe if there's no inferring", - in: []string{"/ip4/0.0.0.0/udp/9999/quic-v1", "/ip4/0.0.0.0/udp/9999/quic-v1", "/ip4/0.0.0.0/tcp/9999"}, - out: []string{"/ip4/0.0.0.0/udp/9999/quic-v1", "/ip4/0.0.0.0/udp/9999/quic-v1", "/ip4/0.0.0.0/tcp/9999"}, - }, - { - name: "Dedupes if we inferred a webtransport addr", - in: []string{"/ip4/0.0.0.0/udp/9999/quic-v1", "/ip4/0.0.0.0/udp/9999/quic-v1/webtransport", "/ip4/1.2.3.4/udp/9999/quic-v1", "/ip4/1.2.3.4/udp/9999/quic-v1", "/ip4/0.0.0.0/tcp/9999", "/ip4/0.0.0.0/tcp/9999"}, - out: []string{"/ip4/0.0.0.0/udp/9999/quic-v1", "/ip4/0.0.0.0/udp/9999/quic-v1/webtransport", "/ip4/1.2.3.4/udp/9999/quic-v1", "/ip4/1.2.3.4/udp/9999/quic-v1/webtransport", "/ip4/0.0.0.0/tcp/9999"}, - }, { name: "Already discovered", in: []string{"/ip4/0.0.0.0/udp/9999/quic-v1", "/ip4/0.0.0.0/udp/9999/quic-v1/webtransport", "/ip4/1.2.3.4/udp/9999/quic-v1", "/ip4/1.2.3.4/udp/9999/quic-v1/webtransport"},