good morning!!!!

Skip to content
Snippets Groups Projects
Commit 6167dd65 authored by Ferenc Szabo's avatar Ferenc Szabo Committed by Anton Evangelatov
Browse files

swarm/pss: fix data race in notify_test.go (TestStart) (#18518)

parent 684faced
Branches
Tags
No related merge requests found
...@@ -128,7 +128,7 @@ func TestStart(t *testing.T) { ...@@ -128,7 +128,7 @@ func TestStart(t *testing.T) {
defer rightSub.Unsubscribe() defer rightSub.Unsubscribe()
updateC := make(chan []byte) updateC := make(chan []byte)
updateMsg := []byte{} var updateMsg []byte
ctrlClient := NewController(psses[rightPub]) ctrlClient := NewController(psses[rightPub])
ctrlNotifier := NewController(psses[leftPub]) ctrlNotifier := NewController(psses[leftPub])
ctrlNotifier.NewNotifier("foo.eth", 2, updateC) ctrlNotifier.NewNotifier("foo.eth", 2, updateC)
...@@ -145,17 +145,24 @@ func TestStart(t *testing.T) { ...@@ -145,17 +145,24 @@ func TestStart(t *testing.T) {
if err != nil { if err != nil {
t.Fatal(err) t.Fatal(err)
} }
copyOfUpdateMsg := make([]byte, len(updateMsg))
copy(copyOfUpdateMsg, updateMsg)
ctrlClientError := make(chan error, 1)
ctrlClient.Subscribe(rsrcName, pubkey, addrbytes, func(s string, b []byte) error { ctrlClient.Subscribe(rsrcName, pubkey, addrbytes, func(s string, b []byte) error {
if s != "foo.eth" || !bytes.Equal(updateMsg, b) { if s != "foo.eth" || !bytes.Equal(copyOfUpdateMsg, b) {
t.Fatalf("unexpected result in client handler: '%s':'%x'", s, b) ctrlClientError <- fmt.Errorf("unexpected result in client handler: '%s':'%x'", s, b)
} } else {
log.Info("client handler receive", "s", s, "b", b) log.Info("client handler receive", "s", s, "b", b)
}
return nil return nil
}) })
var inMsg *pss.APIMsg var inMsg *pss.APIMsg
select { select {
case inMsg = <-rmsgC: case inMsg = <-rmsgC:
case err := <-ctrlClientError:
t.Fatal(err)
case <-ctx.Done(): case <-ctx.Done():
t.Fatal(ctx.Err()) t.Fatal(ctx.Err())
} }
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Please register or to comment