Commit 8c2b131c authored by Dave Cheney's avatar Dave Cheney

net: return error from pollster rather than panicing

Fixes #3590.

R=bradfitz, mikioh.mikioh, iant, bsiegert
CC=golang-dev
https://golang.org/cl/6684054
parent 75657268
...@@ -97,15 +97,11 @@ func (s *pollServer) AddFD(fd *netFD, mode int) error { ...@@ -97,15 +97,11 @@ func (s *pollServer) AddFD(fd *netFD, mode int) error {
} }
wake, err := s.poll.AddFD(intfd, mode, false) wake, err := s.poll.AddFD(intfd, mode, false)
s.Unlock()
if err != nil { if err != nil {
panic("pollServer AddFD " + err.Error()) return &OpError{"addfd", fd.net, fd.laddr, err}
}
if wake {
doWakeup = true
} }
s.Unlock() if wake || doWakeup {
if doWakeup {
s.Wakeup() s.Wakeup()
} }
return nil return nil
......
// Copyright 2012 The Go Authors. All rights reserved.
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
// +build darwin freebsd linux netbsd openbsd
package net
import (
"testing"
)
// Issue 3590. netFd.AddFD should return an error
// from the underlying pollster rather than panicing.
func TestAddFDReturnsError(t *testing.T) {
l, err := Listen("tcp", "127.0.0.1:0")
if err != nil {
t.Fatal(err)
}
defer l.Close()
go func() {
for {
c, err := l.Accept()
if err != nil {
return
}
defer c.Close()
}
}()
c, err := Dial("tcp", l.Addr().String())
if err != nil {
t.Fatal(err)
}
defer c.Close()
// replace c's pollServer with a closed version.
ps, err := newPollServer()
if err != nil {
t.Fatal(err)
}
ps.poll.Close()
c.(*TCPConn).conn.fd.pollServer = ps
var b [1]byte
_, err = c.Read(b[:])
if err, ok := err.(*OpError); ok {
if err.Op == "addfd" {
return
}
if err, ok := err.Err.(*OpError); ok {
// the err is sometimes wrapped by another OpError
if err.Op == "addfd" {
return
}
}
}
t.Error(err)
}
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment