From 3f58366b0e01aa723d9d3bbb9fe8549d3082eb8e Mon Sep 17 00:00:00 2001 From: Michael Grosse Huelsewiesche Date: Wed, 25 Sep 2024 15:25:54 -0400 Subject: [PATCH] CDN URL on Analytics Settings (#1157) --- .changeset/angry-items-change.md | 5 +++++ .../browser/src/browser/__tests__/integration.test.ts | 1 + .../src/browser/__tests__/standalone-analytics.test.ts | 6 ++++-- packages/browser/src/browser/index.ts | 10 ++++------ packages/browser/src/core/analytics/index.ts | 5 ++++- .../src/plugins/segmentio/__tests__/retries.test.ts | 1 + 6 files changed, 19 insertions(+), 9 deletions(-) create mode 100644 .changeset/angry-items-change.md diff --git a/.changeset/angry-items-change.md b/.changeset/angry-items-change.md new file mode 100644 index 000000000..40d400b39 --- /dev/null +++ b/.changeset/angry-items-change.md @@ -0,0 +1,5 @@ +--- +'@segment/analytics-next': minor +--- + +Refactoring CDN Url to be available from analytics settings diff --git a/packages/browser/src/browser/__tests__/integration.test.ts b/packages/browser/src/browser/__tests__/integration.test.ts index 0d06e19a4..913b1a471 100644 --- a/packages/browser/src/browser/__tests__/integration.test.ts +++ b/packages/browser/src/browser/__tests__/integration.test.ts @@ -1045,6 +1045,7 @@ describe('public settings api', () => { writeKey, cdnSettings: cdnSettingsMinimal, timeout: 300, + cdnURL: 'https://cdn.segment.com', }) }) diff --git a/packages/browser/src/browser/__tests__/standalone-analytics.test.ts b/packages/browser/src/browser/__tests__/standalone-analytics.test.ts index ad2322fcb..d2bbd3d78 100644 --- a/packages/browser/src/browser/__tests__/standalone-analytics.test.ts +++ b/packages/browser/src/browser/__tests__/standalone-analytics.test.ts @@ -132,7 +132,9 @@ describe('standalone bundle', () => { // @ts-ignore ignore Response required fields .mockImplementation((): Promise => fetchSettings) - await loadCDNSettings(segmentDotCom) + const mockCdn = 'https://cdn.foo.com' + + await loadCDNSettings(segmentDotCom, mockCdn) expect(unfetch).toHaveBeenCalledWith( 'https://cdn.foo.com/v1/projects/foo/settings' @@ -147,7 +149,7 @@ describe('standalone bundle', () => { const mockCdn = 'http://my-overridden-cdn.com' getGlobalAnalytics()!._cdn = mockCdn - await loadCDNSettings(segmentDotCom) + await loadCDNSettings(segmentDotCom, mockCdn) expect(unfetch).toHaveBeenCalledWith(expect.stringContaining(mockCdn)) }) diff --git a/packages/browser/src/browser/index.ts b/packages/browser/src/browser/index.ts index 64d577f56..c9d1927ec 100644 --- a/packages/browser/src/browser/index.ts +++ b/packages/browser/src/browser/index.ts @@ -148,10 +148,8 @@ export interface AnalyticsBrowserSettings { export function loadCDNSettings( writeKey: string, - cdnURL?: string + baseUrl: string ): Promise { - const baseUrl = cdnURL ?? getCDN() - return fetch(`${baseUrl}/v1/projects/${writeKey}/settings`) .then((res) => { if (!res.ok) { @@ -355,9 +353,9 @@ async function loadAnalytics( preInitBuffer.add(new PreInitMethodCall('page', [])) } + const cdnURL = settings.cdnURL ?? getCDN() let cdnSettings = - settings.cdnSettings ?? - (await loadCDNSettings(settings.writeKey, settings.cdnURL)) + settings.cdnSettings ?? (await loadCDNSettings(settings.writeKey, cdnURL)) if (options.updateCDNSettings) { cdnSettings = options.updateCDNSettings(cdnSettings) @@ -379,7 +377,7 @@ async function loadAnalytics( ...options, } - const analytics = new Analytics({ ...settings, cdnSettings }, options) + const analytics = new Analytics({ ...settings, cdnSettings, cdnURL }, options) attachInspector(analytics) diff --git a/packages/browser/src/core/analytics/index.ts b/packages/browser/src/core/analytics/index.ts index a21120e59..976f3c8a1 100644 --- a/packages/browser/src/core/analytics/index.ts +++ b/packages/browser/src/core/analytics/index.ts @@ -80,9 +80,10 @@ export class AnalyticsInstanceSettings { * This is an unstable API, it may change in the future without warning. */ readonly cdnSettings: CDNSettings + readonly cdnURL?: string /** - * Auto-track specific timeout setting for legacy purposes. + * Auto-track specific timeout setting for legacy purposes. */ timeout = 300 @@ -92,6 +93,7 @@ export class AnalyticsInstanceSettings { integrations: {}, edgeFunction: {}, } + this.cdnURL = settings.cdnURL } } @@ -101,6 +103,7 @@ export class AnalyticsInstanceSettings { export interface AnalyticsSettings { writeKey: string cdnSettings?: CDNSettings + cdnURL?: string } export interface InitOptions { diff --git a/packages/browser/src/plugins/segmentio/__tests__/retries.test.ts b/packages/browser/src/plugins/segmentio/__tests__/retries.test.ts index a3ed608f0..20fe9452c 100644 --- a/packages/browser/src/plugins/segmentio/__tests__/retries.test.ts +++ b/packages/browser/src/plugins/segmentio/__tests__/retries.test.ts @@ -52,6 +52,7 @@ describe('Segment.io retries 500s and 429', () => { }) test('delays retry on 429', async () => { + jest.useFakeTimers({ advanceTimers: true }) const headers = new Headers() const resetTime = 1234 headers.set('x-ratelimit-reset', resetTime.toString())