Skip to content

Commit

Permalink
RescuedExceptionInterceptor: Handle empty configuration
Browse files Browse the repository at this point in the history
Previously, it could happen that `Sentry.configuration` was `nil`.
In this case, calling `rails` would produce a `NoMethodError`.
We fix this issue by using safe navigation.

Furthermore, this commit ensures we use a reasonable default
in case the configuration couldn't be loaded. Since the config
`report_rescued_exceptions` defaults to `true`, we assume
this value here, too.

Fixes #2386
  • Loading branch information
MrSerth committed Oct 15, 2024
1 parent f3ed31e commit fd7d18b
Show file tree
Hide file tree
Showing 2 changed files with 5 additions and 1 deletion.
1 change: 1 addition & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@
### Bug Fixes

- Fix Vernier profiler not stopping when already stopped [#2429](https://github.com/getsentry/sentry-ruby/pull/2429)
- Fix `RescuedExceptionInterceptor` to handle an empty configuration [#2428](https://github.com/getsentry/sentry-ruby/pull/2428)

## 5.21.0

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,10 @@ def call(env)
end

def report_rescued_exceptions?
Sentry.configuration.rails.report_rescued_exceptions
report_rescued_exceptions = Sentry.configuration&.rails&.report_rescued_exceptions
return report_rescued_exceptions unless report_rescued_exceptions.nil?

true

Check warning on line 25 in sentry-rails/lib/sentry/rails/rescued_exception_interceptor.rb

View check run for this annotation

Codecov / codecov/patch

sentry-rails/lib/sentry/rails/rescued_exception_interceptor.rb#L25

Added line #L25 was not covered by tests
end
end
end
Expand Down

0 comments on commit fd7d18b

Please sign in to comment.