From 4ed223b4169f6b5dfcc951fc86d6b1b1b6752091 Mon Sep 17 00:00:00 2001 From: MartenH <72463136+mhennoch@users.noreply.github.com> Date: Thu, 10 Dec 2020 20:07:47 +0200 Subject: [PATCH] fix(plugin-document-load): check if getEntriesByType is available before using it (#259) * fix(plugin-document-load): check if getEntriesByType is available before using it * fix: lint Co-authored-by: Bartlomiej Obecny --- .../src/types.ts | 4 +- .../src/documentLoad.ts | 4 +- .../test/documentLoad.test.ts | 51 +++++++++++++------ 3 files changed, 39 insertions(+), 20 deletions(-) diff --git a/plugins/node/opentelemetry-instrumentation-graphql/src/types.ts b/plugins/node/opentelemetry-instrumentation-graphql/src/types.ts index 9c157e5d92..c3c78b3653 100644 --- a/plugins/node/opentelemetry-instrumentation-graphql/src/types.ts +++ b/plugins/node/opentelemetry-instrumentation-graphql/src/types.ts @@ -63,9 +63,7 @@ export interface GraphQLInstrumentationConfig { /** * Merged and parsed config of default instrumentation config and GraphQL */ -export type GraphQLInstrumentationParsedConfig = Required< - GraphQLInstrumentationConfig -> & +export type GraphQLInstrumentationParsedConfig = Required & InstrumentationConfig; export type executeFunctionWithObj = ( diff --git a/plugins/web/opentelemetry-plugin-document-load/src/documentLoad.ts b/plugins/web/opentelemetry-plugin-document-load/src/documentLoad.ts index 7becf0a299..2cd3242051 100644 --- a/plugins/web/opentelemetry-plugin-document-load/src/documentLoad.ts +++ b/plugins/web/opentelemetry-plugin-document-load/src/documentLoad.ts @@ -73,7 +73,7 @@ export class DocumentLoad extends BasePlugin { * @param rootSpan */ private _addResourcesSpans(rootSpan: Span): void { - const resources: PerformanceResourceTiming[] = otperformance.getEntriesByType( + const resources: PerformanceResourceTiming[] = otperformance.getEntriesByType?.( 'resource' ) as PerformanceResourceTiming[]; if (resources) { @@ -163,7 +163,7 @@ export class DocumentLoad extends BasePlugin { */ private _getEntries() { const entries: PerformanceEntries = {}; - const performanceNavigationTiming = (otperformance.getEntriesByType( + const performanceNavigationTiming = (otperformance.getEntriesByType?.( 'navigation' )[0] as unknown) as PerformanceEntries; diff --git a/plugins/web/opentelemetry-plugin-document-load/test/documentLoad.test.ts b/plugins/web/opentelemetry-plugin-document-load/test/documentLoad.test.ts index 6e2ce8ebf7..609cda203a 100644 --- a/plugins/web/opentelemetry-plugin-document-load/test/documentLoad.test.ts +++ b/plugins/web/opentelemetry-plugin-document-load/test/documentLoad.test.ts @@ -511,21 +511,7 @@ describe('DocumentLoad Plugin', () => { }); }); - describe('when navigation entries types are NOT available then fallback to "performance.timing"', () => { - let spyEntries: any; - beforeEach(() => { - spyEntries = sinon.stub(window.performance, 'getEntriesByType'); - spyEntries.withArgs('navigation').returns([]); - spyEntries.withArgs('resource').returns([]); - Object.defineProperty(window.performance, 'timing', { - writable: true, - value: entriesFallback, - }); - }); - afterEach(() => { - spyEntries.restore(); - }); - + function shouldExportCorrectSpan() { it('should export correct span with events', done => { const spyOnEnd = sinon.spy(dummyExporter, 'export'); plugin.enable(moduleExports, provider, logger, config); @@ -557,6 +543,41 @@ describe('DocumentLoad Plugin', () => { done(); }); }); + } + + describe('when navigation entries types are NOT available then fallback to "performance.timing"', () => { + let spyEntries: any; + beforeEach(() => { + spyEntries = sinon.stub(window.performance, 'getEntriesByType'); + spyEntries.withArgs('navigation').returns([]); + spyEntries.withArgs('resource').returns([]); + + Object.defineProperty(window.performance, 'timing', { + writable: true, + value: entriesFallback, + }); + }); + afterEach(() => { + spyEntries.restore(); + }); + + shouldExportCorrectSpan(); + }); + + describe('when getEntriesByType is not defined then fallback to "performance.timing"', () => { + beforeEach(() => { + Object.defineProperty(window.performance, 'getEntriesByType', { + writable: true, + value: undefined, + }); + + Object.defineProperty(window.performance, 'timing', { + writable: true, + value: entriesFallback, + }); + }); + + shouldExportCorrectSpan(); }); describe('when navigation entries types and "performance.timing" are NOT available', () => {