Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

swarm_test: support more transports for GenSwarm #3130

Draft
wants to merge 1 commit into
base: master
Choose a base branch
from

Conversation

sukunrt
Copy link
Member

@sukunrt sukunrt commented Dec 30, 2024

This adds support for /webtransport and /webrtc-direct to GenSwarm.

Ideally, we should rewrite this to have the same semantics, opt into transports not opt out, as libp2p.New. But I need webtransport and webrtc support to write address inference tests for #3075

Depending on how disruptive this is to users, we can decide on whether to merge or drop this.

@sukunrt sukunrt requested a review from MarcoPolo December 30, 2024 16:01
This adds support for `/webtransport` andn `/webrtc-direct` to GenSwarm.

Ideally, we should rewrite this to have the same semantics, opt into
transports not opt out, as `libp2p.New`. But I need webtransport and
webrtc support to write address inference tests for
#3075

Depending on how disruptive this is to users, we can decide on whether
to merge or drop this.
Copy link
Collaborator

@MarcoPolo MarcoPolo left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

one question, but otherwise looks good.

@@ -191,6 +209,75 @@ func GenSwarm(t testing.TB, opts ...Option) *swarm.Swarm {
if err := s.Listen(ma.StringCast("/ip4/127.0.0.1/udp/0/quic-v1")); err != nil {
t.Fatal(err)
}
for _, a := range s.ListenAddresses() {
if _, err := a.ValueForProtocol(ma.P_QUIC_V1); err == nil {
quicListenAddr = a
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It's not obvious to me why you want to share this address with all the other transports. Can you explain? Also what happens if ListenAddresses contains a different address for WebTransport?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants