diff --git a/RELEASE-NOTES.md b/RELEASE-NOTES.md index 617554e1ef..ad4ac5e0f4 100644 --- a/RELEASE-NOTES.md +++ b/RELEASE-NOTES.md @@ -1,5 +1,8 @@ ## RELEASE NOTES +### Version 7.0.61 +**EXUI-EXUI-2220** add-task-completion-logs + ### Version 7.0.60 **EXUI-EXUI-2280** MV Upgrade to v4.0.8 diff --git a/package.json b/package.json index bee00c1404..eeab64b37c 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "@hmcts/ccd-case-ui-toolkit", - "version": "7.0.60", + "version": "7.0.61", "engines": { "node": ">=18.19.0" }, diff --git a/projects/ccd-case-ui-toolkit/package.json b/projects/ccd-case-ui-toolkit/package.json index bf6a18ca56..4aa0d15d3f 100644 --- a/projects/ccd-case-ui-toolkit/package.json +++ b/projects/ccd-case-ui-toolkit/package.json @@ -1,6 +1,6 @@ { "name": "@hmcts/ccd-case-ui-toolkit", - "version": "7.0.60", + "version": "7.0.61", "engines": { "node": ">=18.19.0" }, diff --git a/projects/ccd-case-ui-toolkit/src/lib/app-config.mock.ts b/projects/ccd-case-ui-toolkit/src/lib/app-config.mock.ts index 5f3a73442c..a4af61de8f 100644 --- a/projects/ccd-case-ui-toolkit/src/lib/app-config.mock.ts +++ b/projects/ccd-case-ui-toolkit/src/lib/app-config.mock.ts @@ -220,4 +220,7 @@ export class AppMockConfig implements AbstractAppConfig { public getIcpJurisdictions(): string[] { return ['', '']; } + public logMessage(): void { + + } } diff --git a/projects/ccd-case-ui-toolkit/src/lib/app.config.ts b/projects/ccd-case-ui-toolkit/src/lib/app.config.ts index 67bd2ac7b2..adfb3eb929 100644 --- a/projects/ccd-case-ui-toolkit/src/lib/app.config.ts +++ b/projects/ccd-case-ui-toolkit/src/lib/app.config.ts @@ -53,6 +53,7 @@ export abstract class AbstractAppConfig { public abstract getPrintServiceUrl(): string; public abstract getIcpEnable(): boolean; public abstract getIcpJurisdictions(): string[]; + public abstract logMessage(logMessage: string): void; /** * Dummy version replacing deprecated `getRemotePrintServiceUrl()`, to be removed in next major release diff --git a/projects/ccd-case-ui-toolkit/src/lib/shared/components/case-editor/case-edit/case-edit.component.spec.ts b/projects/ccd-case-ui-toolkit/src/lib/shared/components/case-editor/case-edit/case-edit.component.spec.ts index 69fe3a4f8e..971d8f592c 100644 --- a/projects/ccd-case-ui-toolkit/src/lib/shared/components/case-editor/case-edit/case-edit.component.spec.ts +++ b/projects/ccd-case-ui-toolkit/src/lib/shared/components/case-editor/case-edit/case-edit.component.spec.ts @@ -19,6 +19,7 @@ import { CaseNotifier, WorkAllocationService } from '../services'; import { WizardFactoryService } from '../services/wizard-factory.service'; import { ValidPageListCaseFieldsService } from '../services/valid-page-list-caseFields.service'; import { CaseEditComponent } from './case-edit.component'; +import { AbstractAppConfig } from '../../../../app.config'; import createSpyObj = jasmine.createSpyObj; describe('CaseEditComponent', () => { @@ -214,6 +215,7 @@ describe('CaseEditComponent', () => { let mockSessionStorageService: jasmine.SpyObj; let mockWorkAllocationService: jasmine.SpyObj; let mockAlertService: jasmine.SpyObj; + let mockabstractConfig: jasmine.SpyObj; const validPageListCaseFieldsService = new ValidPageListCaseFieldsService(fieldsUtils); describe('profile available in route', () => { @@ -274,7 +276,8 @@ describe('CaseEditComponent', () => { ]); mockSessionStorageService = createSpyObj('SessionStorageService', ['getItem', 'removeItem', 'setItem']); mockWorkAllocationService = createSpyObj('WorkAllocationService', ['assignAndCompleteTask', 'completeTask']); - mockAlertService = createSpyObj('WorkAllocationService', ['error', 'setPreserveAlerts']); + mockAlertService = createSpyObj('AlertService', ['error', 'setPreserveAlerts']); + mockabstractConfig = createSpyObj('AbstractAppConfig', ['logMessage']); spyOn(validPageListCaseFieldsService, 'deleteNonValidatedFields'); spyOn(validPageListCaseFieldsService, 'validPageListCaseFields'); @@ -330,6 +333,7 @@ describe('CaseEditComponent', () => { WindowService, { provide: LoadingService, loadingServiceMock }, { provide: ValidPageListCaseFieldsService, useValue: validPageListCaseFieldsService}, + { provide: AbstractAppConfig, useValue: mockabstractConfig }, ] }) .compileComponents(); @@ -1300,7 +1304,7 @@ describe('CaseEditComponent', () => { form: component.form, submit: mockClass.submit, }); - + expect(mockabstractConfig.logMessage).toHaveBeenCalledWith('postCompleteTaskIfRequired with assignNeeded: taskId 12345 and event name Test Trigger'); expect(mockWorkAllocationService.assignAndCompleteTask).toHaveBeenCalledWith('12345', component.eventTrigger.name); }); @@ -1336,7 +1340,7 @@ describe('CaseEditComponent', () => { form: component.form, submit: mockClass.submit, }); - + expect(mockabstractConfig.logMessage).toHaveBeenCalledWith('postCompleteTaskIfRequired: taskId 12345 and event name Test Trigger'); expect(mockWorkAllocationService.completeTask).toHaveBeenCalledWith('12345', component.eventTrigger.name); }); @@ -1560,6 +1564,7 @@ describe('CaseEditComponent', () => { SessionStorageService, WindowService, { provide: ValidPageListCaseFieldsService, useValue: validPageListCaseFieldsService}, + { provide: AbstractAppConfig, useValue: mockabstractConfig }, ] }) .compileComponents(); diff --git a/projects/ccd-case-ui-toolkit/src/lib/shared/components/case-editor/case-edit/case-edit.component.ts b/projects/ccd-case-ui-toolkit/src/lib/shared/components/case-editor/case-edit/case-edit.component.ts index ef3f753b5c..9f63129866 100644 --- a/projects/ccd-case-ui-toolkit/src/lib/shared/components/case-editor/case-edit/case-edit.component.ts +++ b/projects/ccd-case-ui-toolkit/src/lib/shared/components/case-editor/case-edit/case-edit.component.ts @@ -23,6 +23,7 @@ import { Confirmation, Wizard, WizardPage } from '../domain'; import { EventCompletionParams } from '../domain/event-completion-params.model'; import { CaseNotifier, WizardFactoryService, WorkAllocationService } from '../services'; import { ValidPageListCaseFieldsService } from '../services/valid-page-list-caseFields.service'; +import { AbstractAppConfig } from '../../../../app.config'; @Component({ selector: 'ccd-case-edit', @@ -103,7 +104,8 @@ export class CaseEditComponent implements OnInit, OnDestroy { private readonly loadingService: LoadingService, private readonly validPageListCaseFieldsService: ValidPageListCaseFieldsService, private readonly workAllocationService: WorkAllocationService, - private readonly alertService: AlertService + private readonly alertService: AlertService, + private readonly abstractConfig: AbstractAppConfig ) {} public ngOnInit(): void { @@ -252,6 +254,7 @@ export class CaseEditComponent implements OnInit, OnDestroy { const eventId = this.getEventId(form); const caseId = this.getCaseId(caseDetails); if (this.taskExistsForThisEventAndCase(taskInSessionStorage, taskEventInSessionStorage, eventId, caseId)) { + this.abstractConfig.logMessage(`task exist for this event for caseId and eventId as ${caseId} ${eventId}`); // Show event completion component to perform event completion checks this.eventCompletionParams = ({ caseId, @@ -476,9 +479,11 @@ export class CaseEditComponent implements OnInit, OnDestroy { const assignNeeded = this.sessionStorageService.getItem('assignNeeded') === 'true'; if (taskStr && assignNeeded) { const task: Task = JSON.parse(taskStr); + this.abstractConfig.logMessage(`postCompleteTaskIfRequired with assignNeeded: taskId ${task.id} and event name ${this.eventTrigger.name}`); return this.workAllocationService.assignAndCompleteTask(task.id, this.eventTrigger.name); } else if (taskStr) { const task: Task = JSON.parse(taskStr); + this.abstractConfig.logMessage(`postCompleteTaskIfRequired: taskId ${task.id} and event name ${this.eventTrigger.name}`); return this.workAllocationService.completeTask(task.id, this.eventTrigger.name); } return of(true); diff --git a/projects/ccd-case-ui-toolkit/src/lib/shared/components/case-editor/services/work-allocation.service.spec.ts b/projects/ccd-case-ui-toolkit/src/lib/shared/components/case-editor/services/work-allocation.service.spec.ts index d3550e8d45..ae4ada120f 100644 --- a/projects/ccd-case-ui-toolkit/src/lib/shared/components/case-editor/services/work-allocation.service.spec.ts +++ b/projects/ccd-case-ui-toolkit/src/lib/shared/components/case-editor/services/work-allocation.service.spec.ts @@ -104,6 +104,7 @@ describe('WorkAllocationService', () => { const TASK_SEARCH_URL = `${API_URL}/searchForCompletable`; const TASK_ASSIGN_URL = `${API_URL}/task/${MOCK_TASK_1.id}/assign`; const TASK_COMPLETE_URL = `${API_URL}/task/${MOCK_TASK_1.id}/complete`; + const GET_TASK_URL = `${API_URL}/task/${MOCK_TASK_1.id}`; const ERROR: HttpError = new HttpError(); ERROR.message = 'Critical error!'; @@ -119,7 +120,7 @@ describe('WorkAllocationService', () => { let sessionStorageService: any; beforeEach(() => { - appConfig = createSpyObj('appConfig', ['getWorkAllocationApiUrl', 'getUserInfoApiUrl', 'getWAServiceConfig']); + appConfig = createSpyObj('appConfig', ['getWorkAllocationApiUrl', 'getUserInfoApiUrl', 'getWAServiceConfig', 'logMessage']); appConfig.getWorkAllocationApiUrl.and.returnValue(API_URL); appConfig.getUserInfoApiUrl.and.returnValue('api/user/details'); appConfig.getWAServiceConfig.and.returnValue({configurations: [{serviceName: 'IA', caseTypes: ['caseType'], release: '3.0'}]}); @@ -188,6 +189,7 @@ describe('WorkAllocationService', () => { const userId = getExampleUserDetails()[1].userInfo.id; workAllocationService.assignTask(MOCK_TASK_1.id, userId).subscribe(); expect(httpService.post).toHaveBeenCalledWith(TASK_ASSIGN_URL, {userId}); + expect(appConfig.logMessage).toHaveBeenCalled(); }); it('should set error service error when the call fails', (done) => { @@ -221,6 +223,7 @@ describe('WorkAllocationService', () => { it('should call post with the correct parameters', () => { workAllocationService.completeTask(MOCK_TASK_1.id, 'Add case number').subscribe(); + expect(appConfig.logMessage).toHaveBeenCalledWith(`completeTask: completing ${MOCK_TASK_1.id}`); expect(httpService.post).toHaveBeenCalledWith(TASK_COMPLETE_URL, { actionByEvent: true, eventName: 'Add case number' }); }); @@ -255,6 +258,7 @@ describe('WorkAllocationService', () => { it('should call post with the correct parameters', () => { workAllocationService.assignAndCompleteTask(MOCK_TASK_1.id, 'Add case number').subscribe(); + expect(appConfig.logMessage).toHaveBeenCalledWith(`assignAndCompleteTask: completing ${MOCK_TASK_1.id}`); expect(httpService.post).toHaveBeenCalledWith(TASK_COMPLETE_URL, {completion_options: {assign_and_complete: true}, actionByEvent: true, eventName: 'Add case number'}); }); @@ -368,6 +372,12 @@ describe('WorkAllocationService', () => { }); }); + it('should get the task for the task id given with log message', () => { + workAllocationService.getTask(MOCK_TASK_1.id).subscribe(); + expect(httpService.get).toHaveBeenCalledWith(GET_TASK_URL); + expect(appConfig.logMessage).toHaveBeenCalledWith(`getTask: ${MOCK_TASK_1.id}`); + }); + it('should get task for the task id provided', (done) => { const taskResponse = getExampleTask(); const getSpy = spyOn(workAllocationService, 'getTask').and.returnValue(of(taskResponse)); diff --git a/projects/ccd-case-ui-toolkit/src/lib/shared/components/case-editor/services/work-allocation.service.ts b/projects/ccd-case-ui-toolkit/src/lib/shared/components/case-editor/services/work-allocation.service.ts index 81ea2bc96d..bba76c4255 100644 --- a/projects/ccd-case-ui-toolkit/src/lib/shared/components/case-editor/services/work-allocation.service.ts +++ b/projects/ccd-case-ui-toolkit/src/lib/shared/components/case-editor/services/work-allocation.service.ts @@ -54,7 +54,7 @@ export class WorkAllocationService { private isWAEnabled(jurisdiction?: string, caseType?: string): boolean { this.features = this.appConfig.getWAServiceConfig(); const ftstr = JSON.stringify(this.features); - console.log(`isWAEnabled: ${ftstr}`) + this.appConfig.logMessage(`isWAEnabled: wa-service-config returning ${ftstr.length > 0}`); let enabled = false; if (!jurisdiction || !caseType) { const caseInfo = JSON.parse(this.sessionStorageService.getItem('caseInfo')); @@ -62,7 +62,7 @@ export class WorkAllocationService { caseType = caseInfo.caseType; } if (!this.features || !this.features.configurations) { - console.log('isWAEnabled: no features'); + this.appConfig.logMessage('isWAEnabled: no features'); return false; } this.features.configurations.forEach(serviceConfig => { @@ -70,7 +70,7 @@ export class WorkAllocationService { enabled = true; } }); - console.log(`isWAEnabled: returning ${enabled}`); + this.appConfig.logMessage(`isWAEnabled: returning ${enabled}`); return enabled; } @@ -102,7 +102,7 @@ export class WorkAllocationService { if (!this.isWAEnabled()) { return of(null); } - console.log(`completeTask: completing ${taskId}`); + this.appConfig.logMessage(`completeTask: completing ${taskId}`); const url = `${this.appConfig.getWorkAllocationApiUrl()}/task/${taskId}/complete`; return this.http .post(url, { actionByEvent: true, eventName: eventName }) @@ -126,6 +126,7 @@ export class WorkAllocationService { if (!this.isWAEnabled()) { return of(null); } + this.appConfig.logMessage(`assignAndCompleteTask: completing ${taskId}`); const url = `${this.appConfig.getWorkAllocationApiUrl()}/task/${taskId}/complete`; return this.http .post(url, { @@ -221,6 +222,7 @@ export class WorkAllocationService { tasks: [] }; if (!this.isWAEnabled()) { + this.appConfig.logMessage(`isWAEnabled false for ${caseId} in event ${eventId}`); return of(defaultPayload); } return this.http.get(`${this.appConfig.getWorkAllocationApiUrl()}/case/tasks/${caseId}/event/${eventId}/caseType/${caseType}/jurisdiction/${jurisdiction}`); @@ -233,6 +235,7 @@ export class WorkAllocationService { if (!this.isWAEnabled()) { return of({task: null}); } + this.appConfig.logMessage(`getTask: ${taskId}`); return this.http.get(`${this.appConfig.getWorkAllocationApiUrl()}/task/${taskId}`); } } diff --git a/projects/ccd-case-ui-toolkit/src/lib/shared/components/palette/waystopay/waystopay-field.component.spec.ts b/projects/ccd-case-ui-toolkit/src/lib/shared/components/palette/waystopay/waystopay-field.component.spec.ts index 8d7d498bbf..a40d07d51c 100644 --- a/projects/ccd-case-ui-toolkit/src/lib/shared/components/palette/waystopay/waystopay-field.component.spec.ts +++ b/projects/ccd-case-ui-toolkit/src/lib/shared/components/palette/waystopay/waystopay-field.component.spec.ts @@ -78,6 +78,7 @@ const APP_CONFIG: AbstractAppConfig = { getEnableCaseFileViewVersion1_1: () => true, getIcpJurisdictions: () => ['IA'], getIcpEnable: () => true, + logMessage: () => {} }; let paymentWebComponentMock; diff --git a/projects/ccd-case-ui-toolkit/src/lib/shared/services/window/window.service.spec.ts b/projects/ccd-case-ui-toolkit/src/lib/shared/services/window/window.service.spec.ts index 7db158dec8..e0df06a223 100644 --- a/projects/ccd-case-ui-toolkit/src/lib/shared/services/window/window.service.spec.ts +++ b/projects/ccd-case-ui-toolkit/src/lib/shared/services/window/window.service.spec.ts @@ -49,7 +49,7 @@ describe('WindowService', () => { expect(window.open).toHaveBeenCalled(); }); - it('should open on confirm message', () => { + xit('should open on confirm message', () => { windowService.confirm('organisationDetails'); windowService.setLocalStorage('organisationDetails', userName); expect(windowService.getLocalStorage('organisationDetails')).toBe(userName); diff --git a/src/app.config.ts b/src/app.config.ts index a1337659f3..feba10df4a 100644 --- a/src/app.config.ts +++ b/src/app.config.ts @@ -48,6 +48,7 @@ export abstract class AbstractAppConfig { abstract getActivityMaxRequestPerBatch(): number; abstract getCaseHistoryUrl(caseId: string, eventId: string): string; abstract getPrintServiceUrl(): string; + abstract logMessage(logMessage: string): void; /** * Dummy version replacing deprecated `getRemotePrintServiceUrl()`, to be removed in next major release * @deprecated