From fba30130dfd0363900486b34663703c46603606b Mon Sep 17 00:00:00 2001 From: sherwinski Date: Thu, 14 Nov 2024 15:27:45 -0500 Subject: [PATCH 1/3] chore: add test script with watch flag --- package.json | 1 + 1 file changed, 1 insertion(+) diff --git a/package.json b/package.json index 4d3266441..be6b5b5ce 100644 --- a/package.json +++ b/package.json @@ -34,6 +34,7 @@ "build:staging": "ENV=staging yarn transpile:sources && ENV=staging yarn bundle-sw && ENV=staging yarn bundle-sdk && ENV=staging yarn bundle-page-sdk-es6 && ENV=staging build/scripts/publish.sh", "build:prod": "ENV=production yarn transpile:sources && ENV=production yarn bundle-sw && ENV=production yarn bundle-sdk && ENV=production yarn bundle-page-sdk-es6 && bundlesize && ENV=production build/scripts/publish.sh", "test": "NODE_OPTIONS=\"--trace-warnings --unhandled-rejections=warn\" yarn run jest --detectOpenHandles --forceExit --runInBand", + "test:watch": "NODE_OPTIONS=\"--trace-warnings --unhandled-rejections=warn\" yarn run jest --detectOpenHandles --forceExit --runInBand --watch", "publish": "yarn clean && yarn build:prod && yarn", "build:dev-dev": "./build/scripts/build.sh -f development -t development -a localhost", "build:dev-prod": "./build/scripts/build.sh -f development -t production", From ffad6d6d0d4de6365d18963abc508bbefcf18394 Mon Sep 17 00:00:00 2001 From: sherwinski Date: Thu, 14 Nov 2024 15:57:50 -0500 Subject: [PATCH 2/3] test: suppress PushPermissionNotGrantedError --- __test__/unit/push/registerForPush.test.ts | 2 ++ 1 file changed, 2 insertions(+) diff --git a/__test__/unit/push/registerForPush.test.ts b/__test__/unit/push/registerForPush.test.ts index 76080a535..eac2d4e3e 100644 --- a/__test__/unit/push/registerForPush.test.ts +++ b/__test__/unit/push/registerForPush.test.ts @@ -1,6 +1,7 @@ import { TestEnvironment } from '../../support/environment/TestEnvironment'; import InitHelper from '../../../src/shared/helpers/InitHelper'; import OneSignalEvent from '../../../src/shared/services/OneSignalEvent'; +import Log from '../../../src/shared/libraries/Log'; import BrowserUserAgent from '../../support/models/BrowserUserAgent'; //stub dismisshelper @@ -9,6 +10,7 @@ jest.mock('../../../src/shared/helpers/DismissHelper'); describe('Register for push', () => { beforeEach(async () => { jest.useFakeTimers(); + jest.spyOn(Log, 'error').mockImplementation(() => {}) await TestEnvironment.initialize({ addPrompts: true, userAgent: BrowserUserAgent.Default, From b407469d7fdc4572d23dca646ac2e6717d1ffc19 Mon Sep 17 00:00:00 2001 From: sherwinski Date: Mon, 18 Nov 2024 15:22:39 -0500 Subject: [PATCH 3/3] test: update Log mocking in registerForPush tests - Replace manual Log.error spy with Jest mock - Add complete mock implementation for Log methods (error, warn, info, debug) - Add explicit assertions for Log.error calls --- __test__/unit/push/registerForPush.test.ts | 12 +++++++++++- 1 file changed, 11 insertions(+), 1 deletion(-) diff --git a/__test__/unit/push/registerForPush.test.ts b/__test__/unit/push/registerForPush.test.ts index eac2d4e3e..fda38ce89 100644 --- a/__test__/unit/push/registerForPush.test.ts +++ b/__test__/unit/push/registerForPush.test.ts @@ -7,10 +7,18 @@ import BrowserUserAgent from '../../support/models/BrowserUserAgent'; //stub dismisshelper jest.mock('../../../src/shared/helpers/DismissHelper'); +//stub log +jest.mock('../../../src/shared/libraries/Log', () => ({ + debug: jest.fn(), + trace: jest.fn(), + info: jest.fn(), + warn: jest.fn(), + error: jest.fn(), +})); + describe('Register for push', () => { beforeEach(async () => { jest.useFakeTimers(); - jest.spyOn(Log, 'error').mockImplementation(() => {}) await TestEnvironment.initialize({ addPrompts: true, userAgent: BrowserUserAgent.Default, @@ -31,6 +39,7 @@ describe('Register for push', () => { expect(spy).not.toHaveBeenCalled(); OneSignalEvent.trigger(OneSignal.EVENTS.SDK_INITIALIZED); await promise; + expect(Log.error).toHaveBeenCalled(); expect(OneSignal.initialized).toBe(true); expect(spy).toHaveBeenCalledTimes(1); }); @@ -41,6 +50,7 @@ describe('Register for push', () => { const spy = jest.spyOn(InitHelper, 'registerForPushNotifications'); await InitHelper.registerForPushNotifications(); + expect(Log.error).toHaveBeenCalled(); expect(spy).toHaveBeenCalledTimes(1); }); });