Skip to content

Commit

Permalink
Add Hepatitis C support for bulk upload
Browse files Browse the repository at this point in the history
  • Loading branch information
emyl3 committed Nov 5, 2024
1 parent 8e4aa72 commit 85619a1
Show file tree
Hide file tree
Showing 7 changed files with 109 additions and 12 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -502,6 +502,18 @@ private boolean isSyphilisResult() {
equipmentModelName.getValue(), testPerformedCode.getValue()));
}

private boolean isHepatitisCResult() {
if (equipmentModelName.getValue() == null || testPerformedCode.getValue() == null) {
return false;
}

return resultsUploaderCachingService
.getHepatitisCEquipmentModelAndTestPerformedCodeSet()
.contains(
ResultsUploaderCachingService.getKey(
equipmentModelName.getValue(), testPerformedCode.getValue()));
}

private List<FeedbackMessage> generateInvalidDataErrorMessages() {
String errorMessage =
"Invalid " + EQUIPMENT_MODEL_NAME + " and " + TEST_PERFORMED_CODE + " combination";
Expand Down Expand Up @@ -627,6 +639,14 @@ public List<FeedbackMessage> validateIndividualValues() {
List.of(gendersOfSexualPartners, pregnant, syphilisHistory, symptomaticForDisease)));
}

if (isHepatitisCResult()) {
errors.addAll(
validateRequiredFieldsForPositiveResult(
testResult,
DiseaseService.HEPATITIS_C_NAME,
List.of(gendersOfSexualPartners, pregnant, symptomaticForDisease)));
}

return errors;
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,8 @@ public class CachingConfig {

public static final String COVID_EQUIPMENT_MODEL_AND_TEST_PERFORMED_CODE_SET =
"covidEquipmentModelAndTestPerformedCodeSet";
public static final String HEPATITIS_C_EQUIPMENT_MODEL_AND_TEST_PERFORMED_CODE_SET =
"hepatitisCEquipmentModelAndTestPerformedCodeSet";
public static final String HIV_EQUIPMENT_MODEL_AND_TEST_PERFORMED_CODE_SET =
"hivEquipmentModelAndTestPerformedCodeSet";
public static final String SYPHILIS_EQUIPMENT_MODEL_AND_TEST_PERFORMED_CODE_SET =
Expand All @@ -27,6 +29,7 @@ public class CachingConfig {
public CacheManager cacheManager() {
return new ConcurrentMapCacheManager(
COVID_EQUIPMENT_MODEL_AND_TEST_PERFORMED_CODE_SET,
HEPATITIS_C_EQUIPMENT_MODEL_AND_TEST_PERFORMED_CODE_SET,
HIV_EQUIPMENT_MODEL_AND_TEST_PERFORMED_CODE_SET,
SYPHILIS_EQUIPMENT_MODEL_AND_TEST_PERFORMED_CODE_SET,
DEVICE_MODEL_AND_TEST_PERFORMED_CODE_MAP,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,7 @@ public class DiseaseService {
public static final String FLU_B_NAME = "Flu B";
public static final String FLU_A_AND_B_NAME = "Flu A and B";
public static final String FLU_RNA_NAME = "Flu RNA";
public static final String HEPATITIS_C_NAME = "Hepatitis C";
public static final String RSV_NAME = "RSV";
public static final String HIV_NAME = "HIV";
public static final String SYPHILIS_NAME = "Syphilis";
Expand Down Expand Up @@ -60,6 +61,10 @@ public SupportedDisease fluB() {
return getDiseaseByName(FLU_B_NAME);
}

public SupportedDisease hepatitisC() {
return getDiseaseByName(HEPATITIS_C_NAME);
}

public SupportedDisease rsv() {
return getDiseaseByName(RSV_NAME);
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@
import static gov.cdc.usds.simplereport.config.CachingConfig.ADDRESS_TIMEZONE_LOOKUP_MAP;
import static gov.cdc.usds.simplereport.config.CachingConfig.COVID_EQUIPMENT_MODEL_AND_TEST_PERFORMED_CODE_SET;
import static gov.cdc.usds.simplereport.config.CachingConfig.DEVICE_MODEL_AND_TEST_PERFORMED_CODE_MAP;
import static gov.cdc.usds.simplereport.config.CachingConfig.HEPATITIS_C_EQUIPMENT_MODEL_AND_TEST_PERFORMED_CODE_SET;
import static gov.cdc.usds.simplereport.config.CachingConfig.HIV_EQUIPMENT_MODEL_AND_TEST_PERFORMED_CODE_SET;
import static gov.cdc.usds.simplereport.config.CachingConfig.SNOMED_TO_SPECIMEN_NAME_MAP;
import static gov.cdc.usds.simplereport.config.CachingConfig.SPECIMEN_NAME_TO_SNOMED_MAP;
Expand Down Expand Up @@ -163,6 +164,12 @@ public Set<String> getCovidEquipmentModelAndTestPerformedCodeSet() {
return getDiseaseSpecificEquipmentModelAndTestPerformedCodeSet(DiseaseService.COVID19_NAME);
}

@Cacheable(HEPATITIS_C_EQUIPMENT_MODEL_AND_TEST_PERFORMED_CODE_SET)
public Set<String> getHepatitisCEquipmentModelAndTestPerformedCodeSet() {
log.info("generating hepatitisCEquipmentModelAndTestPerformedCodeSet cache");
return getDiseaseSpecificEquipmentModelAndTestPerformedCodeSet(DiseaseService.HEPATITIS_C_NAME);
}

@Scheduled(fixedRate = 1, timeUnit = TimeUnit.HOURS)
@Caching(
evict = {
Expand All @@ -183,6 +190,18 @@ public void cacheHivEquipmentModelAndTestPerformedCodeSet() {
getHivEquipmentModelAndTestPerformedCodeSet();
}

@Scheduled(fixedRate = 1, timeUnit = TimeUnit.HOURS)
@Caching(
evict = {
@CacheEvict(
value = HEPATITIS_C_EQUIPMENT_MODEL_AND_TEST_PERFORMED_CODE_SET,
allEntries = true)
})
public void cacheHepatitisCEquipmentModelAndTestPerformedCodeSet() {
log.info("clear and generate hepatitisCEquipmentModelAndTestPerformedCodeSet cache");
getHepatitisCEquipmentModelAndTestPerformedCodeSet();
}

@Cacheable(SNOMED_TO_SPECIMEN_NAME_MAP)
public Map<String, String> getSNOMEDToSpecimenTypeNameMap() {
log.info("generating SNOMEDToSpecimenTypeNameMap cache");
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -58,6 +58,13 @@ void getFluB_successful() {
assertEquals("Flu B", _service.fluB().getName());
}

@Test
void getHepatitisC_successful() {
SupportedDisease hepC = _service.hepatitisC();
assertNotNull(hepC);
assertEquals(DiseaseService.HEPATITIS_C_NAME, hepC.getName());
}

@Test
void getByName_successful() {
SupportedDisease covidByName = _service.getDiseaseByName(COVID19_NAME);
Expand All @@ -77,7 +84,9 @@ void getSupportedDiseasesMap_successful() {
.containsEntry(_service.covid().getInternalId(), _service.covid())
.containsEntry(_service.fluA().getInternalId(), _service.fluA())
.containsEntry(_service.fluB().getInternalId(), _service.fluB())
.containsEntry(_service.rsv().getInternalId(), _service.rsv());
.containsEntry(_service.rsv().getInternalId(), _service.rsv())
.containsEntry(_service.hiv().getInternalId(), _service.hiv())
.containsEntry(_service.hepatitisC().getInternalId(), _service.hepatitisC());
}

@Test
Expand All @@ -90,6 +99,8 @@ void getSupportedDiseasesList_successful() {
.contains(_service.covid())
.contains(_service.fluA())
.contains(_service.fluB())
.contains(_service.rsv());
.contains(_service.rsv())
.contains(_service.hiv())
.contains(_service.hepatitisC());
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -110,6 +110,8 @@ void validateOnlyIncludeActiveDiseases_returnsTrueWhenHIVIsOn() {
assertThat(validationResult).isTrue();
}

// add for hep C?

private DeviceType createDeviceType(
String model, List<String> testPerformedCodes, UUID diseaseUUID) {
SpecimenType specimenType =
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@
import java.util.Map;
import java.util.Set;
import java.util.stream.Collectors;
import org.jetbrains.annotations.NotNull;
import org.junit.jupiter.api.BeforeEach;
import org.junit.jupiter.api.Test;
import org.junit.jupiter.api.extension.ExtendWith;
Expand Down Expand Up @@ -432,11 +433,8 @@ void validateIndividualFields() {

@Test
void validatePositiveHivRequiredAoeFields() {
var missingHivRequiredAoeFields = validRowMap;
missingHivRequiredAoeFields.put("equipment_model_name", "HIV model");
missingHivRequiredAoeFields.put("test_performed_code", "80387-4");
missingHivRequiredAoeFields.put("specimen_type", "123456789");
missingHivRequiredAoeFields.put("test_result", "Detected");
Map<String, String> missingHivRequiredAoeFields =
getPositiveResultRowMap("HIV model", "80387-4");
missingHivRequiredAoeFields.put("pregnant", "");
missingHivRequiredAoeFields.put("genders_of_sexual_partners", "");

Expand All @@ -463,11 +461,8 @@ void validatePositiveHivRequiredAoeFields() {

@Test
void validatePositiveSyphilisRequiredAoeFields() {
var missingSyphilisRequiredAoeFields = validRowMap;
missingSyphilisRequiredAoeFields.put("equipment_model_name", "Syphilis model");
missingSyphilisRequiredAoeFields.put("test_performed_code", "80387-4");
missingSyphilisRequiredAoeFields.put("specimen_type", "123456789");
missingSyphilisRequiredAoeFields.put("test_result", "Detected");
Map<String, String> missingSyphilisRequiredAoeFields =
getPositiveResultRowMap("Syphilis model", "80387-4");
missingSyphilisRequiredAoeFields.put("pregnant", "");
missingSyphilisRequiredAoeFields.put("genders_of_sexual_partners", "");
missingSyphilisRequiredAoeFields.put("previous_syphilis_diagnosis", "");
Expand Down Expand Up @@ -495,6 +490,48 @@ void validatePositiveSyphilisRequiredAoeFields() {
"This is required because the row contains a positive Syphilis test result."));
}

@Test
void validatePositiveHepatitisCRequiredAoeFields() {
Map<String, String> missingHepCRequiredAoeFields =
getPositiveResultRowMap("Hepatitis C Model", "40726-2");
missingHepCRequiredAoeFields.put("pregnant", "");
missingHepCRequiredAoeFields.put("genders_of_sexual_partners", "");
missingHepCRequiredAoeFields.put("symptomatic_for_disease", "");

ResultsUploaderCachingService resultsUploaderCachingService =
mock(ResultsUploaderCachingService.class);
when(resultsUploaderCachingService.getModelAndTestPerformedCodeToDeviceMap())
.thenReturn(Map.of("hepatitis c model|40726-2", TestDataBuilder.createDeviceType()));
when(resultsUploaderCachingService.getHepatitisCEquipmentModelAndTestPerformedCodeSet())
.thenReturn(Set.of("hepatitis c model|40726-2"));

TestResultRow testResultRow =
new TestResultRow(
missingHepCRequiredAoeFields,
resultsUploaderCachingService,
mock(FeatureFlagsConfig.class));

List<FeedbackMessage> actual = testResultRow.validateIndividualValues();

assertThat(actual).hasSize(3);
actual.forEach(
message ->
assertThat(message.getMessage())
.contains(
"This is required because the row contains a positive Hepatitis C test result."));
}

@NotNull
private Map<String, String> getPositiveResultRowMap(
String deviceModelName, String testPerformedCode) {
Map<String, String> positiveResultRowMap = validRowMap;
positiveResultRowMap.put("equipment_model_name", deviceModelName);
positiveResultRowMap.put("test_performed_code", testPerformedCode);
positiveResultRowMap.put("specimen_type", "123456789");
positiveResultRowMap.put("test_result", "Detected");
return positiveResultRowMap;
}

private ResultsUploaderCachingService mockResultsUploaderCachingService() {
var resultsUploaderCachingService = mock(ResultsUploaderCachingService.class);
when(resultsUploaderCachingService.getModelAndTestPerformedCodeToDeviceMap())
Expand Down

0 comments on commit 85619a1

Please sign in to comment.