import type { BreadcrumbFrameEvent, OptionFrameEvent, SpanFrameEvent, } from 'sentry/utils/replays/types'; import {EventType} from 'sentry/utils/replays/types'; type Overwrite = Pick> & U; type TestableFrameEvent< FrameEvent extends BreadcrumbFrameEvent | SpanFrameEvent | OptionFrameEvent, > = Overwrite< Omit, { data: Omit; timestamp: Date; } >; /** * `replayBreadcrumbFrameData.tsx` has factories to help construct the correct payloads. * * ``` * ReplayBreadcrumbFrameEventFixture({ * timestamp, * data: { * payload: {...}, * }, * }); * ``` */ export function ReplayBreadcrumbFrameEventFixture( fields: TestableFrameEvent ): BreadcrumbFrameEvent { return { type: EventType.Custom, timestamp: fields.timestamp.getTime(), // frame timestamps are in ms data: { tag: 'breadcrumb', payload: fields.data.payload, metric: fields.data.metric, }, }; } /** * `replaySpanFrameData.tsx` has factories to help consturt valid payloads given an operation name. * * ``` * ReplaySpanFrameEventFixture({ * timestamp, * data: { * payload: ReplayNavigationFrameFixture({ * data: {...} * }), * }, * }); * ``` */ export function ReplaySpanFrameEventFixture( fields: TestableFrameEvent ): SpanFrameEvent { return { type: EventType.Custom, timestamp: fields.timestamp.getTime(), // frame timestamps are in ms data: { tag: 'performanceSpan', payload: fields.data.payload, }, }; } export function ReplayOptionFrameEventFixture( fields: TestableFrameEvent ): OptionFrameEvent { return { type: EventType.Custom, timestamp: fields.timestamp.getTime(), // frame timestamps are in ms data: { tag: 'options', payload: fields.data.payload, }, }; } export function ReplayOptionFrameFixture( fields: Partial = {} ): OptionFrameEvent['data']['payload'] { return { blockAllMedia: false, errorSampleRate: 0, maskAllInputs: false, maskAllText: false, networkCaptureBodies: false, networkDetailHasUrls: false, networkRequestHasHeaders: false, networkResponseHasHeaders: false, sessionSampleRate: 0, shouldRecordCanvas: false, useCompression: false, useCompressionOption: false, ...fields, }; }