mirror of
https://github.com/soheilhy/cmux.git
synced 2025-01-19 03:06:07 +08:00
Return an error in Accept() when root is closed.
As reported in #4, when the root listener is closed, calling Accept
on mux'd listeners would block forever, instead of returning an error.
This is because of a bug introduced in b90740d
.
This commit fixes #4 by selecting on both donec and connc of muxed
listeners.
Added a test case to guard against this issue.
This commit is contained in:
parent
44439c27f0
commit
89dd8ce1fd
7
cmux.go
7
cmux.go
@ -158,11 +158,12 @@ type muxListener struct {
|
||||
}
|
||||
|
||||
func (l muxListener) Accept() (c net.Conn, err error) {
|
||||
c, ok := <-l.connc
|
||||
if !ok {
|
||||
select {
|
||||
case c = <-l.connc:
|
||||
return c, nil
|
||||
case <-l.donec:
|
||||
return nil, ErrListenerClosed
|
||||
}
|
||||
return c, nil
|
||||
}
|
||||
|
||||
type MuxConn struct {
|
||||
|
@ -180,4 +180,8 @@ func TestClosed(t *testing.T) {
|
||||
lis := mux.Match(Any()).(muxListener)
|
||||
close(lis.donec)
|
||||
mux.serve(closerConn{})
|
||||
_, err := lis.Accept()
|
||||
if _, ok := err.(errListenerClosed); !ok {
|
||||
t.Errorf("expected errListenerClosed got %v", err)
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user