-
-
Notifications
You must be signed in to change notification settings - Fork 523
Description
Issue Description
When Rails handles an exception internally and converts it to a specific HTTP status code (e.g., ActiveRecord::RecordNotFound -> 404), the Sentry transaction is incorrectly reported with status internal_error and http.response.status_code: 500 instead of the actual HTTP response status code.
This creates inaccurate reports, as all Rails-rescued exceptions appear as 500 errors in Sentry, even though the client receives the correct HTTP status code (404, 422, etc.).
The breadcrumbs in the transaction correctly show the actual status code (404), but the transaction-level status and span-level status codes are incorrect (500).
Even though version 6.0.0+ includes trace_ignore_status_codes which by default excludes 404s from being traced, this is a workaround rather than a fix. The underlying issue of incorrect status code reporting remains for any status codes that are not ignored.
Reproduction Steps
- Configure a Rails application with
sentry-railsversion5.27.0 - Enable tracing with
config.traces_sample_rate = 1.0 - Create a route that raises
ActiveRecord::RecordNotFoundor similar exception that Rails rescues and converts to a 404 response - Make a request to that route
- Examine the transaction in Sentry
Expected Behavior
- Span status should be "not_found"
- Span
data.http.response.status_codeshould be 404
Actual Behavior
- Span status is "internal_error"
- Span
data.http.response.status_codeis 500
Ruby Version
Ruby 3.4.4
SDK Version
sentry-ruby: 5.27.0
Integration and Its Version
No response
Sentry Config
No response
Metadata
Metadata
Assignees
Projects
Status