From 325a914ff3cc89303413aa98f201994b2d7cd803 Mon Sep 17 00:00:00 2001 From: Suyash Patil <127177049+suyashpatil78@users.noreply.github.com> Date: Mon, 16 Oct 2023 18:25:47 +0530 Subject: [PATCH] test: some branches in app-version service (#2508) --- .../core/services/app-version.service.spec.ts | 48 +++++++++++++++---- 1 file changed, 39 insertions(+), 9 deletions(-) diff --git a/src/app/core/services/app-version.service.spec.ts b/src/app/core/services/app-version.service.spec.ts index 37916fbf02..1a878a97fd 100644 --- a/src/app/core/services/app-version.service.spec.ts +++ b/src/app/core/services/app-version.service.spec.ts @@ -58,6 +58,22 @@ describe('AppVersionService', () => { it('should check if a mobile app version is lower than other', () => { expect(appVersionService.isVersionLower('5.57.0', '5.56.0')).toBeFalse(); }); + + it('should return true if version1 is undefined', () => { + expect(appVersionService.isVersionLower(undefined, '5.56.0')).toBeTrue(); + }); + + it('should return true if version1 has no digit after decimal in version number', () => { + expect(appVersionService.isVersionLower('5.56.', '5.56.5')).toBeTrue(); + }); + + it('should return false if version2 has no digit after decimal in version number', () => { + expect(appVersionService.isVersionLower('5.56.5', '5.56.')).toBeFalse(); + }); + + it('should return false if version1 and version2 are empty strings', () => { + expect(appVersionService.isVersionLower('', '')).toBeFalse(); + }); }); it('get(): should get app version', (done) => { @@ -141,16 +157,30 @@ describe('AppVersionService', () => { }); }); - it("getUserAppVersionDetails(): should get user's app version details", (done) => { - spyOn(appVersionService, 'isSupported').and.returnValue(of({ supported: true })); - loginInfoService.getLastLoggedInVersion.and.returnValue(of('5.50.0')); - authService.getEou.and.returnValue(Promise.resolve(apiEouRes)); + describe('getUserAppVersionDetails():', () => { + beforeEach(() => { + spyOn(appVersionService, 'isSupported').and.returnValue(of({ supported: true })); + loginInfoService.getLastLoggedInVersion.and.returnValue(of('5.50.0')); + authService.getEou.and.returnValue(Promise.resolve(apiEouRes)); + }); - appVersionService.getUserAppVersionDetails(extendedDeviceInfoMockData).subscribe(() => { - expect(appVersionService.isSupported).toHaveBeenCalledOnceWith(extendedDeviceInfoMockData); - expect(loginInfoService.getLastLoggedInVersion).toHaveBeenCalledTimes(1); - expect(authService.getEou).toHaveBeenCalledTimes(1); + it("getUserAppVersionDetails(): should get user's app version details", (done) => { + appVersionService.getUserAppVersionDetails(extendedDeviceInfoMockData).subscribe(() => { + expect(appVersionService.isSupported).toHaveBeenCalledOnceWith(extendedDeviceInfoMockData); + expect(loginInfoService.getLastLoggedInVersion).toHaveBeenCalledTimes(1); + expect(authService.getEou).toHaveBeenCalledTimes(1); + }); + done(); + }); + + it("getUserAppVersionDetails(): should get user's app version details if supported is false", (done) => { + appVersionService.isSupported = jasmine.createSpy().and.returnValue(of({ supported: false })); + appVersionService.getUserAppVersionDetails(extendedDeviceInfoMockData).subscribe(() => { + expect(appVersionService.isSupported).toHaveBeenCalledOnceWith(extendedDeviceInfoMockData); + expect(loginInfoService.getLastLoggedInVersion).toHaveBeenCalledTimes(1); + expect(authService.getEou).toHaveBeenCalledTimes(1); + }); + done(); }); - done(); }); });