diff --git a/lib/shim/message-shim/subscribe-consume.js b/lib/shim/message-shim/subscribe-consume.js index cefd59f5c6..0886f2ec38 100644 --- a/lib/shim/message-shim/subscribe-consume.js +++ b/lib/shim/message-shim/subscribe-consume.js @@ -213,7 +213,7 @@ function createConsumerWrapper({ shim, spec, consumer }) { } } if (msgDesc.headers) { - shim.handleMqTracingHeaders(msgDesc.headers, tx.baseSegment, tx, shim._transportType) + shim.handleMqTracingHeaders(msgDesc.headers, tx.baseSegment, shim._transportType, tx) } shim.logger.trace('Started message transaction %s named %s', tx.id, txName) diff --git a/lib/shim/shim.js b/lib/shim/shim.js index 120a9f6e3a..2e1f46feea 100644 --- a/lib/shim/shim.js +++ b/lib/shim/shim.js @@ -1315,6 +1315,7 @@ function createSegment(name, recorder, parent) { } const transaction = this.tracer.getTransaction() + parent = parent || this.getActiveSegment() const spec = new specs.SegmentSpec(opts) return _rawCreateSegment({ shim: this, spec, parent, transaction }) } diff --git a/lib/shim/transaction-shim.js b/lib/shim/transaction-shim.js index b42254986e..61eb12fff3 100644 --- a/lib/shim/transaction-shim.js +++ b/lib/shim/transaction-shim.js @@ -184,7 +184,7 @@ function setTransactionName(name) { /** * Retrieves whatever CAT headers may be in the given headers. * - * - `handleMqTracingHeaders(headers [, segment [, transportType]])` + * - `handleMqTracingHeaders(headers [, segment ] [, transportType], [, transaction])` * * @memberof TransactionShim.prototype * @@ -195,11 +195,11 @@ function setTransactionName(name) { * @param {TraceSegment} [segment] * The trace segment to associate the header data with. If no segment is * provided then the currently active segment is used. - * @param {Transaction} transaction active transaction * @param {string} [transportType] * The transport type that brought the headers. Usually `HTTP` or `HTTPS`. + * @param {Transaction} transaction active transaction */ -function handleMqTracingHeaders(headers, segment, transaction, transportType) { +function handleMqTracingHeaders(headers, segment, transportType, transaction) { // TODO: replace functionality when CAT fully removed. if (!headers) { @@ -216,6 +216,7 @@ function handleMqTracingHeaders(headers, segment, transaction, transportType) { // Check that we're in an active transaction. const currentSegment = segment || this.getSegment() + transaction = transaction || this.tracer.getTransaction() if (!currentSegment || !transaction.isActive()) { this.logger.trace('Not processing headers for CAT or DT, not in an active transaction.') return diff --git a/test/unit/shim/shim.test.js b/test/unit/shim/shim.test.js index 3563a9d4fe..e3976aa552 100644 --- a/test/unit/shim/shim.test.js +++ b/test/unit/shim/shim.test.js @@ -2117,7 +2117,7 @@ test('Shim', async function (t) { helper.runInTransaction(agent, function (tx) { const args = [wrappable.getActiveSegment] const segment = wrappable.getActiveSegment() - const parent = shim.createSegment({ name: 'test segment', parent: segment }) + const parent = shim.createSegment('test-segment') shim.bindCallbackSegment({}, args, shim.LAST, parent) const cbSegment = args[0]() diff --git a/test/unit/shim/transaction-shim.test.js b/test/unit/shim/transaction-shim.test.js index e6cd12122c..57bbd7083d 100644 --- a/test/unit/shim/transaction-shim.test.js +++ b/test/unit/shim/transaction-shim.test.js @@ -441,7 +441,7 @@ test('TransactionShim', async function (t) { assert.ok(!segment.catTransaction) assert.ok(!segment.getAttributes().transaction_guid) - shim.handleMqTracingHeaders(headers, segment, tx) + shim.handleMqTracingHeaders(headers, segment, null, tx) assert.ok(!tx.incomingCatId) assert.ok(!tx.referringTransactionGuid) @@ -465,7 +465,7 @@ test('TransactionShim', async function (t) { assert.ok(!segment.catTransaction) assert.ok(!segment.getAttributes().transaction_guid) - shim.handleMqTracingHeaders(headers, segment, tx) + shim.handleMqTracingHeaders(headers, segment, null, tx) assert.ok(!tx.incomingCatId) assert.ok(!tx.referringTransactionGuid) @@ -488,7 +488,7 @@ test('TransactionShim', async function (t) { assert.ok(!segment.getAttributes().transaction_guid) assert.doesNotThrow(function () { - shim.handleMqTracingHeaders(null, segment, tx) + shim.handleMqTracingHeaders(null, segment, null, tx) }) assert.ok(!tx.incomingCatId) @@ -516,7 +516,7 @@ test('TransactionShim', async function (t) { helper.runInTransaction(agent, shim.BG, function (tx2) { assert.notEqual(tx2, tx) - shim.handleMqTracingHeaders(headers, segment, tx) + shim.handleMqTracingHeaders(headers, segment, null, tx) }) assert.equal(tx.incomingCatId, '9876#id') @@ -541,7 +541,7 @@ test('TransactionShim', async function (t) { assert.ok(!tx.tripId) assert.ok(!tx.referringPathHash) - shim.handleMqTracingHeaders(headers, null, tx) + shim.handleMqTracingHeaders(headers) assert.equal(tx.incomingCatId, '9876#id') assert.equal(tx.referringTransactionGuid, 'trans id') @@ -568,7 +568,7 @@ test('TransactionShim', async function (t) { helper.runInTransaction(agent, shim.BG, function (tx2) { assert.notEqual(tx2, tx) - shim.handleMqTracingHeaders(headers, segment, tx) + shim.handleMqTracingHeaders(headers, segment, null, tx) }) assert.equal(tx.incomingCatId, '9876#id') @@ -592,7 +592,7 @@ test('TransactionShim', async function (t) { helper.runInTransaction(agent, function (tx) { const headers = { traceparent, tracestate } const segment = shim.getSegment() - shim.handleMqTracingHeaders(headers, segment, tx) + shim.handleMqTracingHeaders(headers, segment) const outboundHeaders = {} tx.insertDistributedTraceHeaders(outboundHeaders) @@ -615,7 +615,7 @@ test('TransactionShim', async function (t) { helper.runInTransaction(agent, function (tx) { const headers = { traceparent } const segment = shim.getSegment() - shim.handleMqTracingHeaders(headers, segment, tx) + shim.handleMqTracingHeaders(headers, segment, null, tx) const outboundHeaders = {} tx.insertDistributedTraceHeaders(outboundHeaders) @@ -638,7 +638,7 @@ test('TransactionShim', async function (t) { helper.runInTransaction(agent, function (tx) { const headers = { traceparent, tracestate } const segment = shim.getSegment() - shim.handleMqTracingHeaders(headers, segment, tx) + shim.handleMqTracingHeaders(headers, segment, null, tx) const outboundHeaders = {} tx.insertDistributedTraceHeaders(outboundHeaders) @@ -660,7 +660,7 @@ test('TransactionShim', async function (t) { helper.runInTransaction(agent, function (tx) { const headers = { traceparent, tracestate } const segment = shim.getSegment() - shim.handleMqTracingHeaders(headers, segment, tx) + shim.handleMqTracingHeaders(headers, segment, null, tx) const outboundHeaders = {} tx.insertDistributedTraceHeaders(outboundHeaders) @@ -687,7 +687,7 @@ test('TransactionShim', async function (t) { helper.runInTransaction(agent, shim.BG, function (tx2) { assert.notEqual(tx2, tx) - shim.handleMqTracingHeaders(headers, segment, tx2) + shim.handleMqTracingHeaders(headers, segment, null, tx2) }) assert.equal(segment.catId, '6789#app') @@ -712,7 +712,7 @@ test('TransactionShim', async function (t) { assert.ok(!segment.catTransaction) assert.ok(!segment.getAttributes().transaction_guid) - shim.handleMqTracingHeaders(headers, null, tx) + shim.handleMqTracingHeaders(headers, null, null, tx) assert.equal(segment.catId, '6789#app') assert.equal(segment.catTransaction, 'app data transaction name') @@ -738,7 +738,7 @@ test('TransactionShim', async function (t) { helper.runInTransaction(agent, shim.BG, function (tx2) { assert.notEqual(tx2, tx) - shim.handleMqTracingHeaders(headers, segment, tx2) + shim.handleMqTracingHeaders(headers, segment, null, tx2) }) assert.equal(segment.catId, '6789#app') @@ -764,7 +764,7 @@ test('TransactionShim', async function (t) { assert.ok(!segment.catTransaction) assert.ok(!segment.getAttributes().transaction_guid) - shim.handleMqTracingHeaders(headers, null, tx) + shim.handleMqTracingHeaders(headers, null, null, tx) assert.ok(!segment.catId) assert.ok(!segment.catTransaction) diff --git a/test/versioned/aws-sdk-v3/lambda.test.js b/test/versioned/aws-sdk-v3/lambda.test.js index f163bc1e92..b98c248415 100644 --- a/test/versioned/aws-sdk-v3/lambda.test.js +++ b/test/versioned/aws-sdk-v3/lambda.test.js @@ -21,7 +21,7 @@ const { match } = require('../../lib/custom-assertions') function checkEntityLinkingSegments({ operations, tx, end }) { const root = tx.trace.root - const segments = checkAWSAttributes(root, EXTERN_PATTERN) + const segments = checkAWSAttributes({ trace: tx.trace, segment: root, pattern: EXTERN_PATTERN }) const accountId = tx.agent.config.cloud.aws.account_id const testFunctionName = 'funcName' @@ -47,7 +47,7 @@ function checkNonLinkableSegments({ operations, tx, end }) { // When no account ID or ARN is available, make sure not to set cloud resource id or platform const root = tx.trace.root - const segments = checkAWSAttributes(root, EXTERN_PATTERN) + const segments = checkAWSAttributes({ trace: tx.trace, segment: root, pattern: EXTERN_PATTERN }) const accountId = tx.agent.config?.cloud?.aws?.account_id assert(segments.length > 0, 'should have segments')