Add extra protection for grid reconnects (#18840)

Race checks would occasionally show race on handleMsgWg WaitGroup by debug messages (used in test only).

Use the `connMu` mutex to protect this against concurrent Wait/Add.

Fixes #18827
This commit is contained in:
Klaus Post 2024-01-22 09:39:06 -08:00 committed by GitHub
parent 65c4d550cb
commit feeeef71f1
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194

View File

@ -831,7 +831,9 @@ func (c *Connection) reconnected() {
c.outgoing.Clear() c.outgoing.Clear()
// Wait for existing to exit // Wait for existing to exit
c.connMu.Lock()
c.handleMsgWg.Wait() c.handleMsgWg.Wait()
c.connMu.Unlock()
} }
func (c *Connection) updateState(s State) { func (c *Connection) updateState(s State) {
@ -855,7 +857,9 @@ func (c *Connection) updateState(s State) {
func (c *Connection) handleMessages(ctx context.Context, conn net.Conn) { func (c *Connection) handleMessages(ctx context.Context, conn net.Conn) {
// Read goroutine // Read goroutine
c.connMu.Lock()
c.handleMsgWg.Add(2) c.handleMsgWg.Add(2)
c.connMu.Unlock()
ctx, cancel := context.WithCancelCause(ctx) ctx, cancel := context.WithCancelCause(ctx)
go func() { go func() {
defer func() { defer func() {
@ -1534,7 +1538,9 @@ func (c *Connection) debugMsg(d debugMsg, args ...any) {
c.debugInConn.Close() c.debugInConn.Close()
} }
case debugWaitForExit: case debugWaitForExit:
c.connMu.Lock()
c.handleMsgWg.Wait() c.handleMsgWg.Wait()
c.connMu.Unlock()
case debugSetConnPingDuration: case debugSetConnPingDuration:
c.connMu.Lock() c.connMu.Lock()
defer c.connMu.Unlock() defer c.connMu.Unlock()