-
Notifications
You must be signed in to change notification settings - Fork 821
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
fix: otlp json encoding #4220
fix: otlp json encoding #4220
Conversation
Codecov Report
@@ Coverage Diff @@
## main #4220 +/- ##
==========================================
- Coverage 92.24% 90.54% -1.71%
==========================================
Files 331 159 -172
Lines 9481 3765 -5716
Branches 1999 837 -1162
==========================================
- Hits 8746 3409 -5337
+ Misses 735 356 -379
|
That linked table seems to indicate that fixed64 is preferred to be a string, whereas fixed32 is preferred to be a number (although either would be accepted). I see that this PR does output the |
It would be helpful if this branch could be updated to the latest in "main". That should hopefully fix the "Unit Tests / ..." check failures, now that #4238 has gone in. |
Is there any way to expedite getting this patch in? For some users, the last release (1.17.1 and the experimental packages 0.44.0) is broken. Web-based JSON exporters in this release broke by sending data that does not conform to the JSON serialization of the protobufs expected by the OpenTelemetry Collector. That release was on October 10, so we are getting close to a month now where we have a broken release as the "latest release". Could we please get this fix merged and a new release (1.17.2? 0.44.1?) pushed ASAP? |
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.
Looks like the test faliures that were fixed by #4238 held this PR up quite a bit while I was out of office 😞
I ran some local tests with the exporter example and the changes look good to me. Thank you @seemk for taking care of this.
I'll push a commit to this PR to move the changelog entry - then I'll merge; I'll continue to review PRs in this repo for the rest of my day and then I'll open a release PR so we can get this published as soon as possible.
* chore: track package-lock.json (#4238) * chore: track package-lock.json * Pin to old versions for node 14 * Use version range * Remove unused cached directories * Temporarily disable other tests * Temporarily enable only api test * Enable only some packages * Test only api packages * Test trace exporters * Fix line ordering * Test all packages except otlp exporters * Add trace http exporter * Add trace proto exporter * Test all but grpc exporters * chore: use npm workspaces and degrade lerna to v6 * chore: get rid of lerna bootstrap * chore: use npx * chore: allow install scripts to setup buf * chore: fix w3c-integration-test cache key * chore: fix cache key * chore: disable resource compat test * chore: fix node_modules assumptions * chore: fix hoisted karma issue * chore: fix markdown linter complaints * chore: lock @grpc/grpc-js to v1.8.21 * Break caches * chore: remove cache * chore: fixup inline commands --------- Co-authored-by: Daniel Dyla <[email protected]> * docs: fixed link to benchmark results (#4233) Co-authored-by: Chengzhong Wu <[email protected]> * chore(deps): update all patch versions (#4215) * fix: otlp json encoding (#4220) Co-authored-by: Marc Pichler <[email protected]> * fix: remove duplicate export star from version.ts (#4225) Co-authored-by: Marc Pichler <[email protected]> * docs: fix sdk-node config instructions (#4249) Co-authored-by: Marc Pichler <[email protected]> * feat(api): publish api esnext target (#4231) * chore: release API 1.7.0/Core 1.18.0/Experimental 0.45.0 (#4254) * fix(sdk-metrics): hand-roll MetricAdvice type as older API versions do not include it (#4260) * chore: prepare release 1.18.1/0.45.1 (#4261) * chore: no need for 'packages' in "lerna.json" (#4264) * Benchmark tests for trace OTLP transform and BatchSpanProcessor (#4218) Co-authored-by: Marc Pichler <[email protected]> * chore: type reference on zone.js (#4257) Co-authored-by: Marc Pichler <[email protected]> * docs: add docker-compose to run prometheus for the experimental example (#4268) Co-authored-by: Marc Pichler <[email protected]> * fix(sdk-logs): avoid map attribute set when count limit exceeded (#4195) Co-authored-by: Marc Pichler <[email protected]> * chore(deps): update dependency chromedriver to v119 [security] (#4280) * chore(deps): update actions/setup-node action to v4 (#4236) * fix(sdk-trace-base): processor onStart called with a span having empty attributes (#4277) Co-authored-by: artahmetaj <[email protected]> * Update fetch instrumentation to be runtime agnostic (#4063) Co-authored-by: Marc Pichler <[email protected]> --------- Co-authored-by: Chengzhong Wu <[email protected]> Co-authored-by: Martin Kuba <[email protected]> Co-authored-by: Mend Renovate <[email protected]> Co-authored-by: Siim Kallas <[email protected]> Co-authored-by: Marc Pichler <[email protected]> Co-authored-by: David Luna <[email protected]> Co-authored-by: Dinko Osrecki <[email protected]> Co-authored-by: Trent Mick <[email protected]> Co-authored-by: François <[email protected]> Co-authored-by: Hyun Oh <[email protected]> Co-authored-by: André Cruz <[email protected]> Co-authored-by: artahmetaj <[email protected]> Co-authored-by: drewcorlin1 <[email protected]>
Regression introduced in commit evanderkoogh@bd0a46a after api change in open-telemetry/opentelemetry-js#4220
Which problem is this PR solving?
Please include a summary of the change and which issue is fixed. Please also include relevant motivation and context. List any dependencies that are required for this change.
Fixes #4216
Short description of the changes
Fixes the breakage introduced in #4062 where OTLP JSON encoding was encoding the intermediate low and high bytes directly to JSON, but in JSON mapping fixed64 can only be either a string or a number.
Removed usage of the parts taken from long.js and used
BigInt
instead with a fallback to the old worse precisionhrTimeToNanoseconds
fromcore
ifBigInt
is not available.Refactored the
createExport{Trace,Metrics,Logs}ServiceRequest
calls to unified options and an encoder (getOtlpEncoder
), added tests for the encoder.Type of change
How Has This Been Tested?
Tested manually against collector with gRPC, http/proto, http/json exporters.
Checklist: