Commit d4775a78 authored by Dave Cheney's avatar Dave Cheney

net/http/httptest: fix possible race on historyListener.history

R=golang-dev, bradfitz
CC=golang-dev
https://golang.org/cl/6845077
parent ec2460a3
...@@ -36,13 +36,16 @@ type Server struct { ...@@ -36,13 +36,16 @@ type Server struct {
// accepted. // accepted.
type historyListener struct { type historyListener struct {
net.Listener net.Listener
history []net.Conn sync.Mutex // protects history
history []net.Conn
} }
func (hs *historyListener) Accept() (c net.Conn, err error) { func (hs *historyListener) Accept() (c net.Conn, err error) {
c, err = hs.Listener.Accept() c, err = hs.Listener.Accept()
if err == nil { if err == nil {
hs.Lock()
hs.history = append(hs.history, c) hs.history = append(hs.history, c)
hs.Unlock()
} }
return return
} }
...@@ -96,7 +99,7 @@ func (s *Server) Start() { ...@@ -96,7 +99,7 @@ func (s *Server) Start() {
if s.URL != "" { if s.URL != "" {
panic("Server already started") panic("Server already started")
} }
s.Listener = &historyListener{s.Listener, make([]net.Conn, 0)} s.Listener = &historyListener{Listener: s.Listener}
s.URL = "http://" + s.Listener.Addr().String() s.URL = "http://" + s.Listener.Addr().String()
s.wrapHandler() s.wrapHandler()
go s.Config.Serve(s.Listener) go s.Config.Serve(s.Listener)
...@@ -122,7 +125,7 @@ func (s *Server) StartTLS() { ...@@ -122,7 +125,7 @@ func (s *Server) StartTLS() {
} }
tlsListener := tls.NewListener(s.Listener, s.TLS) tlsListener := tls.NewListener(s.Listener, s.TLS)
s.Listener = &historyListener{tlsListener, make([]net.Conn, 0)} s.Listener = &historyListener{Listener: tlsListener}
s.URL = "https://" + s.Listener.Addr().String() s.URL = "https://" + s.Listener.Addr().String()
s.wrapHandler() s.wrapHandler()
go s.Config.Serve(s.Listener) go s.Config.Serve(s.Listener)
...@@ -161,9 +164,11 @@ func (s *Server) CloseClientConnections() { ...@@ -161,9 +164,11 @@ func (s *Server) CloseClientConnections() {
if !ok { if !ok {
return return
} }
hl.Lock()
for _, conn := range hl.history { for _, conn := range hl.history {
conn.Close() conn.Close()
} }
hl.Unlock()
} }
// waitGroupHandler wraps a handler, incrementing and decrementing a // waitGroupHandler wraps a handler, incrementing and decrementing a
......
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