-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathassociate_test.go
109 lines (98 loc) · 2.22 KB
/
associate_test.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
package socks5
import (
"bytes"
"fmt"
"log"
"net"
"os"
"strconv"
"sync"
"testing"
"time"
)
func TestSOCKS5_Associate(t *testing.T) {
// Create a udp listener
udpAddr, _ := net.ResolveUDPAddr("udp", "127.0.0.1:8888")
l, err := net.ListenUDP("udp", udpAddr)
if err != nil {
t.Fatalf("err: %v", err)
}
defer l.Close()
errCh := make(chan error, 1)
go func() {
var buf [1024]byte
for {
n, from, err := l.ReadFromUDP(buf[:])
if err != nil {
errCh <- fmt.Errorf("err: %v", err)
break
}
if i := bytes.Index(buf[:n], []byte("ping")); i == -1 {
errCh <- fmt.Errorf("bad: %v", buf)
} else {
idx, _ := strconv.Atoi(string(buf[4:n]))
msg := fmt.Sprintf("pong%v", idx)
fmt.Printf("@@@ response udp read %v, echo %v @@@\n", string(buf[:n]), msg)
l.WriteToUDP([]byte(msg), from)
}
}
}()
// Create a socks server
creds := StaticCredentials{
"foo": "bar",
}
cator := UserPassAuthenticator{Credentials: creds}
conf := &Config{
AuthMethods: []Authenticator{cator},
BindIP: net.ParseIP("127.0.0.1"),
Logger: log.New(os.Stdout, "", log.LstdFlags),
}
serv, err := New(conf)
if err != nil {
t.Fatalf("err: %v", err)
}
// Start listening
go func() {
if err := serv.ListenAndServe("tcp", "127.0.0.1:12366"); err != nil {
errCh <- fmt.Errorf("err: %v", err)
}
}()
time.Sleep(10 * time.Millisecond)
// 10 task
n := 10
var wg = sync.WaitGroup{}
for ; n > 0; n-- {
wg.Add(1)
go func(i int) {
defer wg.Done()
s5, err := NewClient("127.0.0.1:12366", "foo", "bar", 0, 0)
if err != nil {
errCh <- fmt.Errorf("NewClient err: %v", err)
return
}
conn, err := s5.Dial("udp", "127.0.0.1:8888")
if err != nil {
errCh <- fmt.Errorf("NewClient err: %v", err)
return
}
defer conn.Close()
var buf [1024]byte
msg := fmt.Sprintf("ping%v", i)
_, err = conn.Write([]byte(msg))
if err != nil {
errCh <- fmt.Errorf("conn.Write err: %v", err)
return
}
l, _ := conn.Read(buf[:])
fmt.Printf("### response len %v: %v ###\n", l, string(buf[:l]))
}(n)
}
wg.Wait()
// Check for any errors from the goroutines
select {
case err := <-errCh:
t.Fatalf("Error in goroutine: %v", err)
default:
// No errors, continue
}
}