fix websocket conn reuse

pull/362/head
Darien Raymond 2017-01-04 15:34:11 +01:00
parent 9a7d389f15
commit 5684beed8c
No known key found for this signature in database
GPG Key ID: 7251FFA14BB18169
2 changed files with 47 additions and 14 deletions

View File

@ -7,7 +7,7 @@ import (
func (c *Config) IsConnectionReuse() bool { func (c *Config) IsConnectionReuse() bool {
if c == nil || c.ConnectionReuse == nil { if c == nil || c.ConnectionReuse == nil {
return false return true
} }
return c.ConnectionReuse.Enable return c.ConnectionReuse.Enable
} }

View File

@ -7,6 +7,8 @@ import (
"testing" "testing"
"time" "time"
"bytes"
v2net "v2ray.com/core/common/net" v2net "v2ray.com/core/common/net"
"v2ray.com/core/common/serial" "v2ray.com/core/common/serial"
"v2ray.com/core/testing/assert" "v2ray.com/core/testing/assert"
@ -32,16 +34,27 @@ func Test_listenWSAndDial(t *testing.T) {
}) })
assert.Error(err).IsNil() assert.Error(err).IsNil()
go func() { go func() {
conn, err := listen.Accept() for {
assert.Error(err).IsNil() conn, err := listen.Accept()
conn.Close() if err != nil {
conn, err = listen.Accept() break
assert.Error(err).IsNil() }
conn.Close() go func() {
conn, err = listen.Accept() defer conn.Close()
assert.Error(err).IsNil()
conn.Close() var b [1024]byte
listen.Close() n, err := conn.Read(b[:])
//assert.Error(err).IsNil()
if err != nil {
conn.SetReusable(false)
return
}
assert.Bool(bytes.HasPrefix(b[:n], []byte("Test connection"))).IsTrue()
_, err = conn.Write([]byte("Response"))
assert.Error(err).IsNil()
}()
}
}() }()
conn, err := Dial(v2net.AnyIP, v2net.TCPDestination(v2net.DomainAddress("localhost"), 13146), internet.DialerOptions{ conn, err := Dial(v2net.AnyIP, v2net.TCPDestination(v2net.DomainAddress("localhost"), 13146), internet.DialerOptions{
Stream: &internet.StreamConfig{ Stream: &internet.StreamConfig{
@ -57,7 +70,15 @@ func Test_listenWSAndDial(t *testing.T) {
}, },
}) })
assert.Error(err).IsNil() assert.Error(err).IsNil()
conn.Close() _, err = conn.Write([]byte("Test connection 1"))
assert.Error(err).IsNil()
var b [1024]byte
n, err := conn.Read(b[:])
assert.Error(err).IsNil()
assert.String(string(b[:n])).Equals("Response")
assert.Error(conn.Close()).IsNil()
<-time.After(time.Second * 5) <-time.After(time.Second * 5)
conn, err = Dial(v2net.AnyIP, v2net.TCPDestination(v2net.DomainAddress("localhost"), 13146), internet.DialerOptions{ conn, err = Dial(v2net.AnyIP, v2net.TCPDestination(v2net.DomainAddress("localhost"), 13146), internet.DialerOptions{
Stream: &internet.StreamConfig{ Stream: &internet.StreamConfig{
@ -73,7 +94,12 @@ func Test_listenWSAndDial(t *testing.T) {
}, },
}) })
assert.Error(err).IsNil() assert.Error(err).IsNil()
conn.Close() _, err = conn.Write([]byte("Test connection 2"))
assert.Error(err).IsNil()
n, err = conn.Read(b[:])
assert.Error(err).IsNil()
assert.String(string(b[:n])).Equals("Response")
assert.Error(conn.Close()).IsNil()
<-time.After(time.Second * 15) <-time.After(time.Second * 15)
conn, err = Dial(v2net.AnyIP, v2net.TCPDestination(v2net.DomainAddress("localhost"), 13146), internet.DialerOptions{ conn, err = Dial(v2net.AnyIP, v2net.TCPDestination(v2net.DomainAddress("localhost"), 13146), internet.DialerOptions{
Stream: &internet.StreamConfig{ Stream: &internet.StreamConfig{
@ -89,7 +115,14 @@ func Test_listenWSAndDial(t *testing.T) {
}, },
}) })
assert.Error(err).IsNil() assert.Error(err).IsNil()
conn.Close() _, err = conn.Write([]byte("Test connection 3"))
assert.Error(err).IsNil()
n, err = conn.Read(b[:])
assert.Error(err).IsNil()
assert.String(string(b[:n])).Equals("Response")
assert.Error(conn.Close()).IsNil()
assert.Error(listen.Close()).IsNil()
} }
func Test_listenWSAndDial_TLS(t *testing.T) { func Test_listenWSAndDial_TLS(t *testing.T) {