-
Notifications
You must be signed in to change notification settings - Fork 448
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
[SDK] Restore Recordable API compatibility with versions < 1.14.0 #2547
Conversation
Agree with the change. This got overlooked in the review. |
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.
The change implemented in Recordable
in #2488:
- is an SDK API breaking change (new pure virtual method)
- is an SDK ABI breaking change (new virtual method)
- is indeed not documented as breaking change in the CHANGELOG.md, and release notes for 1.14.0
As the author of #2488, I failed to document this, which caused unexpected breaks.
Point taken.
Now, about the idea to provide a default no-op implementation for this method, I failed to understand why it is considered desirable:
-
The default no-op implementation is broken. Every exporter not recording trace flags (by overriding SetTraceFlags) will cause bugs with sampling downstream, and yet this is what opentelemetry-cpp would cause by default.
-
Providing a default implementation might make the code "compatible" (but broken, see above) at the API level (old exporters will still build with both 1.13.0 and 1.14.0), but it resolves nothing at the ABI level:
- An exporter compiled with 1.13.0 and linked (dynamically) with 1.14.0 will crash
- An exporter compiled with 1.14.0 and linked (dynamically) with 1.13.0 will crash
See related #2549 |
An exporter compiled with 1.13.0 but not the same exporter will not compile with 1.4.0 because no default implementation for the new virtual method. The exporter will need to add its implementation to pass compilation. As 1.14.0 is already broken, this fix could make it into 1.40.1 as patch release instead of the next minor version update 1.15.0. |
No worries. My problem is more with the API break (which caused me to do work 😵💫), not a call-out in the release notes.
My understanding is that providing a default no-op implementation does not change any behavior that existed in v1.13.0, right? So the PR can't make any current problems worse. (Please correct me if I am wrong.) So what do we gain? I think some exporters do not care about trace flags1. If I understand correctly, these are not broken in v1.13.0. e.g. zipkin seems not to, and I don't think Cloud Trace does either. These exporters take an unnecessary API break in v1.14.0. I think you are using the API breaking change to alert exporters to check whether they need to heed the trace flags. Are you sure you would rather A. introduce an API break that forces exporters to update, whether they use trace flags or not over... B. provide a default implementation that might go unnoticed by exporters that should use the trace flags If you still think option A, that is fine. Feel free to close this PR.
Ack. Note that some consumers of Footnotes
|
Thanks for the details. This is what I suggest then:
It is correct that some exporters will never care about trace flags (like zipkin). My first concern is with:
but it can be mitigated by other means (documentation) instead of forcing a decision with a build break (pure virtual method). Ok to have 1.14.1 as well. My second concern is with binary compatibility. With or without a no op implementation, mixing binaries pre and post 1.14.0 will lead to crashes, so the claim that "Recordable is backward compatible" should be clarified and put into context, because there is still an ABI change that can not be ignored. |
Thanks for working with me on this.
I updated the PR title and description to try to capture the nuance. (sorry, I only ever think about API compatibility). Feel free to make edits. |
Done with edits, please confirm you are ok with the rewording. |
LGTM, thanks! |
Issue:
Recordable::SetTraceFlags(...)
was added in v1.14.0. This was a breaking change. Consumers of this library would have to define an override for this method. Also, the latest version of opentelemetry-cpp would not be API compatible with older versions of consumers (which could not know about this new, pure virtual method).#2488 (comment)
Solution:
Provides a default implementation for
Recordable::SetTraceFlags(...)
.The default implementation is sufficient for W3C Trace Context version 1, which is actually used.
To later support W3C Trace Context version 2, exporters are encouraged to capture trace flags, by providing an implementation in Recordable sub classes.
Limitation:
Note that this PR does not restore ABI compatibility for older versions.
The ABI change is required to support opentelemetry-proto 1.1.0, used by the OTLP exporter.