Implement handle_failed/3

Learn to handle failed messages through the handle_message callback function.

The handle_failed/3 callback function

Right now, when we return a message from handle_message/3, Broadway automatically acknowledges it since it reaches the end of the pipeline.

However, if an unhandled exception happens in our business logic, the message is marked as failed. We can also manually mark a message as failed using Broadway.Message.failed/2. This could be useful when we want to discard messages we don’t want to process.

Remember that in @producer_config we configure the :on_failure setting with the :reject_and_requeue value. This means that failed messages will be sent back to RabbitMQ and redelivered. By default, messages will be redelivered indefinitely. We can change this setting to :reject_and_requeue_once or simply :reject to completely discard all failed messages.

We can also configure acknowledgments on a per-message basis, and the ideal place for that is handle_failed/3. The optional handle_failed/3 callback allows us to check which messages have failed and why. We can then decide if we want to take further action.

Update tickets_available?

Let’s update the tickets_available?/1 function and pattern match for cinema events. We return false to all of them for being unavailable:

Get hands-on with 1300+ tech skills courses.