-
Notifications
You must be signed in to change notification settings - Fork 858
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 Marshalers for profiling signal type #6565
Conversation
Utility functions to support required data types.
Marshaler classes for Profile and its constituent types.
Unit tests for profile marshaling.
Codecov ReportAttention: Patch coverage is
Additional details and impacted files@@ Coverage Diff @@
## main #6565 +/- ##
============================================
- Coverage 90.59% 90.31% -0.29%
- Complexity 6255 6261 +6
============================================
Files 689 690 +1
Lines 18698 18762 +64
Branches 1843 1853 +10
============================================
+ Hits 16940 16945 +5
- Misses 1201 1258 +57
- Partials 557 559 +2 ☔ View full report in Codecov by Sentry. |
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.
Just a couple of minor comments, but looks pretty good!
exporters/common/src/main/java/io/opentelemetry/exporter/internal/marshal/Serializer.java
Outdated
Show resolved
Hide resolved
...s/otlp/profiles/src/main/java/io/opentelemetry/exporter/otlp/profiles/FunctionMarshaler.java
Outdated
Show resolved
Hide resolved
...rters/otlp/profiles/src/main/java/io/opentelemetry/exporter/otlp/profiles/LineMarshaler.java
Outdated
Show resolved
Hide resolved
Changes addressing review comments.
Changes addressing review comments.
Move proto wire generation, per review comments.
The third step towards support for the new experimental profiling OTLP signal type, following on from the data model interfaces and implementation.
These marshaler classes are somewhat verbose and very boilerplatey, but should not contain any surprises, being patterned largely on the existing marshalers for other signal types. The code is tedious to review, particularly to check the field names and data types correspond correctly to the proto file. I think I got all the cut and paste errors out, but then again I thought that on two previous occasions whilst checking it and proved myself wrong both times. Should probably have written a codegen tool instead, but hey, hindsight...
The classes here cover the payload, pprofextended.proto The PR is already a bit big, so the ones for the envelope, profiles.proto, will follow later.
The utility classes in common are extended with some additional methods to support data types used by profiling but not other signal types.
For the first time we actually get some test coverage on profiling code. The tests for the marshalers use the data model interface and impl, so those get exercised too. May even have gone a bit too far - the code and tests were written starting from the leaf nodes, whereas just testing serialization of the root type would have transitively tested the rest. I'm leaving all the tests in for now, but they could be curated a little to reduce duplication if desired.