forked from apache/cassandra-gocql-driver
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsession_connect_test.go
68 lines (59 loc) · 1.18 KB
/
session_connect_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
package gocql
import (
"net"
"strconv"
"sync"
)
type OneConnTestServer struct {
Err error
Addr net.IP
Port int
listener net.Listener
acceptChan chan struct{}
mu sync.Mutex
closed bool
}
func NewOneConnTestServer() (*OneConnTestServer, error) {
lstn, err := net.Listen("tcp4", "localhost:0")
if err != nil {
return nil, err
}
addr, port := parseAddressPort(lstn.Addr().String())
return &OneConnTestServer{
listener: lstn,
acceptChan: make(chan struct{}),
Addr: addr,
Port: port,
}, nil
}
func (c *OneConnTestServer) Accepted() chan struct{} {
return c.acceptChan
}
func (c *OneConnTestServer) Close() {
c.lockedClose()
}
func (c *OneConnTestServer) Serve() {
conn, err := c.listener.Accept()
c.Err = err
if conn != nil {
conn.Close()
}
c.lockedClose()
}
func (c *OneConnTestServer) lockedClose() {
c.mu.Lock()
defer c.mu.Unlock()
if !c.closed {
close(c.acceptChan)
c.listener.Close()
c.closed = true
}
}
func parseAddressPort(hostPort string) (net.IP, int) {
host, portStr, err := net.SplitHostPort(hostPort)
if err != nil {
return net.ParseIP(""), 0
}
port, _ := strconv.Atoi(portStr)
return net.ParseIP(host), port
}