blob: 608835b5c753c84d4058225e60123ddfecfaac84 [file] [log] [blame]
// 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"
"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 := nettest.NewLocalListener("tcp")
if err != nil {
t.Fatal(err)
}
defer l.Close()
ctx, cancel := context.WithCancel(context.Background())
defer cancel()
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 := nettest.NewLocalListener("tcp")
if err != nil {
t.Fatal(err)
}
defer l.Close()
ctx, cancel := context.WithTimeout(context.Background(), 5*time.Second)
defer cancel()
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 := nettest.NewLocalListener("tcp")
if err != nil {
t.Fatal(err)
}
defer l.Close()
ctx, cancel := context.WithTimeout(context.Background(), time.Nanosecond)
time.Sleep(time.Millisecond)
defer cancel()
c, err := Dial(ctx, l.Addr().Network(), l.Addr().String())
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")
}
})
}