Skip to content

Commit

Permalink
proxy: fix TestDial failures on wasm/js
Browse files Browse the repository at this point in the history
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: #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]>
  • Loading branch information
dweomer authored and Bryan C. Mills committed Jun 28, 2019
1 parent 3b0461e commit da137c7
Showing 1 changed file with 7 additions and 19 deletions.
26 changes: 7 additions & 19 deletions proxy/dial_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -7,69 +7,57 @@ package proxy
import (
"context"
"fmt"
"net"
"os"
"testing"
"time"

"golang.org/x/net/internal/sockstest"
"golang.org/x/net/nettest"
)

func TestDial(t *testing.T) {
ResetProxyEnv()
t.Run("DirectWithCancel", func(t *testing.T) {
defer ResetProxyEnv()
l, err := net.Listen("tcp", "127.0.0.1:0")
l, err := nettest.NewLocalListener("tcp")
if err != nil {
t.Fatal(err)
}
defer l.Close()
_, port, err := net.SplitHostPort(l.Addr().String())
if err != nil {
t.Fatal(err)
}
ctx, cancel := context.WithCancel(context.Background())
defer cancel()
c, err := Dial(ctx, l.Addr().Network(), net.JoinHostPort("", port))
c, err := Dial(ctx, l.Addr().Network(), l.Addr().String())
if err != nil {
t.Fatal(err)
}
c.Close()
})
t.Run("DirectWithTimeout", func(t *testing.T) {
defer ResetProxyEnv()
l, err := net.Listen("tcp", "127.0.0.1:0")
l, err := nettest.NewLocalListener("tcp")
if err != nil {
t.Fatal(err)
}
defer l.Close()
_, port, err := net.SplitHostPort(l.Addr().String())
if err != nil {
t.Fatal(err)
}
ctx, cancel := context.WithTimeout(context.Background(), 5*time.Second)
defer cancel()
c, err := Dial(ctx, l.Addr().Network(), net.JoinHostPort("", port))
c, err := Dial(ctx, l.Addr().Network(), l.Addr().String())
if err != nil {
t.Fatal(err)
}
c.Close()
})
t.Run("DirectWithTimeoutExceeded", func(t *testing.T) {
defer ResetProxyEnv()
l, err := net.Listen("tcp", "127.0.0.1:0")
l, err := nettest.NewLocalListener("tcp")
if err != nil {
t.Fatal(err)
}
defer l.Close()
_, port, err := net.SplitHostPort(l.Addr().String())
if err != nil {
t.Fatal(err)
}
ctx, cancel := context.WithTimeout(context.Background(), time.Nanosecond)
time.Sleep(time.Millisecond)
defer cancel()
c, err := Dial(ctx, l.Addr().Network(), net.JoinHostPort("", port))
c, err := Dial(ctx, l.Addr().Network(), l.Addr().String())
if err == nil {
defer c.Close()
t.Fatal("failed to timeout")
Expand Down

0 comments on commit da137c7

Please sign in to comment.