From f99ef79adc8b4bf2a38c37d1ed0dfb8d8b602870 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Bj=C3=B8rn=20Erik=20Pedersen?= Date: Sun, 31 Mar 2024 21:27:14 +0200 Subject: [PATCH] Fix data race in client Close --- client.go | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) diff --git a/client.go b/client.go index 635a0f7..8476f1f 100644 --- a/client.go +++ b/client.go @@ -227,7 +227,6 @@ func (c *ClientRaw) Close() error { if c == nil { return nil } - defer close(c.Messages) c.sendMu.Lock() defer c.sendMu.Unlock() @@ -241,6 +240,8 @@ func (c *ClientRaw) Close() error { err := c.conn.Close() + close(c.Messages) + return err } @@ -316,16 +317,17 @@ func (c *ClientRaw) input() { break } + c.mu.Lock() id := message.Header.ID if id == 0 { // A message with ID 0 is a standalone message (e.g. log message) // and not part of the request-response flow. c.Messages <- message + c.mu.Unlock() continue } // Attach it to the correct pending call. - c.mu.Lock() call, found := c.pending[id] if !found { panic(fmt.Sprintf("call with ID %d not found", id)) @@ -337,12 +339,13 @@ func (c *ClientRaw) input() { } delete(c.pending, id) - c.mu.Unlock() if call == nil { err = fmt.Errorf("call with ID %d not found", id) + c.mu.Unlock() break } call.Messages <- message + c.mu.Unlock() call.done() }