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 usage of semantic conventions to new exported strings #2025

Closed
59 tasks done
Tracked by #4572
JamieDanielson opened this issue Mar 19, 2024 · 20 comments
Closed
59 tasks done
Tracked by #4572

Update usage of semantic conventions to new exported strings #2025

JamieDanielson opened this issue Mar 19, 2024 · 20 comments
Labels
good first issue needs:code-contribution This feature/bug is ready to implement type:feature-tracking A feature with sub-issues that need to be addressed up-for-grabs Good for taking. Extra help will be provided by maintainers

Comments

@JamieDanielson
Copy link
Member

JamieDanielson commented Mar 19, 2024

This is somewhat related to #1778 , which is for documenting current semantic convention versions for each instrumentation package.

This issue is intended to track the necessary change of updating each package to use the new exports for semantic conventions that were added in open-telemetry/opentelemetry-js#4298 and now available in v1.22.0.

Each package will need to

  • update the dependency for @opentelemetry/semantic-conventions to "^1.22.0"
  • update the imported semantic convention to match the new version, i.e. HTTP_ROUTE becomes SEMATTRS_HTTP_ROUTE

Please limit PRs to a single package in order to make them quickly and easily reviewable.
If you are working on one of the below packages, please comment so others know the issue is being worked on.

EDIT: updated to add other packages that will need replacements for the deprecated attributes:

@pichlermarc pichlermarc added type:feature-tracking A feature with sub-issues that need to be addressed good first issue needs:code-contribution This feature/bug is ready to implement up-for-grabs Good for taking. Extra help will be provided by maintainers labels Mar 20, 2024
@JamieDanielson
Copy link
Member Author

I am updating the express package

@JamieDanielson JamieDanielson changed the title Update instrumentation semantic conventions to new exported strings Update usage of semantic conventions to new exported strings Mar 21, 2024
@MrFabio
Copy link
Contributor

MrFabio commented Mar 21, 2024

I am updating the koa package #2033

@JamieDanielson
Copy link
Member Author

Updating instrumentation-document-load package #2039

@maryliag
Copy link
Contributor

I am updating all the resource detector packages

@maryliag
Copy link
Contributor

also updated the instrumentation-pg plugin

@JamieDanielson
Copy link
Member Author

Also! A great follow-up PR (or maybe even the same PR, depending on how big the PR is) is to add the attributes to the README as listed in this issue #1778 . As an example, check out open-telemetry/opentelemetry-js#4587 😄

@maryliag
Copy link
Contributor

I can do that for the ones I updated. I will do on a follow PRs, because I currently have a few PRs up updating those same README files and want to avoid the conflict. So once those are merged I will update with the missing info for this.

MrFabio added a commit to MrFabio/opentelemetry-js-contrib that referenced this issue Mar 29, 2024
pichlermarc added a commit that referenced this issue Apr 2, 2024
* feat(koa): Use exported strings for attributes

* feat(koa): Updated package-lock.json #2025

---------

Co-authored-by: Marc Pichler <[email protected]>
Zirak added a commit to Zirak/opentelemetry-js-contrib that referenced this issue Apr 3, 2024
Zirak added a commit to Zirak/opentelemetry-js-contrib that referenced this issue Apr 3, 2024
maryliag added a commit to maryliag/opentelemetry-js-contrib that referenced this issue Apr 3, 2024
Add Semantic Conventions to Alibaba README

PArt Of open-telemetry#2025

Signed-off-by: maryliag <[email protected]>
trentm pushed a commit that referenced this issue Apr 25, 2024
Use exported strings for Semantic Attributes

Signed-off-by: maryliag <[email protected]>
Refs: #2025
trentm pushed a commit that referenced this issue Apr 25, 2024
Use exported strings for Semantic Resource Attributes

Signed-off-by: maryliag <[email protected]>
Refs: #2025
trentm added a commit that referenced this issue May 1, 2024
…#2139)

Also, correct component-label mapping for instrumentation-cassandra-driver package

Co-authored-by: Trent Mick <[email protected]>
Refs: #2025
@JamieDanielson
Copy link
Member Author

For a smaller list, these are remaining packages that still need to get updated in this repo:

  • @opentelemetry/instrumentation-bunyan (dev dep)
  • @opentelemetry/instrumentation-hapi
  • @opentelemetry/instrumentation-ioredis
  • @opentelemetry/instrumentation-memcached
  • @opentelemetry/instrumentation-nestjs-core
  • @opentelemetry/instrumentation-net
  • @opentelemetry/instrumentation-long-task
  • @opentelemetry/instrumentation-user-interaction
  • @opentelemetry/browser-extension-autoinjection (this is archived, do we still need to update it?)

@JamieDanielson
Copy link
Member Author

JamieDanielson commented May 7, 2024

These packages do not seem to have semantic conventions; I am opening a PR for them to document as such and remove any unused semantic-convention packages

  • @opentelemetry/instrumentation-lru-memoizer

  • @opentelemetry/instrumentation-dns

  • @opentelemetry/instrumentation-generic-pool

  • @opentelemetry/instrumentation-pino

  • @opentelemetry/instrumentation-winston

  • @opentelemetry/plugin-react-load

  • @opentelemetry/sampler-aws-xray

  • done in docs: remove unused semconv packages and document #2182

@maryliag
Copy link
Contributor

Updated the ones from your latest list:

I didn't update long-task and user-interaction because I didn't actually see any usage of the semantic convention package on then, maybe am I missing something?
Also, don't think we should update an archived package, so I didn't do the extension-autoinjection

Seems to be some errors with the tests on the hapi one, I will try to look into it when I get some time

@trentm
Copy link
Contributor

trentm commented May 15, 2024

Remaining hits:

% rg SemanticAttributes -g '!instrumentation-undici' -w
plugins/node/opentelemetry-instrumentation-hapi/src/utils.ts
18:import { SemanticAttributes } from '@opentelemetry/semantic-conventions';
80:        [SemanticAttributes.HTTP_ROUTE]: route.path,
81:        [SemanticAttributes.HTTP_METHOD]: route.method,
90:      [SemanticAttributes.HTTP_ROUTE]: route.path,
91:      [SemanticAttributes.HTTP_METHOD]: route.method,

plugins/node/instrumentation-socket.io/test/utils.ts
20:import { SemanticAttributes } from '@opentelemetry/semantic-conventions';
60:    s => s.attributes[SemanticAttributes.MESSAGING_SYSTEM] === 'socket.io'

plugins/node/opentelemetry-instrumentation-mongodb/test/mongodb-v5-v6.test.ts
47:import { SemanticAttributes } from '@opentelemetry/semantic-conventions';
340:              mongoSpan!.attributes[SemanticAttributes.DB_STATEMENT] as string
386:                mongoSpan!.attributes[SemanticAttributes.DB_STATEMENT] as string

plugins/node/opentelemetry-instrumentation-mongodb/test/mongodb-v4.test.ts
38:import { SemanticAttributes } from '@opentelemetry/semantic-conventions';
337:              mongoSpan!.attributes[SemanticAttributes.DB_STATEMENT] as string
383:                mongoSpan!.attributes[SemanticAttributes.DB_STATEMENT] as string

plugins/node/opentelemetry-instrumentation-mongodb/test/mongodb-v3.test.ts
36:import { SemanticAttributes } from '@opentelemetry/semantic-conventions';
298:              mongoSpan!.attributes[SemanticAttributes.DB_STATEMENT] as string
344:                mongoSpan!.attributes[SemanticAttributes.DB_STATEMENT] as string
583:                mongoSpan.attributes[SemanticAttributes.NET_PEER_NAME],
587:                mongoSpan.attributes[SemanticAttributes.NET_PEER_PORT],

plugins/node/opentelemetry-instrumentation-mongodb/test/utils.ts
18:import { SemanticAttributes } from '@opentelemetry/semantic-conventions';
96:    mongoSpan.attributes[SemanticAttributes.DB_OPERATION],
100:    mongoSpan.attributes[SemanticAttributes.DB_SYSTEM],
104:    mongoSpan.attributes[SemanticAttributes.NET_PEER_NAME],
110:      mongoSpan.attributes[SemanticAttributes.DB_CONNECTION_STRING],
117:      mongoSpan.attributes[SemanticAttributes.DB_STATEMENT] as string

So looks like instr-mongodb and instr-socket.io missed a couple usages in tests. And then the instr-hapi PR to complete

@trentm
Copy link
Contributor

trentm commented May 15, 2024

Remaining hits:

I've opened #2210 (review) for the last remaining uses.

@trentm
Copy link
Contributor

trentm commented May 22, 2024

I believe this is done now.

@trentm trentm closed this as completed May 22, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
good first issue needs:code-contribution This feature/bug is ready to implement type:feature-tracking A feature with sub-issues that need to be addressed up-for-grabs Good for taking. Extra help will be provided by maintainers
Projects
None yet
Development

No branches or pull requests

6 participants