From 31aa39bda3ab1fc42d8c7840b5c67d30162c1280 Mon Sep 17 00:00:00 2001 From: "Kamat, Trivikram" <16024985+trivikr@users.noreply.github.com> Date: Wed, 15 Jan 2025 09:42:57 -0800 Subject: [PATCH] test(aws-sdk): use sinon to test propagation.inject calls --- .../test/MessageAttributes.test.ts | 14 ++++++++++---- 1 file changed, 10 insertions(+), 4 deletions(-) diff --git a/plugins/node/opentelemetry-instrumentation-aws-sdk/test/MessageAttributes.test.ts b/plugins/node/opentelemetry-instrumentation-aws-sdk/test/MessageAttributes.test.ts index 826fa3f15e..2720b50e7c 100644 --- a/plugins/node/opentelemetry-instrumentation-aws-sdk/test/MessageAttributes.test.ts +++ b/plugins/node/opentelemetry-instrumentation-aws-sdk/test/MessageAttributes.test.ts @@ -14,7 +14,9 @@ * limitations under the License. */ +import { propagation } from '@opentelemetry/api'; import { expect } from 'expect'; +import * as sinon from 'sinon'; import { MAX_MESSAGE_ATTRIBUTES, contextGetter, @@ -71,6 +73,7 @@ describe('MessageAttributes', () => { describe('injectPropagationContext', () => { it('should inject context if there are available attributes', () => { + sinon.spy(propagation, "inject"); const contextAttributes = { key1: { DataType: 'String', StringValue: 'value1' }, key2: { DataType: 'String', StringValue: 'value2' }, @@ -79,12 +82,14 @@ describe('MessageAttributes', () => { key5: { DataType: 'String', StringValue: 'value5' }, }; - expect(Object.keys(contextAttributes).length).toBe(5); injectPropagationContext(contextAttributes); - expect(Object.keys(contextAttributes).length).toBeGreaterThan(5); + // @ts-expect-error Property 'calledOnce' does not exist on type + expect(propagation.inject.calledOnce).toBe(true); + sinon.restore(); }); it('should not inject context if there not enough available attributes', () => { + sinon.spy(propagation, "inject"); const contextAttributes = { key1: { DataType: 'String', StringValue: 'value1' }, key2: { DataType: 'String', StringValue: 'value2' }, @@ -98,9 +103,10 @@ describe('MessageAttributes', () => { key10: { DataType: 'String', StringValue: 'value10' }, }; - expect(Object.keys(contextAttributes).length).toBe(10); injectPropagationContext(contextAttributes); - expect(Object.keys(contextAttributes).length).toBe(10); + // @ts-expect-error Property 'calledOnce' does not exist on type + expect(propagation.inject.calledOnce).toBe(false); + sinon.restore(); }); });