From a05be3634e56d4099283bc0befe2a3d94a9d1613 Mon Sep 17 00:00:00 2001 From: Oleksandr Ohurtsov Date: Mon, 5 Jul 2021 13:44:36 +0300 Subject: [PATCH] Fix datarace while update a channel.lastEventID Protect the option by wrappring into a mutex. The datarace is gone. It closes https://github.com/alexandrevicenzi/go-sse/issues/18 --- channel.go | 2 ++ sse_test.go | 5 +++-- 2 files changed, 5 insertions(+), 2 deletions(-) diff --git a/channel.go b/channel.go index 24aba8b..7c59f23 100644 --- a/channel.go +++ b/channel.go @@ -26,7 +26,9 @@ func newChannel(name string) *Channel { // SendMessage broadcast a message to all clients in a channel. func (c *Channel) SendMessage(message *Message) { + c.mu.Lock() c.lastEventID = message.id + c.mu.Unlock() timer := time.NewTimer(sendMessageToClientTimeout) defer timer.Stop() diff --git a/sse_test.go b/sse_test.go index 45c5c14..0a11a3d 100644 --- a/sse_test.go +++ b/sse_test.go @@ -191,8 +191,9 @@ func TestServerDontStartServer(t *testing.T) { } func TestMultipleTopics(t *testing.T) { - // usage pattern we have a client which subsribed to multiple channels - // in one connection + // The usage pattern: Imagine we have a client which subsribed to multiple topics + // inside a connection. It track changes of specific items state by their ID + // for example. sendersWg := sync.WaitGroup{} workerWg := sync.WaitGroup{} m := sync.Mutex{}