diff --git a/plugins/node/instrumentation-amqplib/src/amqplib.ts b/plugins/node/instrumentation-amqplib/src/amqplib.ts index 9b27d3d29c..519bf056f1 100644 --- a/plugins/node/instrumentation-amqplib/src/amqplib.ts +++ b/plugins/node/instrumentation-amqplib/src/amqplib.ts @@ -655,21 +655,18 @@ export class AmqplibInstrumentation extends InstrumentationBase ${routingKey} send`, - { - kind: SpanKind.PRODUCER, - attributes: { - ...channel.connection[CONNECTION_ATTRIBUTES], - [SEMATTRS_MESSAGING_DESTINATION]: exchange, - [SEMATTRS_MESSAGING_DESTINATION_KIND]: - MESSAGINGDESTINATIONKINDVALUES_TOPIC, - [SEMATTRS_MESSAGING_RABBITMQ_ROUTING_KEY]: routingKey, - [SEMATTRS_MESSAGING_MESSAGE_ID]: options?.messageId, - [SEMATTRS_MESSAGING_CONVERSATION_ID]: options?.correlationId, - }, - } - ); + const span = self.tracer.startSpan(`publish ${normalizedExchange}`, { + kind: SpanKind.PRODUCER, + attributes: { + ...channel.connection[CONNECTION_ATTRIBUTES], + [SEMATTRS_MESSAGING_DESTINATION]: exchange, + [SEMATTRS_MESSAGING_DESTINATION_KIND]: + MESSAGINGDESTINATIONKINDVALUES_TOPIC, + [SEMATTRS_MESSAGING_RABBITMQ_ROUTING_KEY]: routingKey, + [SEMATTRS_MESSAGING_MESSAGE_ID]: options?.messageId, + [SEMATTRS_MESSAGING_CONVERSATION_ID]: options?.correlationId, + }, + }); const modifiedOptions = options ?? {}; modifiedOptions.headers = modifiedOptions.headers ?? {}; diff --git a/plugins/node/instrumentation-amqplib/test/amqplib-callbacks.test.ts b/plugins/node/instrumentation-amqplib/test/amqplib-callbacks.test.ts index a323cebee9..1e415cb084 100644 --- a/plugins/node/instrumentation-amqplib/test/amqplib-callbacks.test.ts +++ b/plugins/node/instrumentation-amqplib/test/amqplib-callbacks.test.ts @@ -136,6 +136,7 @@ describe('amqplib instrumentation callback model', () => { const [publishSpan, consumeSpan] = getTestSpans(); // assert publish span + expect(publishSpan.name).toMatch('publish '); expect(publishSpan.kind).toEqual(SpanKind.PRODUCER); expect(publishSpan.attributes[SEMATTRS_MESSAGING_SYSTEM]).toEqual( 'rabbitmq'