-
Notifications
You must be signed in to change notification settings - Fork 829
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
chore: cleanup API dependencies #2904
Conversation
Move api-metrics into dependency instead of mixing dep/peer-dep. Use fixed version for components part of the lerna project. Move api-metrics to dev-dependency in exporter prometheus.
An alternative would be to move api-metrics into peer-dep like api at all places. Please note also that api-metrics has api as a dependency. Therefore having api-metrics as a dependency one has automatically api as dependency (not as peer-dependency like if metrics is not used). |
Codecov Report
@@ Coverage Diff @@
## main #2904 +/- ##
=======================================
Coverage 93.73% 93.73%
=======================================
Files 187 187
Lines 6145 6145
Branches 1308 1308
=======================================
Hits 5760 5760
Misses 385 385
|
@@ -45,6 +45,7 @@ | |||
}, | |||
"devDependencies": { | |||
"@opentelemetry/api": "^1.0.0", | |||
"@opentelemetry/api-metrics": "0.27.0", |
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.
Does this also need to be added to peer dependencies?
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.
Used in src/PrometheusSerializer.ts
line 27
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.
Or real dependencies
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.
It imports only a type import type { MetricAttributes } from '@opentelemetry/api-metrics';
and the place where it is used is not exported. Therefore it's only needed at compile time.
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.
I think when users depend on the exporter the typescript libcheck will still look for api-metrics even just for types won't it? The API will definitely be there because it would be useless to have the exporter without it, but I think it is not strictly a dev dependency when it is type only. I think this is the same thing that happened in contrib when the packages being instrumented have their types imported.
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 lib check will only complain if it is part of an exported API or inside a file which is part of the exported API.
But the serialize
function is internal and therefore not even included in PrometheusSerializer.d.ts
. Maybe you remember open-telemetry/opentelemetry-js-contrib#932 where I solved a similar problem by moving the internal types into an internal file.
But as metrics-api will be present anyway because of other deps it's maybe better to move it back. This protects us also from accidentally run into a libcheck problem in future just by using a type somewhere else.
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.
Sounds good thanks for the explanation
Which problem is this PR solving?
Address unresolved comments from #2892.
Short description of the changes
Move api-metrics into dependency instead of mixing dep/peer-dep.
Use fixed version for components part of the lerna project.
Move api-metrics to dev-dependency in exporter prometheus.
Type of change
How Has This Been Tested?
CI, local
Checklist: