Skip to content

Commit

Permalink
handle critical errors
Browse files Browse the repository at this point in the history
  • Loading branch information
mensfeld committed Oct 22, 2023
1 parent a1ed488 commit 950474a
Show file tree
Hide file tree
Showing 6 changed files with 20 additions and 5 deletions.
4 changes: 4 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -1,5 +1,9 @@
# WaterDrop changelog

## 2.6.9 (Unreleased)
- [Improvement] Introduce a `transaction.finished` event to indicate that transaction has finished whether it was aborted or committed.
- [Improvement] Use `transaction.committed` event to indicate that transaction has been committed.

## 2.6.8 (2023-10-20)
- **[Feature]** Introduce transactions support.
- [Improvement] Expand `LoggerListener` to inform about transactions (info level).
Expand Down
2 changes: 1 addition & 1 deletion Gemfile.lock
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
PATH
remote: .
specs:
waterdrop (2.6.8)
waterdrop (2.6.9)
karafka-core (>= 2.2.3, < 3.0.0)
zeitwerk (~> 2.3)

Expand Down
5 changes: 5 additions & 0 deletions lib/waterdrop/instrumentation/logger_listener.rb
Original file line number Diff line number Diff line change
Expand Up @@ -145,6 +145,11 @@ def on_transaction_committed(event)
info(event, 'Committing transaction')
end

# @param event [Dry::Events::Event] event that happened with the details
def on_transaction_finished(event)
info(event, 'Processing transaction')
end

private

# @return [Boolean] should we report the messages details in the debug mode.
Expand Down
1 change: 1 addition & 0 deletions lib/waterdrop/instrumentation/notifications.rb
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,7 @@ class Notifications < ::Karafka::Core::Monitoring::Notifications
transaction.started
transaction.committed
transaction.aborted
transaction.finished

buffer.flushed_async
buffer.flushed_sync
Expand Down
11 changes: 8 additions & 3 deletions lib/waterdrop/producer/transactions.rb
Original file line number Diff line number Diff line change
Expand Up @@ -49,7 +49,7 @@ def transaction
return yield if @transaction_mutex.owned?

@transaction_mutex.synchronize do
transactional_instrument(:committed) do
transactional_instrument(:finished) do
with_transactional_error_handling(:begin) do
transactional_instrument(:started) { client.begin_transaction }
end
Expand All @@ -65,11 +65,16 @@ def transaction
commit || raise(WaterDrop::Errors::AbortTransaction)

with_transactional_error_handling(:commit) do
client.commit_transaction
transactional_instrument(:committed) { client.commit_transaction }
end

result
rescue StandardError => e
# We need to handle any interrupt including critical in order not to have the transaction
# running. This will also handle things like `IRB::Abort`
#
# rubocop:disable Lint/RescueException
rescue Exception => e
# rubocop:enable Lint/RescueException
with_transactional_error_handling(:abort) do
transactional_instrument(:aborted) { client.abort_transaction }
end
Expand Down
2 changes: 1 addition & 1 deletion lib/waterdrop/version.rb
Original file line number Diff line number Diff line change
Expand Up @@ -3,5 +3,5 @@
# WaterDrop library
module WaterDrop
# Current WaterDrop version
VERSION = '2.6.8'
VERSION = '2.6.9'
end

0 comments on commit 950474a

Please sign in to comment.