From ab9efb2f028a1e96683131a9826eb0e2b1ae5ea0 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Kamil=20Og=C3=B3rek?= Date: Tue, 15 Jun 2021 12:56:33 +0200 Subject: [PATCH] fix: Include DSN in envelope header for sessions (#3680) * fix: Include DSN in envelope header for sessions * Add url tests for non-tunnel requests --- packages/core/src/request.ts | 1 + packages/core/test/lib/request.test.ts | 54 +++++++++++++++----------- 2 files changed, 32 insertions(+), 23 deletions(-) diff --git a/packages/core/src/request.ts b/packages/core/src/request.ts index de8168a744f7..54197023a2eb 100644 --- a/packages/core/src/request.ts +++ b/packages/core/src/request.ts @@ -33,6 +33,7 @@ export function sessionToSentryRequest(session: Session | SessionAggregates, api const envelopeHeaders = JSON.stringify({ sent_at: new Date().toISOString(), ...(sdkInfo && { sdk: sdkInfo }), + ...(api.forceEnvelope() && { dsn: api.getDsn().toString() }), }); // I know this is hacky but we don't want to add `session` to request type since it's never rate limited const type: SentryRequestType = 'aggregates' in session ? ('sessions' as SentryRequestType) : 'session'; diff --git a/packages/core/test/lib/request.test.ts b/packages/core/test/lib/request.test.ts index 8f560750698f..3419874d1a97 100644 --- a/packages/core/test/lib/request.test.ts +++ b/packages/core/test/lib/request.test.ts @@ -3,7 +3,12 @@ import { DebugMeta, Event, SentryRequest, TransactionSamplingMethod } from '@sen import { API } from '../../src/api'; import { eventToSentryRequest, sessionToSentryRequest } from '../../src/request'; -const api = new API('https://dogsarebadatkeepingsecrets@squirrelchasers.ingest.sentry.io/12312012', { +const ingestDsn = 'https://dogsarebadatkeepingsecrets@squirrelchasers.ingest.sentry.io/12312012'; +const ingestUrl = + 'https://squirrelchasers.ingest.sentry.io/api/12312012/envelope/?sentry_key=dogsarebadatkeepingsecrets&sentry_version=7'; +const tunnel = 'https://hello.com/world'; + +const api = new API(ingestDsn, { sdk: { integrations: ['AWSLambda'], name: 'sentry.javascript.browser', @@ -12,9 +17,6 @@ const api = new API('https://dogsarebadatkeepingsecrets@squirrelchasers.ingest.s }, }); -const ingestDsn = 'https://dogsarebadatkeepingsecrets@squirrelchasers.ingest.sentry.io/12312012'; -const tunnel = 'https://hello.com/world'; - function parseEnvelopeRequest(request: SentryRequest): any { const [envelopeHeaderString, itemHeaderString, eventString] = request.body.split('\n'); @@ -26,19 +28,9 @@ function parseEnvelopeRequest(request: SentryRequest): any { } describe('eventToSentryRequest', () => { - let api: API; let event: Event; beforeEach(() => { - api = new API(ingestDsn, { - sdk: { - integrations: ['AWSLambda'], - name: 'sentry.javascript.browser', - version: `12.31.12`, - packages: [{ name: 'npm:@sentry/browser', version: `12.31.12` }], - }, - }); - event = { contexts: { trace: { trace_id: '1231201211212012', span_id: '12261980', op: 'pageload' } }, environment: 'dogpark', @@ -140,17 +132,15 @@ describe('eventToSentryRequest', () => { }); it('uses tunnel as the url if it is configured', () => { - api = new API(ingestDsn, {}, tunnel); + const tunnelRequest = eventToSentryRequest(event, new API(ingestDsn, {}, tunnel)); + expect(tunnelRequest.url).toEqual(tunnel); - const result = eventToSentryRequest(event, api); - - expect(result.url).toEqual(tunnel); + const defaultRequest = eventToSentryRequest(event, new API(ingestDsn, {})); + expect(defaultRequest.url).toEqual(ingestUrl); }); it('adds dsn to envelope header if tunnel is configured', () => { - api = new API(ingestDsn, {}, tunnel); - - const result = eventToSentryRequest(event, api); + const result = eventToSentryRequest(event, new API(ingestDsn, {}, tunnel)); const envelope = parseEnvelopeRequest(result); expect(envelope.envelopeHeader).toEqual( @@ -161,10 +151,9 @@ describe('eventToSentryRequest', () => { }); it('adds default "event" item type to item header if tunnel is configured', () => { - api = new API(ingestDsn, {}, tunnel); delete event.type; - const result = eventToSentryRequest(event, api); + const result = eventToSentryRequest(event, new API(ingestDsn, {}, tunnel)); const envelope = parseEnvelopeRequest(result); expect(envelope.itemHeader).toEqual( @@ -202,4 +191,23 @@ describe('sessionToSentryRequest', () => { }), ); }); + + it('uses tunnel as the url if it is configured', () => { + const tunnelRequest = sessionToSentryRequest({ aggregates: [] }, new API(ingestDsn, {}, tunnel)); + expect(tunnelRequest.url).toEqual(tunnel); + + const defaultRequest = sessionToSentryRequest({ aggregates: [] }, new API(ingestDsn, {})); + expect(defaultRequest.url).toEqual(ingestUrl); + }); + + it('adds dsn to envelope header if tunnel is configured', () => { + const result = sessionToSentryRequest({ aggregates: [] }, new API(ingestDsn, {}, tunnel)); + const envelope = parseEnvelopeRequest(result); + + expect(envelope.envelopeHeader).toEqual( + expect.objectContaining({ + dsn: ingestDsn, + }), + ); + }); });