mirror of
https://github.com/golang/net.git
synced 2026-03-31 18:37:08 +09:00
The existing API does not allow client code to take advantage of Dialer implementations that implement DialContext receivers. This a familiar API, see net.Dialer.
Fixes golang/go#27874
Fixes golang/go#19354
Fixes golang/go#17759
Fixes golang/go#13455
Change-Id: I0f247783d2037da28c9917db99adda51db1647bd
GitHub-Last-Rev: b0a372707f
GitHub-Pull-Request: golang/net#38
Reviewed-on: https://go-review.googlesource.com/c/net/+/168921
Reviewed-by: Brad Fitzpatrick <bradfitz@golang.org>
Run-TryBot: Brad Fitzpatrick <bradfitz@golang.org>
TryBot-Result: Gobot Gobot <gobot@golang.org>
132 lines
3.4 KiB
Go
132 lines
3.4 KiB
Go
// Copyright 2019 The Go Authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style
|
|
// license that can be found in the LICENSE file.
|
|
|
|
package proxy
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
"net"
|
|
"os"
|
|
"testing"
|
|
"time"
|
|
|
|
"golang.org/x/net/internal/sockstest"
|
|
)
|
|
|
|
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")
|
|
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))
|
|
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")
|
|
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))
|
|
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")
|
|
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))
|
|
if err == nil {
|
|
defer c.Close()
|
|
t.Fatal("failed to timeout")
|
|
}
|
|
})
|
|
t.Run("SOCKS5", func(t *testing.T) {
|
|
defer ResetProxyEnv()
|
|
s, err := sockstest.NewServer(sockstest.NoAuthRequired, sockstest.NoProxyRequired)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
defer s.Close()
|
|
if err = os.Setenv("ALL_PROXY", fmt.Sprintf("socks5://%s", s.Addr().String())); err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
c, err := Dial(context.Background(), s.TargetAddr().Network(), s.TargetAddr().String())
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
c.Close()
|
|
})
|
|
t.Run("SOCKS5WithTimeout", func(t *testing.T) {
|
|
defer ResetProxyEnv()
|
|
s, err := sockstest.NewServer(sockstest.NoAuthRequired, sockstest.NoProxyRequired)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
defer s.Close()
|
|
if err = os.Setenv("ALL_PROXY", fmt.Sprintf("socks5://%s", s.Addr().String())); err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
ctx, cancel := context.WithTimeout(context.Background(), 5*time.Second)
|
|
defer cancel()
|
|
c, err := Dial(ctx, s.TargetAddr().Network(), s.TargetAddr().String())
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
c.Close()
|
|
})
|
|
t.Run("SOCKS5WithTimeoutExceeded", func(t *testing.T) {
|
|
defer ResetProxyEnv()
|
|
s, err := sockstest.NewServer(sockstest.NoAuthRequired, sockstest.NoProxyRequired)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
defer s.Close()
|
|
if err = os.Setenv("ALL_PROXY", fmt.Sprintf("socks5://%s", s.Addr().String())); err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
ctx, cancel := context.WithTimeout(context.Background(), time.Nanosecond)
|
|
time.Sleep(time.Millisecond)
|
|
defer cancel()
|
|
c, err := Dial(ctx, s.TargetAddr().Network(), s.TargetAddr().String())
|
|
if err == nil {
|
|
defer c.Close()
|
|
t.Fatal("failed to timeout")
|
|
}
|
|
})
|
|
}
|