Skip to content
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

Update opentelementry-proto to 1.4 #6906

Merged
merged 3 commits into from
Dec 2, 2024

Conversation

jhalliday
Copy link
Contributor

Mostly changes to the experimental profiling protocol, with some additions to the serialization framework it uses.

@jhalliday jhalliday requested a review from a team as a code owner November 25, 2024 13:51
Copy link

codecov bot commented Nov 25, 2024

Codecov Report

Attention: Patch coverage is 0% with 28 lines in your changes missing coverage. Please review.

Project coverage is 90.10%. Comparing base (7829f53) to head (7f0700f).
Report is 5 commits behind head on main.

Files with missing lines Patch % Lines
...elemetry/exporter/internal/marshal/Serializer.java 0.00% 17 Missing ⚠️
...metry/exporter/internal/marshal/MarshalerUtil.java 0.00% 11 Missing ⚠️
Additional details and impacted files
@@             Coverage Diff              @@
##               main    #6906      +/-   ##
============================================
- Coverage     90.23%   90.10%   -0.14%     
  Complexity     6594     6594              
============================================
  Files           729      729              
  Lines         19800    19828      +28     
  Branches       1947     1950       +3     
============================================
- Hits          17867    17866       -1     
- Misses         1341     1369      +28     
- Partials        592      593       +1     

☔ View full report in Codecov by Sentry.
📢 Have feedback on the report? Share it here.

@jack-berg
Copy link
Member

Looks like some merge conflicts need resolution.

Copy link
Contributor

@jsuereth jsuereth left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Just a few nits on things we can do to make our proto serialziation helper libs more clear.

public void serializeInt32(ProtoFieldInfo field, int value) throws IOException {
if (value == 0) {
return;
}
writeint32(field, value);
}

/** Serializes a protobuf {@code int32} field. */
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Nit: I'd explicitly call this out as serialization a {@code optional int32} field.

Yes, it's in the name of the method.

@@ -122,14 +122,27 @@ public void serializeSInt32(ProtoFieldInfo field, int value) throws IOException

protected abstract void writeSInt32(ProtoFieldInfo info, int value) throws IOException;

/** Serializes a protobuf {@code uint32} field. */
/** Serializes a protobuf {@code int32} field. */
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

So - IIRC - this is actually how we serialize both uint32 and int32 in Java.

@@ -340,6 +353,25 @@ protected abstract void writeStartRepeatedVarint(ProtoFieldInfo field, int paylo

protected abstract void writeEndRepeatedVarint() throws IOException;

/** Serializes a {@code repeated int32} field. */
public void serializeRepeatedInt32(ProtoFieldInfo field, List<Integer> values)
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Nit: Maybe take Collection instead of List for more flexibility here.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

List is already used elsewhere in methods serializing repeated fields. I agree that Collection is more flexible, but shouldn't obligate @jhalliday to make that switch here. If Jonathan wants to follow the "boy scout rule", and bundle the switch to Collection in with this PR, I'm open to that. Can also open a separate issue and resolve in a followup PR.


final class LocationMarshaler extends MarshalerWithSize {

private static final LocationMarshaler[] EMPTY_REPEATED = new LocationMarshaler[0];

private final long mappingIndex;
@Nullable private final Integer mappingIndex;
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Nit: Does it make sense to use java.util.Optional or does that just add headache here?

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We don't use Optional anywhere in this repository. The logic goes something like this:

  • For external user facing APIs, optional creates a tri-state, with internals needing to check for null, present, and empty, since even with assuming non-null arguments and @Nullable annotations where arguments are nullable, we often perform additional null checks.
  • For internal APIs, optinoal adds additional allocation vs. @Nullable, and maintainers can / should accept higher cognitive load in exchange for better performance.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants