Skip to content

Commit

Permalink
jetstream: ordered consumer: handle closed subscriptions gracefully
Browse files Browse the repository at this point in the history
In `orderedConsumer.reset()`, `retryWithBackoff()` is returned from with
`false, nil` in case the subscription is closed. In this case,
`var cons Consumer` is still `nil`, and the code crashes in the attempt to
cast it to a `pullConsumer` later on.

Fix this by catching the `nil` case explicitly.

Signed-off-by: Daniel Mack <[email protected]>
  • Loading branch information
zonque committed Jun 25, 2024
1 parent 370bc4f commit 1de5b00
Showing 1 changed file with 3 additions and 0 deletions.
3 changes: 3 additions & 0 deletions jetstream/ordered.go
Original file line number Diff line number Diff line change
Expand Up @@ -539,6 +539,9 @@ func (c *orderedConsumer) reset() error {
if err != nil {
return err
}
if cons == nil {
return nats.ErrSubscriptionClosed
}
c.currentConsumer = cons.(*pullConsumer)
return nil
}
Expand Down

0 comments on commit 1de5b00

Please sign in to comment.