From aee95c1f6e02dcb739e7164b30d26849fe7405f8 Mon Sep 17 00:00:00 2001 From: ronenk1 Date: Thu, 9 Mar 2023 10:01:16 +0200 Subject: [PATCH 1/4] feat: first commit for new cleanup managment logic --- src/clients/jobManagerWrapper.ts | 13 +++++--- src/common/interfaces.ts | 7 ++++ .../models/createPackageManager.ts | 2 -- src/tasks/models/tasksManager.ts | 32 +++++++++++++++---- 4 files changed, 42 insertions(+), 12 deletions(-) diff --git a/src/clients/jobManagerWrapper.ts b/src/clients/jobManagerWrapper.ts index 4923355..1ea2283 100644 --- a/src/clients/jobManagerWrapper.ts +++ b/src/clients/jobManagerWrapper.ts @@ -66,7 +66,6 @@ export class JobManagerWrapper extends JobManagerClient { resourceId: data.cswProductId, version: data.version, type: this.tilesJobType, - expirationDate, domain: this.jobDomain, parameters: { sanitizedBbox: data.sanitizedBbox, @@ -122,7 +121,6 @@ export class JobManagerWrapper extends JobManagerClient { resourceId: data.cswProductId, version: data.version, type: this.tilesJobType, - expirationDate, domain: this.jobDomain, parameters: jobParameters, internalId: data.dbId, @@ -274,9 +272,16 @@ export class JobManagerWrapper extends JobManagerClient { if (job) { const oldExpirationDate = new Date(job.expirationDate as Date); if (oldExpirationDate < newExpirationDate) { - this.logger.info({ jobId, oldExpirationDate, newExpirationDate }, 'Will execute update for expirationDate'); + this.logger.info({ jobId, oldExpirationDate, newExpirationDate, msg: 'update expirationDate' }); await this.put(getOrUpdateURL, { - expirationDate: newExpirationDate, + parameters: { + ...job.parameters, + cleanupData: { + ...job.parameters.cleanupData, + cleanupExpirationTime: newExpirationDate, + directoryPath: job.parameters.relativeDirectoryPath, + }, + }, }); } else { const msg = 'Will not update expiration date, as current expiration date is later than current expiration date'; diff --git a/src/common/interfaces.ts b/src/common/interfaces.ts index daa9e79..6848392 100644 --- a/src/common/interfaces.ts +++ b/src/common/interfaces.ts @@ -21,6 +21,11 @@ export interface IBaseCreatePackage { priority?: number; } +export interface ICleanupData { + directoryPath?: string; + cleanupExpirationTime?: Date; +} + /** * @deprecated GetMap API - will be deprecated on future */ @@ -174,6 +179,7 @@ export interface IJobParameters { callbackParams?: ICallbackDataBase; fileName: string; gpkgEstimatedSize?: number; + cleanupData?: ICleanupData; } export interface IJobExportParameters { @@ -185,6 +191,7 @@ export interface IJobExportParameters { callbackParams?: ICallbackExportResponse; fileNamesTemplates: ILinkDefinition; gpkgEstimatedSize?: number; + cleanupData?: ICleanupData; } export declare type MergerSourceType = 'S3' | 'GPKG' | 'FS'; diff --git a/src/createPackage/models/createPackageManager.ts b/src/createPackage/models/createPackageManager.ts index 1345c98..6711208 100644 --- a/src/createPackage/models/createPackageManager.ts +++ b/src/createPackage/models/createPackageManager.ts @@ -638,7 +638,6 @@ export class CreatePackageManager { const processingJob = (await this.jobManagerClient.findInProgressJob(dupParams)) ?? (await this.jobManagerClient.findPendingJob(dupParams)); if (processingJob) { await this.updateCallbackURLs(processingJob, newCallbacks); - await this.jobManagerClient.validateAndUpdateExpiration(processingJob.id); return { id: processingJob.id, taskIds: (processingJob.tasks as unknown as IJobResponse[]).map((t) => t.id), @@ -657,7 +656,6 @@ export class CreatePackageManager { (await this.jobManagerClient.findExportJob(OperationStatus.PENDING, dupParams, true)); if (processingJob) { await this.updateExportCallbackURLs(processingJob, newCallbacks); - await this.jobManagerClient.validateAndUpdateExpiration(processingJob.id); return { id: processingJob.id, taskIds: (processingJob.tasks as unknown as IJobResponse[]).map((t) => t.id), diff --git a/src/tasks/models/tasksManager.ts b/src/tasks/models/tasksManager.ts index 6c27669..29f4e04 100644 --- a/src/tasks/models/tasksManager.ts +++ b/src/tasks/models/tasksManager.ts @@ -12,6 +12,7 @@ import { ICallbackDataExportBase, ICallbackExportData, ICallbackExportResponse, + ICleanupData, IExportJobStatusResponse, IJobExportParameters, IJobParameters, @@ -171,8 +172,15 @@ export class TasksManager { reason, /* eslint-disable-next-line @typescript-eslint/no-magic-numbers */ percentage: isSuccess ? 100 : undefined, - expirationDate: expirationDate, }; + + const cleanupData: ICleanupData = { + directoryPath: job.parameters.relativeDirectoryPath, + cleanupExpirationTime: expirationDate, + }; + + this.logger.info({ jobId: job.id, cleanupData, msg: `Generated new cleanupData param for job parameters` }); + try { this.logger.info({ jobId: job.id, msg: `Finalize Job` }); const packageName = job.parameters.fileName; @@ -181,7 +189,7 @@ export class TasksManager { await this.packageManager.createJsonMetadata(packageFullPath, job); } const callbackParams = await this.sendCallbacks(job, expirationDate, reason); - updateJobParams = { ...updateJobParams, parameters: { ...job.parameters, callbackParams } }; + updateJobParams = { ...updateJobParams, parameters: { ...job.parameters, callbackParams, cleanupData } }; this.logger.info({ jobId: job.id, status: isSuccess, msg: `Update Job status` }); await this.jobManagerClient.updateJob(job.id, updateJobParams); @@ -193,7 +201,7 @@ export class TasksManager { msg: `Could not finalize job, will updating to status failed`, }); const callbackParams = await this.sendCallbacks(job, expirationDate, reason); - updateJobParams = { ...updateJobParams, status: OperationStatus.FAILED, parameters: { ...job.parameters, callbackParams } }; + updateJobParams = { ...updateJobParams, status: OperationStatus.FAILED, parameters: { ...job.parameters, callbackParams, cleanupData } }; await this.jobManagerClient.updateJob(job.id, updateJobParams); } } @@ -204,8 +212,15 @@ export class TasksManager { /* eslint-disable-next-line @typescript-eslint/no-magic-numbers */ percentage: isSuccess ? 100 : undefined, status: isSuccess ? OperationStatus.COMPLETED : OperationStatus.FAILED, - expirationDate: expirationDate, }; + + const cleanupData: ICleanupData = { + directoryPath: job.parameters.relativeDirectoryPath, + cleanupExpirationTime: expirationDate, + }; + + this.logger.info({ jobId: job.id, cleanupData, msg: `Generated new cleanupData param for job parameters` }); + try { this.logger.info({ jobId: job.id, isSuccess, msg: `Finalize Job` }); if (isSuccess) { @@ -230,11 +245,16 @@ export class TasksManager { errorReason: reason, }; - updateJobParams = { ...updateJobParams, parameters: { ...job.parameters, callbackParams } }; + updateJobParams = { ...updateJobParams, parameters: { ...job.parameters, callbackParams, cleanupData } }; this.logger.info({ finalizeStatus, jobId: job.id, msg: `Updating job finalizing status` }); } catch (error) { this.logger.error({ jobId: job.id, err: error, reason: `${(error as Error).message}`, msg: `Could not finalize job` }); - updateJobParams = { ...updateJobParams, reason: JSON.stringify(error as Error), status: OperationStatus.FAILED }; + updateJobParams = { + ...updateJobParams, + reason: JSON.stringify(error as Error), + status: OperationStatus.FAILED, + parameters: { ...job.parameters, cleanupData }, + }; } finally { await this.jobManagerClient.updateJob(job.id, updateJobParams); } From f47bd525b57552abeb0f7d085c1a31491ff213b9 Mon Sep 17 00:00:00 2001 From: ronenk1 Date: Thu, 9 Mar 2023 11:36:13 +0200 Subject: [PATCH 2/4] feat: test updating --- src/clients/jobManagerWrapper.ts | 2 +- tests/mocks/data.ts | 8 +++++ tests/mocks/data/mockJob.ts | 2 +- tests/unit/clients/jobManagerClient.spec.ts | 33 +++++++++++++------ .../createPackage/models/tasksModel.spec.ts | 11 ++++--- 5 files changed, 40 insertions(+), 16 deletions(-) diff --git a/src/clients/jobManagerWrapper.ts b/src/clients/jobManagerWrapper.ts index 1ea2283..6df4cf1 100644 --- a/src/clients/jobManagerWrapper.ts +++ b/src/clients/jobManagerWrapper.ts @@ -270,7 +270,7 @@ export class JobManagerWrapper extends JobManagerClient { const job = await this.get(getOrUpdateURL); if (job) { - const oldExpirationDate = new Date(job.expirationDate as Date); + const oldExpirationDate = new Date(job.parameters.cleanupData?.cleanupExpirationTime as Date); if (oldExpirationDate < newExpirationDate) { this.logger.info({ jobId, oldExpirationDate, newExpirationDate, msg: 'update expirationDate' }); await this.put(getOrUpdateURL, { diff --git a/tests/mocks/data.ts b/tests/mocks/data.ts index f9825be..6377a44 100644 --- a/tests/mocks/data.ts +++ b/tests/mocks/data.ts @@ -277,6 +277,10 @@ const completedJob: IJobResponse = { expirationTime: new Date(), targetResolution: 0.0439453125, }, + cleanupData: { + directoryPath: 'test', + cleanupExpirationTime: new Date(), + }, targetResolution: 0.0439453125, }, @@ -693,6 +697,10 @@ const completedExportJob: IJobResponse = expirationTime: new Date(), recordCatalogId: 'b0b19b88-aecb-4e74-b694-dfa7eada8bf7', }, + cleanupData: { + directoryPath: 'b0b19b88-aecb-4e74-b694-dfa7eada8bf7', + cleanupExpirationTime: new Date(), + }, gpkgEstimatedSize: 187500, fileNamesTemplates: { dataURI: 'Orthophoto_testArea_1_0_2023_02_28T15_09_50_924Z.gpkg', diff --git a/tests/mocks/data/mockJob.ts b/tests/mocks/data/mockJob.ts index 66200ce..bfcb0d3 100644 --- a/tests/mocks/data/mockJob.ts +++ b/tests/mocks/data/mockJob.ts @@ -88,7 +88,7 @@ export const mockCompletedJob: JobExportResponse = { reason: '', isCleaned: false, priority: 0, - expirationDate: new Date(), + expirationDate: undefined, internalId: '880a9316-0f10-4874-92e2-a62d587a1169', producerName: undefined, productName: 'test', diff --git a/tests/unit/clients/jobManagerClient.spec.ts b/tests/unit/clients/jobManagerClient.spec.ts index 003bbe7..728b30c 100644 --- a/tests/unit/clients/jobManagerClient.spec.ts +++ b/tests/unit/clients/jobManagerClient.spec.ts @@ -6,6 +6,7 @@ import { JobResponse, ICreateJobResponse as JobInProgressResponse, JobExportDupl import { configMock, registerDefaultConfig } from '../../mocks/config'; import { completedExportJob, + completedJob, fc1, inProgressExportJob, inProgressJob, @@ -131,14 +132,20 @@ describe('JobManagerClient', () => { putFun = jest.fn(); (jobManagerClient as unknown as { put: unknown }).put = putFun.mockResolvedValue(undefined); const jobManager = jobManagerClient as unknown as { get: unknown }; - jobManager.get = get.mockResolvedValue({ ...inProgressJob, expirationDate: testExpirationDate }); + jobManager.get = get.mockResolvedValue({ + ...completedJob, + parameters: { + ...completedJob.parameters, + cleanupData: { ...completedJob.parameters.cleanupData, cleanupExpirationTime: testExpirationDate }, + }, + }); - await jobManagerClient.validateAndUpdateExpiration(inProgressJob.id); + await jobManagerClient.validateAndUpdateExpiration(completedJob.id); expect(get).toHaveBeenCalledTimes(1); expect(putFun).toHaveBeenCalledTimes(1); // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment, @typescript-eslint/no-unsafe-member-access - const expirationParamCall: Date = putFun.mock.calls[0][1].expirationDate; + const expirationParamCall: Date = putFun.mock.calls[0][1].parameters.cleanupData.cleanupExpirationTime; expirationParamCall.setSeconds(0, 0); expect(JSON.stringify(expirationParamCall)).toBe(JSON.stringify(expectedNewExpirationDate)); }); @@ -272,7 +279,7 @@ describe('JobManagerClient', () => { }); }); describe('Update Jobs', () => { - it('should successfully update running Export job (already in progress) expirationDate (old expirationDate lower)', async () => { + it('should successfully update completed Export job (Naive cache) expirationDate (old expirationDate lower)', async () => { const expirationDays: number = configMock.get('jobManager.expirationDays'); const testExpirationDate = getUTCDate(); const expectedNewExpirationDate = getUTCDate(); @@ -284,19 +291,19 @@ describe('JobManagerClient', () => { putFun = jest.fn(); (jobManagerClient as unknown as { put: unknown }).put = putFun.mockResolvedValue(undefined); const jobManager = jobManagerClient as unknown as { get: unknown }; - jobManager.get = get.mockResolvedValue({ ...inProgressExportJob, expirationDate: testExpirationDate }); + jobManager.get = get.mockResolvedValue({ ...completedExportJob }); - await jobManagerClient.validateAndUpdateExpiration(inProgressExportJob.id); + await jobManagerClient.validateAndUpdateExpiration(completedExportJob.id); expect(get).toHaveBeenCalledTimes(1); expect(putFun).toHaveBeenCalledTimes(1); // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment, @typescript-eslint/no-unsafe-member-access - const expirationParamCall: Date = putFun.mock.calls[0][1].expirationDate; + const expirationParamCall: Date = putFun.mock.calls[0][1].parameters.cleanupData.cleanupExpirationTime; expirationParamCall.setSeconds(0, 0); expect(JSON.stringify(expirationParamCall)).toBe(JSON.stringify(expectedNewExpirationDate)); }); - it('should not update running Export job (already in progress) expirationDate (old expirationDate higher)', async () => { + it('should not update completed Export job (naive cache) expirationDate (old expirationDate higher)', async () => { const expirationDays: number = configMock.get('jobManager.expirationDays'); const testExpirationDate = getUTCDate(); const expectedNewExpirationDate = getUTCDate(); @@ -308,9 +315,15 @@ describe('JobManagerClient', () => { putFun = jest.fn(); (jobManagerClient as unknown as { put: unknown }).put = putFun.mockResolvedValue(undefined); const jobManager = jobManagerClient as unknown as { get: unknown }; - jobManager.get = get.mockResolvedValue({ ...inProgressExportJob, expirationDate: testExpirationDate }); + jobManager.get = get.mockResolvedValue({ + ...completedExportJob, + parameters: { + ...completedExportJob.parameters, + cleanupData: { ...completedExportJob.parameters.cleanupData, cleanupExpirationTime: testExpirationDate }, + }, + }); - await jobManagerClient.validateAndUpdateExpiration(inProgressExportJob.id); + await jobManagerClient.validateAndUpdateExpiration(completedExportJob.id); expect(get).toHaveBeenCalledTimes(1); expect(putFun).toHaveBeenCalledTimes(0); diff --git a/tests/unit/createPackage/models/tasksModel.spec.ts b/tests/unit/createPackage/models/tasksModel.spec.ts index 8582e45..e5b3e79 100644 --- a/tests/unit/createPackage/models/tasksModel.spec.ts +++ b/tests/unit/createPackage/models/tasksModel.spec.ts @@ -451,10 +451,10 @@ describe('TasksManager', () => { reason: undefined, percentage: 100, status: OperationStatus.COMPLETED, - expirationDate: expirationTime, parameters: { ...mockCompletedJob.parameters, callbackParams: { ...expectedCallbackParamData, roi: mockCompletedJob.parameters.roi, status: OperationStatus.COMPLETED }, + cleanupData: { directoryPath: mockCompletedJob.parameters.relativeDirectoryPath, cleanupExpirationTime: expirationTime }, }, }; const action = async () => tasksManager.finalizeExportJob(mockCompletedJob, expirationTime); @@ -495,10 +495,10 @@ describe('TasksManager', () => { reason: undefined, percentage: 100, status: OperationStatus.COMPLETED, - expirationDate: expirationTime, parameters: { ...mockCompletedJob.parameters, callbackParams: { ...expectedCallbackParamData, roi: mockCompletedJob.parameters.roi, status: OperationStatus.COMPLETED }, + cleanupData: { directoryPath: mockCompletedJob.parameters.relativeDirectoryPath, cleanupExpirationTime: expirationTime }, }, }; const action = async () => tasksManager.finalizeExportJob(mockCompletedJob, expirationTime); @@ -526,7 +526,10 @@ describe('TasksManager', () => { reason: JSON.stringify({ message: 'failed generate metadata.json' }), percentage: 100, status: OperationStatus.FAILED, - expirationDate: expirationTime, + parameters: { + ...mockCompletedJob.parameters, + cleanupData: { directoryPath: mockCompletedJob.parameters.relativeDirectoryPath, cleanupExpirationTime: expirationTime }, + }, }; const action = async () => tasksManager.finalizeExportJob(mockCompletedJob, expirationTime); await expect(action()).resolves.not.toThrow(); @@ -560,10 +563,10 @@ describe('TasksManager', () => { reason: 'testError', percentage: undefined, status: OperationStatus.FAILED, - expirationDate: expirationTime, parameters: { ...mockCompletedJob.parameters, callbackParams: { ...expectedCallbackParamData, roi: mockCompletedJob.parameters.roi, status: OperationStatus.FAILED }, + cleanupData: { directoryPath: mockCompletedJob.parameters.relativeDirectoryPath, cleanupExpirationTime: expirationTime }, }, }; const action = async () => tasksManager.finalizeExportJob(mockCompletedJob, expirationTime, false, 'testError'); From 7691943e97d8fa22ddc8c2d3e1e1a94e45f9d863 Mon Sep 17 00:00:00 2001 From: ronenk1 Date: Thu, 9 Mar 2023 13:44:24 +0200 Subject: [PATCH 3/4] feat: fix tests --- src/tasks/models/tasksManager.ts | 16 +++++++--------- 1 file changed, 7 insertions(+), 9 deletions(-) diff --git a/src/tasks/models/tasksManager.ts b/src/tasks/models/tasksManager.ts index 29f4e04..01d8963 100644 --- a/src/tasks/models/tasksManager.ts +++ b/src/tasks/models/tasksManager.ts @@ -174,11 +174,7 @@ export class TasksManager { percentage: isSuccess ? 100 : undefined, }; - const cleanupData: ICleanupData = { - directoryPath: job.parameters.relativeDirectoryPath, - cleanupExpirationTime: expirationDate, - }; - + const cleanupData: ICleanupData = this.generateCleanupEntity(job.parameters, expirationDate); this.logger.info({ jobId: job.id, cleanupData, msg: `Generated new cleanupData param for job parameters` }); try { @@ -214,10 +210,7 @@ export class TasksManager { status: isSuccess ? OperationStatus.COMPLETED : OperationStatus.FAILED, }; - const cleanupData: ICleanupData = { - directoryPath: job.parameters.relativeDirectoryPath, - cleanupExpirationTime: expirationDate, - }; + const cleanupData: ICleanupData = this.generateCleanupEntity(job.parameters, expirationDate); this.logger.info({ jobId: job.id, cleanupData, msg: `Generated new cleanupData param for job parameters` }); @@ -260,6 +253,11 @@ export class TasksManager { } } + private generateCleanupEntity(jobParam: IJobExportParameters | IJobParameters, expirationDate: Date): ICleanupData { + const cleanupData = { directoryPath: jobParam.relativeDirectoryPath, cleanupExpirationTime: expirationDate }; + return cleanupData; + } + private async generateCallbackParam(job: JobExportResponse, expirationDate: Date, errorReason?: string): Promise { let links: ILinkDefinition = { ...job.parameters.fileNamesTemplates }; // default file names in case of failure this.logger.info({ jobId: job.id, msg: `generate callback body for job: ${job.id}` }); From 998629cc8626deed978a975edfdb9a2e3acd321f Mon Sep 17 00:00:00 2001 From: ronenk1 Date: Sun, 12 Mar 2023 09:46:47 +0200 Subject: [PATCH 4/4] fix: naming for cleanupExpirationUTC --- src/clients/jobManagerWrapper.ts | 4 ++-- src/common/interfaces.ts | 2 +- src/tasks/models/tasksManager.ts | 12 +++++------- tests/mocks/data.ts | 4 ++-- tests/unit/clients/jobManagerClient.spec.ts | 8 ++++---- tests/unit/createPackage/models/tasksModel.spec.ts | 8 ++++---- 6 files changed, 18 insertions(+), 20 deletions(-) diff --git a/src/clients/jobManagerWrapper.ts b/src/clients/jobManagerWrapper.ts index 6df4cf1..3c313be 100644 --- a/src/clients/jobManagerWrapper.ts +++ b/src/clients/jobManagerWrapper.ts @@ -270,7 +270,7 @@ export class JobManagerWrapper extends JobManagerClient { const job = await this.get(getOrUpdateURL); if (job) { - const oldExpirationDate = new Date(job.parameters.cleanupData?.cleanupExpirationTime as Date); + const oldExpirationDate = new Date(job.parameters.cleanupData?.cleanupExpirationTimeUTC as Date); if (oldExpirationDate < newExpirationDate) { this.logger.info({ jobId, oldExpirationDate, newExpirationDate, msg: 'update expirationDate' }); await this.put(getOrUpdateURL, { @@ -278,7 +278,7 @@ export class JobManagerWrapper extends JobManagerClient { ...job.parameters, cleanupData: { ...job.parameters.cleanupData, - cleanupExpirationTime: newExpirationDate, + cleanupExpirationTimeUTC: newExpirationDate, directoryPath: job.parameters.relativeDirectoryPath, }, }, diff --git a/src/common/interfaces.ts b/src/common/interfaces.ts index 6848392..ab3071b 100644 --- a/src/common/interfaces.ts +++ b/src/common/interfaces.ts @@ -23,7 +23,7 @@ export interface IBaseCreatePackage { export interface ICleanupData { directoryPath?: string; - cleanupExpirationTime?: Date; + cleanupExpirationTimeUTC?: Date; } /** diff --git a/src/tasks/models/tasksManager.ts b/src/tasks/models/tasksManager.ts index 01d8963..1c98765 100644 --- a/src/tasks/models/tasksManager.ts +++ b/src/tasks/models/tasksManager.ts @@ -174,8 +174,7 @@ export class TasksManager { percentage: isSuccess ? 100 : undefined, }; - const cleanupData: ICleanupData = this.generateCleanupEntity(job.parameters, expirationDate); - this.logger.info({ jobId: job.id, cleanupData, msg: `Generated new cleanupData param for job parameters` }); + const cleanupData: ICleanupData = this.generateCleanupEntity(job, expirationDate); try { this.logger.info({ jobId: job.id, msg: `Finalize Job` }); @@ -210,9 +209,7 @@ export class TasksManager { status: isSuccess ? OperationStatus.COMPLETED : OperationStatus.FAILED, }; - const cleanupData: ICleanupData = this.generateCleanupEntity(job.parameters, expirationDate); - - this.logger.info({ jobId: job.id, cleanupData, msg: `Generated new cleanupData param for job parameters` }); + const cleanupData: ICleanupData = this.generateCleanupEntity(job, expirationDate); try { this.logger.info({ jobId: job.id, isSuccess, msg: `Finalize Job` }); @@ -253,8 +250,9 @@ export class TasksManager { } } - private generateCleanupEntity(jobParam: IJobExportParameters | IJobParameters, expirationDate: Date): ICleanupData { - const cleanupData = { directoryPath: jobParam.relativeDirectoryPath, cleanupExpirationTime: expirationDate }; + private generateCleanupEntity(job: JobResponse | JobExportResponse, expirationDate: Date): ICleanupData { + const cleanupData = { directoryPath: job.parameters.relativeDirectoryPath, cleanupExpirationTimeUTC: expirationDate }; + this.logger.info({ jobId: job.id, cleanupData, msg: `Generated new cleanupData param for job parameters` }); return cleanupData; } diff --git a/tests/mocks/data.ts b/tests/mocks/data.ts index 6377a44..0a6ae53 100644 --- a/tests/mocks/data.ts +++ b/tests/mocks/data.ts @@ -279,7 +279,7 @@ const completedJob: IJobResponse = { }, cleanupData: { directoryPath: 'test', - cleanupExpirationTime: new Date(), + cleanupExpirationTimeUTC: new Date(), }, targetResolution: 0.0439453125, @@ -699,7 +699,7 @@ const completedExportJob: IJobResponse = }, cleanupData: { directoryPath: 'b0b19b88-aecb-4e74-b694-dfa7eada8bf7', - cleanupExpirationTime: new Date(), + cleanupExpirationTimeUTC: new Date(), }, gpkgEstimatedSize: 187500, fileNamesTemplates: { diff --git a/tests/unit/clients/jobManagerClient.spec.ts b/tests/unit/clients/jobManagerClient.spec.ts index 728b30c..852fc3a 100644 --- a/tests/unit/clients/jobManagerClient.spec.ts +++ b/tests/unit/clients/jobManagerClient.spec.ts @@ -136,7 +136,7 @@ describe('JobManagerClient', () => { ...completedJob, parameters: { ...completedJob.parameters, - cleanupData: { ...completedJob.parameters.cleanupData, cleanupExpirationTime: testExpirationDate }, + cleanupData: { ...completedJob.parameters.cleanupData, cleanupExpirationTimeUTC: testExpirationDate }, }, }); @@ -145,7 +145,7 @@ describe('JobManagerClient', () => { expect(get).toHaveBeenCalledTimes(1); expect(putFun).toHaveBeenCalledTimes(1); // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment, @typescript-eslint/no-unsafe-member-access - const expirationParamCall: Date = putFun.mock.calls[0][1].parameters.cleanupData.cleanupExpirationTime; + const expirationParamCall: Date = putFun.mock.calls[0][1].parameters.cleanupData.cleanupExpirationTimeUTC; expirationParamCall.setSeconds(0, 0); expect(JSON.stringify(expirationParamCall)).toBe(JSON.stringify(expectedNewExpirationDate)); }); @@ -298,7 +298,7 @@ describe('JobManagerClient', () => { expect(get).toHaveBeenCalledTimes(1); expect(putFun).toHaveBeenCalledTimes(1); // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment, @typescript-eslint/no-unsafe-member-access - const expirationParamCall: Date = putFun.mock.calls[0][1].parameters.cleanupData.cleanupExpirationTime; + const expirationParamCall: Date = putFun.mock.calls[0][1].parameters.cleanupData.cleanupExpirationTimeUTC; expirationParamCall.setSeconds(0, 0); expect(JSON.stringify(expirationParamCall)).toBe(JSON.stringify(expectedNewExpirationDate)); }); @@ -319,7 +319,7 @@ describe('JobManagerClient', () => { ...completedExportJob, parameters: { ...completedExportJob.parameters, - cleanupData: { ...completedExportJob.parameters.cleanupData, cleanupExpirationTime: testExpirationDate }, + cleanupData: { ...completedExportJob.parameters.cleanupData, cleanupExpirationTimeUTC: testExpirationDate }, }, }); diff --git a/tests/unit/createPackage/models/tasksModel.spec.ts b/tests/unit/createPackage/models/tasksModel.spec.ts index e5b3e79..8c45439 100644 --- a/tests/unit/createPackage/models/tasksModel.spec.ts +++ b/tests/unit/createPackage/models/tasksModel.spec.ts @@ -454,7 +454,7 @@ describe('TasksManager', () => { parameters: { ...mockCompletedJob.parameters, callbackParams: { ...expectedCallbackParamData, roi: mockCompletedJob.parameters.roi, status: OperationStatus.COMPLETED }, - cleanupData: { directoryPath: mockCompletedJob.parameters.relativeDirectoryPath, cleanupExpirationTime: expirationTime }, + cleanupData: { directoryPath: mockCompletedJob.parameters.relativeDirectoryPath, cleanupExpirationTimeUTC: expirationTime }, }, }; const action = async () => tasksManager.finalizeExportJob(mockCompletedJob, expirationTime); @@ -498,7 +498,7 @@ describe('TasksManager', () => { parameters: { ...mockCompletedJob.parameters, callbackParams: { ...expectedCallbackParamData, roi: mockCompletedJob.parameters.roi, status: OperationStatus.COMPLETED }, - cleanupData: { directoryPath: mockCompletedJob.parameters.relativeDirectoryPath, cleanupExpirationTime: expirationTime }, + cleanupData: { directoryPath: mockCompletedJob.parameters.relativeDirectoryPath, cleanupExpirationTimeUTC: expirationTime }, }, }; const action = async () => tasksManager.finalizeExportJob(mockCompletedJob, expirationTime); @@ -528,7 +528,7 @@ describe('TasksManager', () => { status: OperationStatus.FAILED, parameters: { ...mockCompletedJob.parameters, - cleanupData: { directoryPath: mockCompletedJob.parameters.relativeDirectoryPath, cleanupExpirationTime: expirationTime }, + cleanupData: { directoryPath: mockCompletedJob.parameters.relativeDirectoryPath, cleanupExpirationTimeUTC: expirationTime }, }, }; const action = async () => tasksManager.finalizeExportJob(mockCompletedJob, expirationTime); @@ -566,7 +566,7 @@ describe('TasksManager', () => { parameters: { ...mockCompletedJob.parameters, callbackParams: { ...expectedCallbackParamData, roi: mockCompletedJob.parameters.roi, status: OperationStatus.FAILED }, - cleanupData: { directoryPath: mockCompletedJob.parameters.relativeDirectoryPath, cleanupExpirationTime: expirationTime }, + cleanupData: { directoryPath: mockCompletedJob.parameters.relativeDirectoryPath, cleanupExpirationTimeUTC: expirationTime }, }, }; const action = async () => tasksManager.finalizeExportJob(mockCompletedJob, expirationTime, false, 'testError');