From 97c36e58f3762e67eeb372d49c270aefa95d8024 Mon Sep 17 00:00:00 2001 From: Joseph Kotanchik Date: Tue, 17 Dec 2024 13:59:56 -0500 Subject: [PATCH] MAT-7961: Trim the eCQM Abbr Title when used in an export filename. --- .../cms/madie/services/PackagingService.java | 20 +++++----- .../madie/services/PackagingServiceTest.java | 39 +++++++++++++++++-- 2 files changed, 47 insertions(+), 12 deletions(-) diff --git a/src/main/java/gov/cms/madie/services/PackagingService.java b/src/main/java/gov/cms/madie/services/PackagingService.java index b8b4959..2042967 100644 --- a/src/main/java/gov/cms/madie/services/PackagingService.java +++ b/src/main/java/gov/cms/madie/services/PackagingService.java @@ -41,23 +41,25 @@ public byte[] createMeasurePackage(Measure measure, String accessToken) { Map entries = new HashMap<>(); for (TranslatedLibrary translatedLibrary : translatedLibraries) { String entryName = translatedLibrary.getName() + "-" + translatedLibrary.getVersion(); - entries.put(resourcesDir + entryName + ".json", translatedLibrary.getElmJson().getBytes()); - entries.put(resourcesDir + entryName + ".xml", translatedLibrary.getElmXml().getBytes()); - entries.put(cqlDir + entryName + ".cql", translatedLibrary.getCql().getBytes()); + entries.put( + resourcesDir + entryName.trim() + ".json", translatedLibrary.getElmJson().getBytes()); + entries.put( + resourcesDir + entryName.trim() + ".xml", translatedLibrary.getElmXml().getBytes()); + entries.put(cqlDir + entryName.trim() + ".cql", translatedLibrary.getCql().getBytes()); } CqlLookups cqlLookups = translationServiceClient.getCqlLookups(qdmMeasure, accessToken); final String humanReadable = humanReadableService.generate(measure, cqlLookups); if (humanReadable != null) { entries.put( - measure.getEcqmTitle() + "-v" + measure.getVersion() + "-QDM" + ".html", + measure.getEcqmTitle().trim() + "-v" + measure.getVersion() + "-QDM" + ".html", humanReadable.getBytes()); } - String hqmf = hqmfService.generateHqmf(qdmMeasure, cqlLookups); - entries.put( - measure.getEcqmTitle() + "-v" + measure.getVersion() + "-QDM" + ".xml", hqmf.getBytes()); - ByteArrayOutputStream outputStream = new ByteArrayOutputStream(); - return new ZipUtility().zipEntries(entries, outputStream); + String hqmf = hqmfService.generateHqmf(qdmMeasure, cqlLookups); + entries.put( + measure.getEcqmTitle().trim() + "-v" + measure.getVersion() + "-QDM" + ".xml", + hqmf.getBytes()); + return new ZipUtility().zipEntries(entries, new ByteArrayOutputStream()); } public byte[] createQRDA(QrdaRequestDTO qrdaRequestDTO, String accessToken) { diff --git a/src/test/java/gov/cms/madie/services/PackagingServiceTest.java b/src/test/java/gov/cms/madie/services/PackagingServiceTest.java index 52be902..6fb0efc 100644 --- a/src/test/java/gov/cms/madie/services/PackagingServiceTest.java +++ b/src/test/java/gov/cms/madie/services/PackagingServiceTest.java @@ -142,13 +142,13 @@ void testCreateMeasurePackageWhenHqmfGenerationFailed() { when(humanReadableService.generate(any(Measure.class), any(CqlLookups.class))) .thenReturn("success"); - Mockito.doThrow(new PackagingException("An error occurred that caused the HQMF generation to fail")) + Mockito.doThrow( + new PackagingException("An error occurred that caused the HQMF generation to fail")) .when(hqmfService) .generateHqmf(any(QdmMeasure.class), any(CqlLookups.class)); Exception exception = assertThrows( - PackagingException.class, - () -> packagingService.createMeasurePackage(measure, TOKEN)); + PackagingException.class, () -> packagingService.createMeasurePackage(measure, TOKEN)); assertThat( exception.getMessage(), containsString("An error occurred that caused the HQMF generation to fail")); @@ -176,4 +176,37 @@ void testCreateQRDA() { assertThat(new String(qrda), containsString("html/")); assertThat(new String(qrda), containsString("1_test.html")); } + + @Test + void trimFileNameValues() { + QdmMeasure msr = measure.toBuilder().ecqmTitle(" test ").build(); + TranslatedLibrary library1 = + TranslatedLibrary.builder() + .name("Lib one") + .version("0.0.000") + .elmJson("elm xml") + .elmXml("elm xml") + .cql("cql") + .build(); + TranslatedLibrary library2 = + TranslatedLibrary.builder() + .name("Lib two") + .version("0.0.001") + .elmJson("elm xml") + .elmXml("elm xml") + .cql("cql") + .build(); + CqlLookups cqlLookups = CqlLookups.builder().build(); + when(translationServiceClient.getTranslatedLibraries(msr.getCql(), TOKEN)) + .thenReturn(List.of(library1, library2)); + when(translationServiceClient.getCqlLookups(any(QdmMeasure.class), anyString())) + .thenReturn(CqlLookups.builder().build()); + when(hqmfService.generateHqmf(msr, cqlLookups)).thenReturn("this is a test hqmf"); + when(humanReadableService.generate(any(Measure.class), any(CqlLookups.class))) + .thenReturn("success"); + byte[] packageContents = packagingService.createMeasurePackage(msr, TOKEN); + String packageString = new String(packageContents); + assertThat(packageString, containsString("test-v1.2.003-QDM.html")); + assertThat(packageString, containsString("test-v1.2.003-QDM.xml")); + } }