From 266e049848f39f565ad20dcab609e3c6f13a3628 Mon Sep 17 00:00:00 2001 From: Quinn Klassen Date: Thu, 30 Nov 2023 10:20:04 -0800 Subject: [PATCH] Fix race in WaitSignalReturnParam (#1309) --- test/integration_test.go | 2 +- test/workflow_test.go | 8 +++++--- 2 files changed, 6 insertions(+), 4 deletions(-) diff --git a/test/integration_test.go b/test/integration_test.go index 754a14da7..d1a99c120 100644 --- a/test/integration_test.go +++ b/test/integration_test.go @@ -851,7 +851,7 @@ func (ts *IntegrationTestSuite) TestWorkflowIDReuseIgnoreDuplicateWhileRunning() // Send signal to each (though in practice they both have the same ID and run // ID, so it's really just two signals) - err = ts.client.SignalWorkflow(ctx, run1.GetID(), run1.GetRunID(), "done-signal", true) + err = ts.client.SignalWorkflow(ctx, run1.GetID(), run1.GetRunID(), "done-signal", false) ts.NoError(err) err = ts.client.SignalWorkflow(ctx, run2.GetID(), run2.GetRunID(), "done-signal", true) ts.NoError(err) diff --git a/test/workflow_test.go b/test/workflow_test.go index 33e540957..b57109088 100644 --- a/test/workflow_test.go +++ b/test/workflow_test.go @@ -1749,12 +1749,14 @@ func (w *Workflows) WaitSignalReturnParam(ctx workflow.Context, v interface{}) ( // Wait for signal before returning s := workflow.NewSelector(ctx) signalCh := workflow.GetSignalChannel(ctx, "done-signal") + var finishWf bool s.AddReceive(signalCh, func(c workflow.ReceiveChannel, more bool) { - var ignore bool - c.Receive(ctx, &ignore) + c.Receive(ctx, &finishWf) workflow.GetLogger(ctx).Info("Received signal") }) - s.Select(ctx) + for !finishWf { + s.Select(ctx) + } return v, nil }