Add IRC client connection tests
This commit is contained in:
parent
c78ca7318c
commit
4f0ad5e6d9
@ -89,6 +89,7 @@ func (c *Client) Quit() {
|
|||||||
c.write("QUIT")
|
c.write("QUIT")
|
||||||
}
|
}
|
||||||
close(c.quit)
|
close(c.quit)
|
||||||
|
c.conn.Close()
|
||||||
}()
|
}()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -10,6 +10,17 @@ import (
|
|||||||
var c *Client
|
var c *Client
|
||||||
var conn *mockConn
|
var conn *mockConn
|
||||||
|
|
||||||
|
func init() {
|
||||||
|
initTestClient()
|
||||||
|
}
|
||||||
|
|
||||||
|
func initTestClient() {
|
||||||
|
c = NewClient("test", "testing")
|
||||||
|
conn = &mockConn{hook: make(chan string, 1)}
|
||||||
|
c.conn = conn
|
||||||
|
go c.send()
|
||||||
|
}
|
||||||
|
|
||||||
type mockConn struct {
|
type mockConn struct {
|
||||||
hook chan string
|
hook chan string
|
||||||
net.Conn
|
net.Conn
|
||||||
@ -20,15 +31,8 @@ func (c *mockConn) Write(b []byte) (int, error) {
|
|||||||
return len(b), nil
|
return len(b), nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func init() {
|
func (c *mockConn) Close() error {
|
||||||
initTestClient()
|
return nil
|
||||||
}
|
|
||||||
|
|
||||||
func initTestClient() {
|
|
||||||
c = NewClient("test", "testing")
|
|
||||||
conn = &mockConn{hook: make(chan string, 1)}
|
|
||||||
c.conn = conn
|
|
||||||
go c.send()
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestPass(t *testing.T) {
|
func TestPass(t *testing.T) {
|
||||||
|
@ -145,14 +145,13 @@ func (c *Client) recv() {
|
|||||||
c.connected = false
|
c.connected = false
|
||||||
c.lock.Unlock()
|
c.lock.Unlock()
|
||||||
c.once.Do(c.ready.Done)
|
c.once.Do(c.ready.Done)
|
||||||
close(c.reconnect)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
select {
|
select {
|
||||||
case <-c.quit:
|
case <-c.quit:
|
||||||
return
|
return
|
||||||
default:
|
default:
|
||||||
|
close(c.reconnect)
|
||||||
|
return
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
msg := parseMessage(line)
|
msg := parseMessage(line)
|
||||||
|
110
irc/conn_test.go
110
irc/conn_test.go
@ -1,11 +1,82 @@
|
|||||||
package irc
|
package irc
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"log"
|
||||||
|
"net"
|
||||||
"testing"
|
"testing"
|
||||||
|
"time"
|
||||||
|
|
||||||
"github.com/khlieng/name_pending/Godeps/_workspace/src/github.com/stretchr/testify/assert"
|
"github.com/khlieng/name_pending/Godeps/_workspace/src/github.com/stretchr/testify/assert"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
var ircd *mockIrcd
|
||||||
|
|
||||||
|
func init() {
|
||||||
|
initTestServer()
|
||||||
|
}
|
||||||
|
|
||||||
|
func initTestServer() {
|
||||||
|
ircd = &mockIrcd{
|
||||||
|
conn: make(chan bool, 1),
|
||||||
|
connClosed: make(chan bool, 1),
|
||||||
|
}
|
||||||
|
ircd.start()
|
||||||
|
}
|
||||||
|
|
||||||
|
type mockIrcd struct {
|
||||||
|
conn chan bool
|
||||||
|
connClosed chan bool
|
||||||
|
}
|
||||||
|
|
||||||
|
func (i *mockIrcd) start() {
|
||||||
|
ln, err := net.Listen("tcp", ":45678")
|
||||||
|
if err != nil {
|
||||||
|
log.Fatal(err)
|
||||||
|
}
|
||||||
|
go i.accept(ln)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (i *mockIrcd) accept(ln net.Listener) {
|
||||||
|
for {
|
||||||
|
conn, err := ln.Accept()
|
||||||
|
if err != nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
go i.handle(conn)
|
||||||
|
i.conn <- true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (i *mockIrcd) handle(conn net.Conn) {
|
||||||
|
buf := make([]byte, 1024)
|
||||||
|
for {
|
||||||
|
_, err := conn.Read(buf)
|
||||||
|
if err != nil {
|
||||||
|
i.connClosed <- true
|
||||||
|
return
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestConnect(t *testing.T) {
|
||||||
|
c.Connect("127.0.0.1:45678")
|
||||||
|
assert.Equal(t, c.Host, "127.0.0.1")
|
||||||
|
assert.Equal(t, c.Server, "127.0.0.1:45678")
|
||||||
|
waitConnAndClose(t)
|
||||||
|
initTestClient()
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestConnectDefaultPorts(t *testing.T) {
|
||||||
|
c.Connect("127.0.0.1")
|
||||||
|
assert.Equal(t, "127.0.0.1:6667", c.Server)
|
||||||
|
initTestClient()
|
||||||
|
|
||||||
|
c.TLS = true
|
||||||
|
c.Connect("127.0.0.1")
|
||||||
|
assert.Equal(t, "127.0.0.1:6697", c.Server)
|
||||||
|
initTestClient()
|
||||||
|
}
|
||||||
|
|
||||||
func TestWrite(t *testing.T) {
|
func TestWrite(t *testing.T) {
|
||||||
c.write("test")
|
c.write("test")
|
||||||
assert.Equal(t, "test\r\n", <-conn.hook)
|
assert.Equal(t, "test\r\n", <-conn.hook)
|
||||||
@ -16,3 +87,42 @@ func TestWrite(t *testing.T) {
|
|||||||
c.Writef("test %d", 2)
|
c.Writef("test %d", 2)
|
||||||
assert.Equal(t, "test 2\r\n", <-conn.hook)
|
assert.Equal(t, "test 2\r\n", <-conn.hook)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestClose(t *testing.T) {
|
||||||
|
defer initTestClient()
|
||||||
|
c.close()
|
||||||
|
ok := false
|
||||||
|
done := make(chan struct{})
|
||||||
|
go func() {
|
||||||
|
_, ok = <-c.out
|
||||||
|
_, ok = <-c.Messages
|
||||||
|
close(done)
|
||||||
|
}()
|
||||||
|
|
||||||
|
select {
|
||||||
|
case <-done:
|
||||||
|
assert.False(t, ok)
|
||||||
|
return
|
||||||
|
|
||||||
|
case <-time.After(100 * time.Millisecond):
|
||||||
|
t.Error("Channels not closed")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func waitConnAndClose(t *testing.T) {
|
||||||
|
done := make(chan struct{})
|
||||||
|
go func() {
|
||||||
|
<-ircd.conn
|
||||||
|
c.Quit()
|
||||||
|
<-ircd.connClosed
|
||||||
|
close(done)
|
||||||
|
}()
|
||||||
|
|
||||||
|
select {
|
||||||
|
case <-done:
|
||||||
|
return
|
||||||
|
|
||||||
|
case <-time.After(500 * time.Millisecond):
|
||||||
|
t.Error("Took too long")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user