From 73088af05400735a1755765fc2a6eb34626b1283 Mon Sep 17 00:00:00 2001 From: Sangeetha Krishnan Date: Wed, 11 Oct 2023 10:52:43 +0530 Subject: [PATCH] Throw error if provider metadata does not have provider id mapping (#85) --- src/hooks/utils/hook-utils.js | 4 ++++ test/hooks/post-deploy-event-reg.test.js | 13 +++++++++++++ 2 files changed, 17 insertions(+) diff --git a/src/hooks/utils/hook-utils.js b/src/hooks/utils/hook-utils.js index 68920f5..c88c5a6 100644 --- a/src/hooks/utils/hook-utils.js +++ b/src/hooks/utils/hook-utils.js @@ -47,6 +47,10 @@ function getEventsOfInterestForRegistration (registration, const eventsOfInterestCompressed = registration.events_of_interest eventsOfInterestCompressed.forEach(eventOfInterest => { const providerId = providerMetadataToProviderIdMapping[eventOfInterest.provider_metadata] + if (!providerId) { + throw new Error( + `No provider id mapping found for provider metadata ${eventOfInterest.provider_metadata}. Skipping event registration`) + } const eventCodesList = eventOfInterest.event_codes for (const eventCode of eventCodesList) { eventsOfInterest.push({ diff --git a/test/hooks/post-deploy-event-reg.test.js b/test/hooks/post-deploy-event-reg.test.js index c5b8bf3..3ee9003 100644 --- a/test/hooks/post-deploy-event-reg.test.js +++ b/test/hooks/post-deploy-event-reg.test.js @@ -92,6 +92,19 @@ describe('post deploy event registration hook interfaces', () => { await expect(hook({ appConfig: { project: mock.data.sampleProject, events: mock.data.sampleEvents } })).rejects.toThrow(new Error('No environment variables for provider metadata to provider id mappings found.')) }) + test('providerMetadata to providerId missing for some providers', async () => { + const hook = require('../../src/hooks/post-deploy-event-reg') + expect(typeof hook).toBe('function') + process.env = mock.data.dotEnvMissingProviderMetadataToProviderIdMapping + process.env.AIO_events_providermetadata_to_provider_mapping = '' + process.env = { + ...mock.data.dotEnvMissingProviderMetadataToProviderIdMapping, + AIO_EVENTS_PROVIDERMETADATA_TO_PROVIDER_MAPPING: 'providerMetadata2:providerId2' + } + getToken.mockReturnValue('accessToken') + await expect(hook({ appConfig: { project: mock.data.sampleProject, events: mock.data.sampleEvents } })).rejects.toThrow(new Error('No provider id mapping found for provider metadata providerMetadata1. Skipping event registration')) + }) + test('error in create registration', async () => { const hook = require('../../src/hooks/post-deploy-event-reg') expect(typeof hook).toBe('function')