-
-
Notifications
You must be signed in to change notification settings - Fork 501
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add ActiveSupport tracer for cache module #2380
Conversation
9f44675
to
10be4dd
Compare
Codecov ReportAttention: Patch coverage is
Additional details and impacted files@@ Coverage Diff @@
## master #2380 +/- ##
==========================================
- Coverage 98.97% 98.82% -0.15%
==========================================
Files 231 233 +2
Lines 15094 15244 +150
==========================================
+ Hits 14939 15065 +126
- Misses 155 179 +24
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
thanks a lot @frederikspang, left a couple of comments.
I will test this out a bit when I have some time with our product.
There are also some other types that are not covered (such as cache_read_multi
) that I will also think about the best way to handle.
sentry-rails/lib/sentry/rails/tracing/active_support_subscriber.rb
Outdated
Show resolved
Hide resolved
sentry-rails/lib/sentry/rails/tracing/active_support_subscriber.rb
Outdated
Show resolved
Hide resolved
f29fb78
to
407d457
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
There are some tests failing under older rubies/rails + a couple of rubocop offenses to fix. Oh and conflict with CHANGELOG still has to be resolved.
Other than that, LGTM. I tested it out locally and it seems to work well.
sentry-rails/lib/sentry/rails/tracing/active_support_subscriber.rb
Outdated
Show resolved
Hide resolved
@solnic I can drill down into why, but it seems to be out of "our hands". |
Awesome :)
I think it's perfectly fine to skip it in Rails 6 and add a note to CHANGELOG (and later on in the docs) that it's Rails 7+ only feature. |
Seems more like a regression in 6.0.x. Works in 5.x and 6.1+ |
I was unable to find anything obvious in Rails 6.0.x releases. I have skipped the spec, and rubocop as well as rspec is passing for me locally. @solnic |
@frederikspang thanks for addressing remaining issues - could you update your branch to latest master? Coverage should be OK after rebasing as we now merge coverage results from all test runs :) |
89b07c3
to
69e41db
Compare
Squashed, and rebased :) |
@solnic I see coverage is kind of misleading in the _spec.rb file.. Rails 8 is not released yet, and is not in the test matrix. |
Spec coverage should be fixed by #2437 I see :) |
can I merge this now @solnic? |
I merged it :) This PR made me think we could consider adding Rails HEAD to the test matrix - WDYT? Not necessarily as a strict CI step, ie allow it to issue a warning if some specs are failing instead of making CI fail. This way we could catch some issues early on. |
Great idea! Might throw in Ruby head as well - or just add it "early" for the preview releases |
We used to do both Rails head and Ruby head. But eventually they just stayed broken most of the time and nobody would check them. More importantly, many times the failures were actually capturing Rails/Ruby/dependencies' bugs, not the SDK's. But we usually only found out after spending hours on it. So I've adapted the approach to just update the CI matrix and tests when there are release candidates (e.g. #2444). It's more economical to fix issues at once when things have mostly settled. |
@st0012 yes this makes sense, thanks for the insights! |
Description
Implement child spans for ActiveSupport cache according to https://docs.sentry.io/platforms/ruby/tracing/instrumentation/custom-instrumentation/caches-module/
Todo: