Skip to content

Commit da137c7

Browse files
dweomerBryan C. Mills
authored and
Bryan C. Mills
committed
proxy: fix TestDial failures on wasm/js
Modified `TestDial` to emulate `internal/socks/dial_test.go` and leverage `nettest#NetLocalListener()` while also honoring the returned `net.Listener` address. It seems that the wasm/js runtime doesn't like dialing addresses with no host. Fixes golang/go#32842 Change-Id: I1915f2ebac773f24a5b37ab7c09a52137abe758d GitHub-Last-Rev: 8f2967f GitHub-Pull-Request: golang#45 Reviewed-on: https://go-review.googlesource.com/c/net/+/184178 Reviewed-by: Bryan C. Mills <[email protected]> Run-TryBot: Bryan C. Mills <[email protected]> TryBot-Result: Gobot Gobot <[email protected]>
1 parent 3b0461e commit da137c7

File tree

1 file changed

+7
-19
lines changed

1 file changed

+7
-19
lines changed

proxy/dial_test.go

+7-19
Original file line numberDiff line numberDiff line change
@@ -7,69 +7,57 @@ package proxy
77
import (
88
"context"
99
"fmt"
10-
"net"
1110
"os"
1211
"testing"
1312
"time"
1413

1514
"golang.org/x/net/internal/sockstest"
15+
"golang.org/x/net/nettest"
1616
)
1717

1818
func TestDial(t *testing.T) {
1919
ResetProxyEnv()
2020
t.Run("DirectWithCancel", func(t *testing.T) {
2121
defer ResetProxyEnv()
22-
l, err := net.Listen("tcp", "127.0.0.1:0")
22+
l, err := nettest.NewLocalListener("tcp")
2323
if err != nil {
2424
t.Fatal(err)
2525
}
2626
defer l.Close()
27-
_, port, err := net.SplitHostPort(l.Addr().String())
28-
if err != nil {
29-
t.Fatal(err)
30-
}
3127
ctx, cancel := context.WithCancel(context.Background())
3228
defer cancel()
33-
c, err := Dial(ctx, l.Addr().Network(), net.JoinHostPort("", port))
29+
c, err := Dial(ctx, l.Addr().Network(), l.Addr().String())
3430
if err != nil {
3531
t.Fatal(err)
3632
}
3733
c.Close()
3834
})
3935
t.Run("DirectWithTimeout", func(t *testing.T) {
4036
defer ResetProxyEnv()
41-
l, err := net.Listen("tcp", "127.0.0.1:0")
37+
l, err := nettest.NewLocalListener("tcp")
4238
if err != nil {
4339
t.Fatal(err)
4440
}
4541
defer l.Close()
46-
_, port, err := net.SplitHostPort(l.Addr().String())
47-
if err != nil {
48-
t.Fatal(err)
49-
}
5042
ctx, cancel := context.WithTimeout(context.Background(), 5*time.Second)
5143
defer cancel()
52-
c, err := Dial(ctx, l.Addr().Network(), net.JoinHostPort("", port))
44+
c, err := Dial(ctx, l.Addr().Network(), l.Addr().String())
5345
if err != nil {
5446
t.Fatal(err)
5547
}
5648
c.Close()
5749
})
5850
t.Run("DirectWithTimeoutExceeded", func(t *testing.T) {
5951
defer ResetProxyEnv()
60-
l, err := net.Listen("tcp", "127.0.0.1:0")
52+
l, err := nettest.NewLocalListener("tcp")
6153
if err != nil {
6254
t.Fatal(err)
6355
}
6456
defer l.Close()
65-
_, port, err := net.SplitHostPort(l.Addr().String())
66-
if err != nil {
67-
t.Fatal(err)
68-
}
6957
ctx, cancel := context.WithTimeout(context.Background(), time.Nanosecond)
7058
time.Sleep(time.Millisecond)
7159
defer cancel()
72-
c, err := Dial(ctx, l.Addr().Network(), net.JoinHostPort("", port))
60+
c, err := Dial(ctx, l.Addr().Network(), l.Addr().String())
7361
if err == nil {
7462
defer c.Close()
7563
t.Fatal("failed to timeout")

0 commit comments

Comments
 (0)