mirror of https://github.com/v2ray/v2ray-core
fix websocket conn reuse
parent
9a7d389f15
commit
5684beed8c
|
@ -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
|
||||||
}
|
}
|
||||||
|
|
|
@ -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) {
|
||||||
|
|
Loading…
Reference in New Issue