-
Notifications
You must be signed in to change notification settings - Fork 783
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
[di-tracing] Fix the TracerProviderBuilder.AddInstrumentation factory pattern extension #4468
[di-tracing] Fix the TracerProviderBuilder.AddInstrumentation factory pattern extension #4468
Conversation
@utpilla @cijothomas @alanwest 1.4.0 is bugged. Do we want to hotfix? |
Codecov Report
Additional details and impacted files@@ Coverage Diff @@
## main #4468 +/- ##
==========================================
+ Coverage 83.30% 83.34% +0.03%
==========================================
Files 314 314
Lines 12522 12522
==========================================
+ Hits 10431 10436 +5
+ Misses 2091 2086 -5
|
@@ -2,6 +2,9 @@ | |||
|
|||
## Unreleased | |||
|
|||
* Fixed the `TracerProviderBuilder.AddInstrumentation` factory extension. |
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.
Can you describe more or give an example of what happened if you used this before the fix? I'm assuming builder
is a different instance than tracerProviderBuilder
, and so calling AddInstrumentation
had no effect?
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.
Can't tell if you are asking me to explain that here or in the CHANGELOG 🤣 I'll start with just here...
I'm assuming builder is a different instance than tracerProviderBuilder, and so calling AddInstrumentation had no effect?
Correct! Calling it before this fix it will just no-op.
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.
So tracerProviderBuilder
instance is not ITracerProviderBuilder
, but the builder
instance is? Then, what about the same check in ConfigureServices
? Do we need to worry about that?
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's 2 builders...
-
TracerProviderBuilderBase
this is the phase 1 builder. ImplementsITracerProviderBuilder
. Dumps everything into theIServiceCollection
. -
TracerProviderBuilderSdk
this is the phase 2 builder which holds the state. Everything from phase 1 is re-played against this builder onceIServiceProvider
is available in the order it was registered. The state then gets consumed into theTracerProviderSdk
.
The working version of the clause is...
if (builder is ITracerProviderBuilder iTracerProviderBuilder
&& iTracerProviderBuilder.Provider != null)
-
The first part (
is ITracerProviderBuilder iTracerProviderBuilder
) is true for bothTracerProviderBuilderBase
&TracerProviderBuilderSdk
. -
The second part (
iTracerProviderBuilder.Provider != null
) is the more interesting one! OnlyTracerProviderBuilderSdk
has access to theIServiceProvider
. During phase 1 we operate on theIServiceCollection
. During phase 2IServiceCollection
has been closed and we have theIServiceProvider
.
The way the code was written before it was capturing the "phase 1" builder (TracerProviderBuilderBase
) so the second clause would evaluate to false
even when the final "phase 2" builder was in play.
Yes, this is confusing 😢
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.
Can't tell if you are asking me to explain that here or in the CHANGELOG 🤣 I'll start with just here...
Both 😆, appreciate the explanation here, but I also think elaborating in the changelog (or at least the PR description) would be good as it might help users determine if they're impacted.
It does not appear that any of our instrumentation is using this particular overload of AddInstrumentation
, so I'd imagine that end users who may be impacted by this bug are ones that are using this overload in some kind of DI scenario.
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.
Updated the CHANGELOG text to be more specific. LMK if you want it to be more verbose. I'll also spin up an issue for this and link to it from the PR description.
I'm open to considering this, but from what I can tell it's not a very pressing bug fix. Have you heard from anyone bumping into this problem? If not, maybe it would be good to open a corresponding issue to link to this PR, in case anyone does run into this bug and searches issues for |
Not yet! I'm good with leaving it broken in 1.4.0 until a fix is needed. |
Relates to #4471
Changes
TracerProviderBuilder.AddInstrumentation(IServiceProvider, TracerProvider)
factory extension from being called during construction of the SDKTracerProvider
.Merge requirement checklist
CHANGELOG.md
files updated for non-trivial changes