2
0
mirror of https://github.com/soheilhy/cmux.git synced 2025-01-18 18:56:26 +08:00

Merge pull request #16 from soheilhy/devel

Close the connections buffered for the listeners
This commit is contained in:
Soheil Hassas Yeganeh 2016-02-23 23:05:27 -05:00
commit 1a2fcbde3a
2 changed files with 22 additions and 17 deletions

12
cmux.go
View File

@ -98,6 +98,10 @@ func (m *cMux) Serve() error {
for _, sl := range m.sls {
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 {
select {
case sl.l.connc <- muc:
default:
select {
case <-donec:
_ = c.Close()
default:
}
case <-donec:
_ = c.Close()
}
return
}

View File

@ -262,17 +262,17 @@ func TestHTTP2(t *testing.T) {
})
h2l := muxl.Match(HTTP2())
go safeServe(errCh, muxl)
muxedConn, err := h2l.Accept()
close(l.connCh)
if muxedConn, err := h2l.Accept(); err != nil {
if err != nil {
t.Fatal(err)
} else {
var b [len(http2.ClientPreface)]byte
if _, err := muxedConn.Read(b[:]); err != io.EOF {
t.Fatal(err)
}
if string(b[:]) != http2.ClientPreface {
t.Errorf("got unexpected read %s, expected %s", b, http2.ClientPreface)
}
}
var b [len(http2.ClientPreface)]byte
if _, err := muxedConn.Read(b[:]); err != io.EOF {
t.Fatal(err)
}
if string(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.
close(l.connCh)
// Second connection goes through.
// Second connection either goes through or it is closed.
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)
}
}
}