forked from go-mysql-org/go-mysql
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathmockconn.go
77 lines (58 loc) · 1.53 KB
/
mockconn.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
package conn
import (
"errors"
"net"
"time"
)
type mockAddr struct{}
func (m mockAddr) String() string { return "mocking" }
func (m mockAddr) Network() string { return "mocking" }
// MockConn is a simple struct implementing net.Conn that allows us to read what
// was written to it and feed data it will read from
type MockConn struct {
readResponses [][]byte
WriteBuffered []byte
Closed bool
MultiWrite bool
}
func (m *MockConn) SetResponse(r [][]byte) {
m.readResponses = r
}
func (m *MockConn) Read(p []byte) (n int, err error) {
if m.Closed {
return -1, errors.New("connection closed")
}
if len(m.readResponses) == 0 {
return -1, errors.New("no response left")
}
copy(p, m.readResponses[0])
m.readResponses = m.readResponses[1:]
return len(p), nil
}
func (m *MockConn) Write(p []byte) (n int, err error) {
if m.Closed {
return -1, errors.New("connection closed")
}
if m.MultiWrite {
m.WriteBuffered = append(m.WriteBuffered, p...)
} else {
m.WriteBuffered = make([]byte, len(p))
copy(m.WriteBuffered, p)
}
return len(p), nil
}
func (m MockConn) LocalAddr() net.Addr { return mockAddr{} }
func (m MockConn) RemoteAddr() net.Addr { return mockAddr{} }
func (m *MockConn) Close() error {
m.Closed = true
return nil
}
func (m MockConn) SetDeadline(t time.Time) error {
return errors.New("not implemented")
}
func (m MockConn) SetReadDeadline(t time.Time) error {
return errors.New("not implemented")
}
func (m MockConn) SetWriteDeadline(t time.Time) error {
return errors.New("not implemented")
}