From 8c2ae58ed199094db72ab88552ef43a2b2a7b00b Mon Sep 17 00:00:00 2001 From: iamacook Date: Mon, 25 Sep 2023 11:13:01 +0200 Subject: [PATCH] fix: test --- .../hooks/__tests__/useNotificationTracking.test.ts | 12 ++++++++++++ 1 file changed, 12 insertions(+) diff --git a/src/components/settings/PushNotifications/hooks/__tests__/useNotificationTracking.test.ts b/src/components/settings/PushNotifications/hooks/__tests__/useNotificationTracking.test.ts index c8601fb782..1e8e834ea0 100644 --- a/src/components/settings/PushNotifications/hooks/__tests__/useNotificationTracking.test.ts +++ b/src/components/settings/PushNotifications/hooks/__tests__/useNotificationTracking.test.ts @@ -2,6 +2,7 @@ import 'fake-indexeddb/auto' import { entries, setMany } from 'idb-keyval' import * as tracking from '@/services/analytics' +import * as useChains from '@/hooks/useChains' import { PUSH_NOTIFICATION_EVENTS } from '@/services/analytics/events/push-notifications' import { createNotificationTrackingIndexedDb } from '@/services/push-notifications/tracking' import { WebhookType } from '@/service-workers/firebase-messaging/webhook-types' @@ -19,7 +20,17 @@ describe('useNotificationTracking', () => { jest.clearAllMocks() }) + it('should not track if the feature flag is disabled', async () => { + jest.spyOn(useChains, 'useHasFeature').mockReturnValue(false) + jest.spyOn(tracking, 'trackEvent') + + renderHook(() => useNotificationTracking()) + + expect(tracking.trackEvent).not.toHaveBeenCalled() + }) + it('should track all cached events and clear the cache', async () => { + jest.spyOn(useChains, 'useHasFeature').mockReturnValue(true) jest.spyOn(tracking, 'trackEvent') const cache = { @@ -73,6 +84,7 @@ describe('useNotificationTracking', () => { }) it('should not track if no cache exists', async () => { + jest.spyOn(useChains, 'useHasFeature').mockReturnValue(true) jest.spyOn(tracking, 'trackEvent') const _entries = await entries(createNotificationTrackingIndexedDb())