mirror of
https://github.com/soheilhy/cmux.git
synced 2025-01-19 03:06:07 +08:00
Merge pull request #16 from soheilhy/devel
Close the connections buffered for the listeners
This commit is contained in:
commit
1a2fcbde3a
12
cmux.go
12
cmux.go
@ -98,6 +98,10 @@ func (m *cMux) Serve() error {
|
|||||||
|
|
||||||
for _, sl := range m.sls {
|
for _, sl := range m.sls {
|
||||||
close(sl.l.connc)
|
close(sl.l.connc)
|
||||||
|
// Drain the connections enqueued for the listener.
|
||||||
|
for c := range sl.l.connc {
|
||||||
|
_ = c.Close()
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}()
|
}()
|
||||||
|
|
||||||
@ -126,12 +130,8 @@ func (m *cMux) serve(c net.Conn, donec <-chan struct{}, wg *sync.WaitGroup) {
|
|||||||
if matched {
|
if matched {
|
||||||
select {
|
select {
|
||||||
case sl.l.connc <- muc:
|
case sl.l.connc <- muc:
|
||||||
default:
|
case <-donec:
|
||||||
select {
|
_ = c.Close()
|
||||||
case <-donec:
|
|
||||||
_ = c.Close()
|
|
||||||
default:
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
27
cmux_test.go
27
cmux_test.go
@ -262,17 +262,17 @@ func TestHTTP2(t *testing.T) {
|
|||||||
})
|
})
|
||||||
h2l := muxl.Match(HTTP2())
|
h2l := muxl.Match(HTTP2())
|
||||||
go safeServe(errCh, muxl)
|
go safeServe(errCh, muxl)
|
||||||
|
muxedConn, err := h2l.Accept()
|
||||||
close(l.connCh)
|
close(l.connCh)
|
||||||
if muxedConn, err := h2l.Accept(); err != nil {
|
if err != nil {
|
||||||
t.Fatal(err)
|
t.Fatal(err)
|
||||||
} else {
|
}
|
||||||
var b [len(http2.ClientPreface)]byte
|
var b [len(http2.ClientPreface)]byte
|
||||||
if _, err := muxedConn.Read(b[:]); err != io.EOF {
|
if _, err := muxedConn.Read(b[:]); err != io.EOF {
|
||||||
t.Fatal(err)
|
t.Fatal(err)
|
||||||
}
|
}
|
||||||
if string(b[:]) != http2.ClientPreface {
|
if string(b[:]) != http2.ClientPreface {
|
||||||
t.Errorf("got unexpected read %s, expected %s", b, http2.ClientPreface)
|
t.Errorf("got unexpected read %s, expected %s", b, http2.ClientPreface)
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -374,9 +374,14 @@ func TestClose(t *testing.T) {
|
|||||||
// Listener is closed.
|
// Listener is closed.
|
||||||
close(l.connCh)
|
close(l.connCh)
|
||||||
|
|
||||||
// Second connection goes through.
|
// Second connection either goes through or it is closed.
|
||||||
if _, err := anyl.Accept(); err != nil {
|
if _, err := anyl.Accept(); err != nil {
|
||||||
t.Fatal(err)
|
if err != ErrListenerClosed {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
if _, err := c2.Read([]byte{}); err != io.ErrClosedPipe {
|
||||||
|
t.Fatalf("connection is not closed and is leaked: %v", err)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user