|
|
@@ -5,14 +5,73 @@
|
|
|
package proxy
|
|
|
|
|
|
import (
|
|
|
+ "bytes"
|
|
|
+ "fmt"
|
|
|
"io"
|
|
|
"net"
|
|
|
"net/url"
|
|
|
+ "os"
|
|
|
"strconv"
|
|
|
+ "strings"
|
|
|
"sync"
|
|
|
"testing"
|
|
|
)
|
|
|
|
|
|
+type proxyFromEnvTest struct {
|
|
|
+ allProxyEnv string
|
|
|
+ noProxyEnv string
|
|
|
+ wantTypeOf Dialer
|
|
|
+}
|
|
|
+
|
|
|
+func (t proxyFromEnvTest) String() string {
|
|
|
+ var buf bytes.Buffer
|
|
|
+ space := func() {
|
|
|
+ if buf.Len() > 0 {
|
|
|
+ buf.WriteByte(' ')
|
|
|
+ }
|
|
|
+ }
|
|
|
+ if t.allProxyEnv != "" {
|
|
|
+ fmt.Fprintf(&buf, "all_proxy=%q", t.allProxyEnv)
|
|
|
+ }
|
|
|
+ if t.noProxyEnv != "" {
|
|
|
+ space()
|
|
|
+ fmt.Fprintf(&buf, "no_proxy=%q", t.noProxyEnv)
|
|
|
+ }
|
|
|
+ return strings.TrimSpace(buf.String())
|
|
|
+}
|
|
|
+
|
|
|
+func TestFromEnvironment(t *testing.T) {
|
|
|
+ ResetProxyEnv()
|
|
|
+
|
|
|
+ type dummyDialer struct {
|
|
|
+ direct
|
|
|
+ }
|
|
|
+
|
|
|
+ RegisterDialerType("irc", func(_ *url.URL, _ Dialer) (Dialer, error) {
|
|
|
+ return dummyDialer{}, nil
|
|
|
+ })
|
|
|
+
|
|
|
+ proxyFromEnvTests := []proxyFromEnvTest{
|
|
|
+ {allProxyEnv: "127.0.0.1:8080", noProxyEnv: "localhost, 127.0.0.1", wantTypeOf: direct{}},
|
|
|
+ {allProxyEnv: "ftp://example.com:8000", noProxyEnv: "localhost, 127.0.0.1", wantTypeOf: direct{}},
|
|
|
+ {allProxyEnv: "socks5://example.com:8080", noProxyEnv: "localhost, 127.0.0.1", wantTypeOf: &PerHost{}},
|
|
|
+ {allProxyEnv: "irc://example.com:8000", wantTypeOf: dummyDialer{}},
|
|
|
+ {noProxyEnv: "localhost, 127.0.0.1", wantTypeOf: direct{}},
|
|
|
+ {wantTypeOf: direct{}},
|
|
|
+ }
|
|
|
+
|
|
|
+ for _, tt := range proxyFromEnvTests {
|
|
|
+ os.Setenv("ALL_PROXY", tt.allProxyEnv)
|
|
|
+ os.Setenv("NO_PROXY", tt.noProxyEnv)
|
|
|
+ ResetCachedEnvironment()
|
|
|
+
|
|
|
+ d := FromEnvironment()
|
|
|
+ if got, want := fmt.Sprintf("%T", d), fmt.Sprintf("%T", tt.wantTypeOf); got != want {
|
|
|
+ t.Errorf("%v: got type = %T, want %T", tt, d, tt.wantTypeOf)
|
|
|
+ }
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
func TestFromURL(t *testing.T) {
|
|
|
endSystem, err := net.Listen("tcp", "127.0.0.1:0")
|
|
|
if err != nil {
|
|
|
@@ -140,3 +199,17 @@ func socks5Gateway(t *testing.T, gateway, endSystem net.Listener, typ byte, wg *
|
|
|
return
|
|
|
}
|
|
|
}
|
|
|
+
|
|
|
+func ResetProxyEnv() {
|
|
|
+ for _, env := range []*envOnce{allProxyEnv, noProxyEnv} {
|
|
|
+ for _, v := range env.names {
|
|
|
+ os.Setenv(v, "")
|
|
|
+ }
|
|
|
+ }
|
|
|
+ ResetCachedEnvironment()
|
|
|
+}
|
|
|
+
|
|
|
+func ResetCachedEnvironment() {
|
|
|
+ allProxyEnv.reset()
|
|
|
+ noProxyEnv.reset()
|
|
|
+}
|