From 9a1b5560f7c3b80078d443c05cbc7c6d05182dce Mon Sep 17 00:00:00 2001 From: SujitMBRDI Date: Tue, 29 Oct 2024 08:44:16 +0530 Subject: [PATCH] fix(bpdm-gate): output stage to only provide generic states for uncategorized states fix(bpdm-gate): output stage to only provide generic states for uncategorized states fix(bpdm-gate): output stage to only provide states based on business partner type --- CHANGELOG.md | 1 + .../bpdm/gate/service/BusinessPartnerMappings.kt | 10 +++++++++- .../BusinessPartnerControllerAndSharingControllerIT.kt | 2 +- .../gate/controller/BusinessPartnerControllerIT.kt | 4 ++-- 4 files changed, 13 insertions(+), 4 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index fb9ae3115..1f0f52e78 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -37,6 +37,7 @@ For changes to the BPDM Helm charts please consult the [changelog](charts/bpdm/C - BPDM Gate: Fixed logic for identifiers to retrieve only generic type on output business partner - BPDM Gate: Fixed construction logic for states and identifiers by enabling business partner type - BPDM Pool: When processing golden record tasks the Pool now ignores isCatenaXMemberData field if it is set to null. ([#1069](https://github.com/eclipse-tractusx/bpdm/issues/1069)) +- BPDM Gate: Fixed gate output logic to provide states based on business partner type. ## [6.1.0] - [2024-07-15] diff --git a/bpdm-gate/src/main/kotlin/org/eclipse/tractusx/bpdm/gate/service/BusinessPartnerMappings.kt b/bpdm-gate/src/main/kotlin/org/eclipse/tractusx/bpdm/gate/service/BusinessPartnerMappings.kt index 4964aa45f..c25d649a7 100644 --- a/bpdm-gate/src/main/kotlin/org/eclipse/tractusx/bpdm/gate/service/BusinessPartnerMappings.kt +++ b/bpdm-gate/src/main/kotlin/org/eclipse/tractusx/bpdm/gate/service/BusinessPartnerMappings.kt @@ -65,7 +65,15 @@ class BusinessPartnerMappings { } } .map(::toIdentifierDto) }?: emptyList(), - states = entity.states.map(::toStateDto), + states = entity.postalAddress.addressType?.let { addressType -> + entity.states + .filter { it.businessPartnerTyp == when (addressType) { + AddressType.LegalAndSiteMainAddress, AddressType.LegalAddress -> BusinessPartnerType.LEGAL_ENTITY + AddressType.AdditionalAddress -> BusinessPartnerType.ADDRESS + AddressType.SiteMainAddress -> BusinessPartnerType.SITE + } } + .map(::toStateDto) + }?: emptyList(), roles = entity.roles, isOwnCompanyData = entity.isOwnCompanyData, legalEntity = toLegalEntityComponentOutputDto(entity), diff --git a/bpdm-gate/src/test/kotlin/org/eclipse/tractusx/bpdm/gate/controller/BusinessPartnerControllerAndSharingControllerIT.kt b/bpdm-gate/src/test/kotlin/org/eclipse/tractusx/bpdm/gate/controller/BusinessPartnerControllerAndSharingControllerIT.kt index a752f63c1..9b5d33551 100644 --- a/bpdm-gate/src/test/kotlin/org/eclipse/tractusx/bpdm/gate/controller/BusinessPartnerControllerAndSharingControllerIT.kt +++ b/bpdm-gate/src/test/kotlin/org/eclipse/tractusx/bpdm/gate/controller/BusinessPartnerControllerAndSharingControllerIT.kt @@ -145,7 +145,7 @@ class BusinessPartnerControllerAndSharingControllerIT @Autowired constructor( // Expect outputBusinessPartner without identifiers as there are not Address identifier provided. val outputBusinessPartners = listOf( - BusinessPartnerVerboseValues.bpOutputDtoCleaned.copy(identifiers = emptyList()) + BusinessPartnerVerboseValues.bpOutputDtoCleaned.copy(identifiers = emptyList(), states = emptyList()), ) val upsertRequests = listOf( diff --git a/bpdm-gate/src/test/kotlin/org/eclipse/tractusx/bpdm/gate/controller/BusinessPartnerControllerIT.kt b/bpdm-gate/src/test/kotlin/org/eclipse/tractusx/bpdm/gate/controller/BusinessPartnerControllerIT.kt index c0e40a6a7..d4caf81a8 100644 --- a/bpdm-gate/src/test/kotlin/org/eclipse/tractusx/bpdm/gate/controller/BusinessPartnerControllerIT.kt +++ b/bpdm-gate/src/test/kotlin/org/eclipse/tractusx/bpdm/gate/controller/BusinessPartnerControllerIT.kt @@ -280,9 +280,9 @@ class BusinessPartnerControllerIT @Autowired constructor( fun `insert one business partners and finalize cleaning task without error`() { this.mockAndAssertUtils.mockOrchestratorApiCleaned(gateWireMockServer) - // Expect outputBusinessPartner without identifiers as there are not Address identifier provided. + // Expect outputBusinessPartner without identifiers and states as there are no Address identifier and states provided. val outputBusinessPartners = listOf( - BusinessPartnerVerboseValues.bpOutputDtoCleaned.copy(identifiers = emptyList()) + BusinessPartnerVerboseValues.bpOutputDtoCleaned.copy(identifiers = emptyList(), states = emptyList()) ) val upsertRequests = listOf(