event, p2p/simulations/adapters: fix rare goroutine leaks (#20657)
Co-authored-by: Felix Lange <fjl@twurst.com>
This commit is contained in:
parent
46c4b699c8
commit
a9614c3c91
@ -145,7 +145,6 @@ func (s *resubscribeSub) loop() {
|
|||||||
func (s *resubscribeSub) subscribe() Subscription {
|
func (s *resubscribeSub) subscribe() Subscription {
|
||||||
subscribed := make(chan error)
|
subscribed := make(chan error)
|
||||||
var sub Subscription
|
var sub Subscription
|
||||||
retry:
|
|
||||||
for {
|
for {
|
||||||
s.lastTry = mclock.Now()
|
s.lastTry = mclock.Now()
|
||||||
ctx, cancel := context.WithCancel(context.Background())
|
ctx, cancel := context.WithCancel(context.Background())
|
||||||
@ -157,19 +156,19 @@ retry:
|
|||||||
select {
|
select {
|
||||||
case err := <-subscribed:
|
case err := <-subscribed:
|
||||||
cancel()
|
cancel()
|
||||||
if err != nil {
|
if err == nil {
|
||||||
// Subscribing failed, wait before launching the next try.
|
if sub == nil {
|
||||||
if s.backoffWait() {
|
panic("event: ResubscribeFunc returned nil subscription and no error")
|
||||||
return nil
|
|
||||||
}
|
}
|
||||||
continue retry
|
return sub
|
||||||
}
|
}
|
||||||
if sub == nil {
|
// Subscribing failed, wait before launching the next try.
|
||||||
panic("event: ResubscribeFunc returned nil subscription and no error")
|
if s.backoffWait() {
|
||||||
|
return nil // unsubscribed during wait
|
||||||
}
|
}
|
||||||
return sub
|
|
||||||
case <-s.unsub:
|
case <-s.unsub:
|
||||||
cancel()
|
cancel()
|
||||||
|
<-subscribed // avoid leaking the s.fn goroutine.
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -102,7 +102,7 @@ func TestResubscribe(t *testing.T) {
|
|||||||
func TestResubscribeAbort(t *testing.T) {
|
func TestResubscribeAbort(t *testing.T) {
|
||||||
t.Parallel()
|
t.Parallel()
|
||||||
|
|
||||||
done := make(chan error)
|
done := make(chan error, 1)
|
||||||
sub := Resubscribe(0, func(ctx context.Context) (Subscription, error) {
|
sub := Resubscribe(0, func(ctx context.Context) (Subscription, error) {
|
||||||
select {
|
select {
|
||||||
case <-ctx.Done():
|
case <-ctx.Done():
|
||||||
|
@ -287,7 +287,7 @@ func (n *ExecNode) Stop() error {
|
|||||||
if err := n.Cmd.Process.Signal(syscall.SIGTERM); err != nil {
|
if err := n.Cmd.Process.Signal(syscall.SIGTERM); err != nil {
|
||||||
return n.Cmd.Process.Kill()
|
return n.Cmd.Process.Kill()
|
||||||
}
|
}
|
||||||
waitErr := make(chan error)
|
waitErr := make(chan error, 1)
|
||||||
go func() {
|
go func() {
|
||||||
waitErr <- n.Cmd.Wait()
|
waitErr <- n.Cmd.Wait()
|
||||||
}()
|
}()
|
||||||
|
Loading…
Reference in New Issue
Block a user