diff --git a/pom.xml b/pom.xml
index d47fce0..1e2bd09 100644
--- a/pom.xml
+++ b/pom.xml
@@ -92,6 +92,12 @@
5.9.2
test
+
+ org.junit.jupiter
+ junit-jupiter-params
+ 5.9.2
+ test
+
org.assertj
assertj-core
diff --git a/src/main/java/DNPM/config/PluginConfiguration.java b/src/main/java/DNPM/config/PluginConfiguration.java
index 3f27034..7cb8475 100644
--- a/src/main/java/DNPM/config/PluginConfiguration.java
+++ b/src/main/java/DNPM/config/PluginConfiguration.java
@@ -38,8 +38,8 @@ public class PluginConfiguration {
}
@Bean
- public MtbService mtbService(final SettingsService settingsService) {
- return new DefaultMtbService(settingsService);
+ public MtbService mtbService() {
+ return new DefaultMtbService();
}
@Bean
diff --git a/src/main/java/DNPM/services/mtb/DefaultMtbService.java b/src/main/java/DNPM/services/mtb/DefaultMtbService.java
index bc9d540..9926a82 100644
--- a/src/main/java/DNPM/services/mtb/DefaultMtbService.java
+++ b/src/main/java/DNPM/services/mtb/DefaultMtbService.java
@@ -1,40 +1,32 @@
package DNPM.services.mtb;
-import DNPM.services.SettingsService;
import de.itc.onkostar.api.Procedure;
+import java.util.Comparator;
import java.util.List;
+import java.util.Optional;
+import java.util.stream.Collectors;
+/**
+ * Standardimplementierung des MtbService
+ *
+ * @since 0.0.2
+ */
public class DefaultMtbService implements MtbService {
- private final SettingsService settingsService;
-
- public DefaultMtbService(final SettingsService settingsService) {
- this.settingsService = settingsService;
- }
-
@Override
public String getProtocol(List procedures) {
- ProcedureToProtocolMapper mapper = null;
- var sid = settingsService.getSID();
+ return procedures.stream()
+ .sorted(Comparator.comparing(Procedure::getStartDate))
+ .map(procedure -> {
+ var mapper = MtbService.procedureToProtocolMapper(procedure);
+ return mapper.apply(procedure);
+ })
+ .filter(Optional::isPresent)
+ .map(Optional::get)
+ .distinct()
+ .collect(Collectors.joining("\n\n"));
- if (sid.isPresent()) {
- switch (sid.get()) {
- case "2011":
- case "20119":
- mapper = new OsTumorkonferenzVarianteUkwToProtocolMapper();
- default:
- if (!settingsService.multipleMtbsInMtbEpisode()) {
- mapper = new OsTumorkonferenzToProtocolMapper();
- }
- }
- }
-
- if (null == mapper) {
- return "";
- }
-
- return mapper.apply(procedures).orElse("");
}
}
diff --git a/src/main/java/DNPM/services/mtb/MtbService.java b/src/main/java/DNPM/services/mtb/MtbService.java
index b854307..fcf55c1 100644
--- a/src/main/java/DNPM/services/mtb/MtbService.java
+++ b/src/main/java/DNPM/services/mtb/MtbService.java
@@ -3,7 +3,19 @@ package DNPM.services.mtb;
import de.itc.onkostar.api.Procedure;
import java.util.List;
+import java.util.Optional;
public interface MtbService {
String getProtocol(List procedures);
+
+ static ProcedureToProtocolMapper procedureToProtocolMapper(Procedure procedure) {
+ switch (procedure.getFormName()) {
+ case "OS.Tumorkonferenz":
+ return new OsTumorkonferenzToProtocolMapper();
+ case "OS.Tumorkonferenz.VarianteUKW":
+ return new OsTumorkonferenzVarianteUkwToProtocolMapper();
+ default:
+ return p -> Optional.empty();
+ }
+ }
}
diff --git a/src/main/java/DNPM/services/mtb/OsTumorkonferenzToProtocolMapper.java b/src/main/java/DNPM/services/mtb/OsTumorkonferenzToProtocolMapper.java
index 6379ecf..b3e99c7 100644
--- a/src/main/java/DNPM/services/mtb/OsTumorkonferenzToProtocolMapper.java
+++ b/src/main/java/DNPM/services/mtb/OsTumorkonferenzToProtocolMapper.java
@@ -2,16 +2,17 @@ package DNPM.services.mtb;
import de.itc.onkostar.api.Procedure;
-import java.util.List;
import java.util.Optional;
+
+/**
+ * Mapper zum Ermitteln des Protokollauszugs für Formular "OS.Tumorkonferenz"
+ *
+ * @since 0.0.2
+ */
public class OsTumorkonferenzToProtocolMapper implements ProcedureToProtocolMapper {
@Override
- public Optional apply(List procedures) {
- assert(procedures.size() == 1);
-
- var procedure = procedures.get(0);
-
+ public Optional apply(Procedure procedure) {
assert(procedure.getFormName().equals("OS.Tumorkonferenz"));
var fragestellung = procedure.getValue("Fragestellung");
diff --git a/src/main/java/DNPM/services/mtb/OsTumorkonferenzVarianteUkwToProtocolMapper.java b/src/main/java/DNPM/services/mtb/OsTumorkonferenzVarianteUkwToProtocolMapper.java
index 78a94eb..c55e46b 100644
--- a/src/main/java/DNPM/services/mtb/OsTumorkonferenzVarianteUkwToProtocolMapper.java
+++ b/src/main/java/DNPM/services/mtb/OsTumorkonferenzVarianteUkwToProtocolMapper.java
@@ -2,41 +2,31 @@ package DNPM.services.mtb;
import de.itc.onkostar.api.Procedure;
-import java.util.Comparator;
-import java.util.List;
import java.util.Optional;
-import java.util.stream.Collectors;
+/**
+ * Mapper zum Ermitteln des Protokollauszugs für Formular "OS.Tumorkonferenz.VarianteUKW"
+ *
+ * @since 0.0.2
+ */
public class OsTumorkonferenzVarianteUkwToProtocolMapper implements ProcedureToProtocolMapper {
@Override
- public Optional apply(List procedures) {
- procedures.forEach(procedure -> {
- assert (procedure.getFormName().equals("OS.Tumorkonferenz.VarianteUKW"));
- });
+ public Optional apply(Procedure procedure) {
+ assert (procedure.getFormName().equals("OS.Tumorkonferenz.VarianteUKW"));
- procedures.sort(Comparator.comparing(Procedure::getStartDate));
+ var fragestellung = procedure.getValue("Fragestellung");
+ var empfehlung = procedure.getValue("Empfehlung");
- var result = procedures.stream().map(procedure -> {
- var fragestellung = procedure.getValue("Fragestellung");
- var empfehlung = procedure.getValue("Empfehlung");
-
- if (
- null != fragestellung && !fragestellung.getString().isBlank()
- && null != empfehlung && !empfehlung.getString().isBlank()
- ) {
- return String.format("Fragestellung:\n%s\n\nEmpfehlung:\n%s", fragestellung.getString().trim(), empfehlung.getString().trim());
- } else if (null != fragestellung && !fragestellung.getString().isBlank()) {
- return fragestellung.getString().trim();
- } else if (null != empfehlung && !empfehlung.getString().isBlank()) {
- return empfehlung.getString().trim();
- }
- return "";
- }).collect(Collectors.joining("\n\n"));
-
- if (!result.isBlank()) {
- return Optional.of(result);
+ if (
+ null != fragestellung && !fragestellung.getString().isBlank()
+ && null != empfehlung && !empfehlung.getString().isBlank()
+ ) {
+ return Optional.of(String.format("Fragestellung:\n%s\n\nEmpfehlung:\n%s", fragestellung.getString().trim(), empfehlung.getString().trim()));
+ } else if (null != fragestellung && !fragestellung.getString().isBlank()) {
+ return Optional.of(fragestellung.getString().trim());
+ } else if (null != empfehlung && !empfehlung.getString().isBlank()) {
+ return Optional.of(empfehlung.getString().trim());
}
-
return Optional.empty();
}
}
diff --git a/src/main/java/DNPM/services/mtb/ProcedureToProtocolMapper.java b/src/main/java/DNPM/services/mtb/ProcedureToProtocolMapper.java
index 54c04d9..d4e0e4c 100644
--- a/src/main/java/DNPM/services/mtb/ProcedureToProtocolMapper.java
+++ b/src/main/java/DNPM/services/mtb/ProcedureToProtocolMapper.java
@@ -2,9 +2,8 @@ package DNPM.services.mtb;
import de.itc.onkostar.api.Procedure;
-import java.util.List;
import java.util.Optional;
import java.util.function.Function;
@FunctionalInterface
-public interface ProcedureToProtocolMapper extends Function, Optional> {}
+public interface ProcedureToProtocolMapper extends Function> {}
diff --git a/src/test/java/DNPM/services/mtb/DefaultMtbServiceTest.java b/src/test/java/DNPM/services/mtb/DefaultMtbServiceTest.java
index 073f25c..f730c85 100644
--- a/src/test/java/DNPM/services/mtb/DefaultMtbServiceTest.java
+++ b/src/test/java/DNPM/services/mtb/DefaultMtbServiceTest.java
@@ -1,6 +1,5 @@
package DNPM.services.mtb;
-import DNPM.services.SettingsService;
import de.itc.onkostar.api.IOnkostarApi;
import de.itc.onkostar.api.Item;
import de.itc.onkostar.api.Procedure;
@@ -14,35 +13,26 @@ import java.time.Instant;
import java.util.Arrays;
import java.util.Date;
import java.util.List;
-import java.util.Optional;
import static org.assertj.core.api.Assertions.assertThat;
-import static org.mockito.Mockito.when;
@ExtendWith(MockitoExtension.class)
public class DefaultMtbServiceTest {
private IOnkostarApi onkostarApi;
- private SettingsService settingsService;
-
private DefaultMtbService service;
@BeforeEach
void setup(
- @Mock IOnkostarApi onkostarApi,
- @Mock SettingsService settingsService
+ @Mock IOnkostarApi onkostarApi
) {
this.onkostarApi = onkostarApi;
- this.settingsService = settingsService;
- this.service = new DefaultMtbService(settingsService);
+ this.service = new DefaultMtbService();
}
@Test
void testShouldReturnMtbProtocolForDefaultImplementation() {
- when(settingsService.getSID()).thenReturn(Optional.of("12345"));
- when(settingsService.multipleMtbsInMtbEpisode()).thenReturn(false);
-
var procedure1 = new Procedure(onkostarApi);
procedure1.setFormName("OS.Tumorkonferenz");
procedure1.setStartDate(Date.from(Instant.parse("2023-01-01T00:00:00Z")));
@@ -59,30 +49,34 @@ public class DefaultMtbServiceTest {
}
@Test
- void testShouldReturnEmptyMtbProtocolForMultipleMtb() {
- when(settingsService.getSID()).thenReturn(Optional.of("12345"));
- when(settingsService.multipleMtbsInMtbEpisode()).thenReturn(true);
-
+ void testShouldReturnMtbProtocolForMultipleTK() {
var procedure1 = new Procedure(onkostarApi);
procedure1.setFormName("OS.Tumorkonferenz");
- procedure1.setStartDate(Date.from(Instant.parse("2023-01-01T00:00:00Z")));
- procedure1.setValue("Fragestellung", new Item("Fragestellung", "Test ok?"));
- procedure1.setValue("Empfehlung", new Item("Empfehlung", "Rerun Test if not ok!"));
+ procedure1.setStartDate(Date.from(Instant.parse("2023-02-01T00:00:00Z")));
+ procedure1.setValue("Fragestellung", new Item("Fragestellung", "Test immer noch ok?"));
+ procedure1.setValue("Empfehlung", new Item("Empfehlung", "Do not rerun Test if ok!"));
+
+ var procedure2 = new Procedure(onkostarApi);
+ procedure2.setFormName("OS.Tumorkonferenz");
+ procedure2.setStartDate(Date.from(Instant.parse("2023-01-01T00:00:00Z")));
+ procedure2.setValue("Fragestellung", new Item("Fragestellung", "Test ok?"));
+ procedure2.setValue("Empfehlung", new Item("Empfehlung", "Rerun Test if not ok!"));
var procedures = List.of(
- procedure1
+ procedure1,
+ procedure2
);
var actual = service.getProtocol(procedures);
- assertThat(actual).isEmpty();
+ assertThat(actual).isEqualTo(
+ "Fragestellung:\nTest ok?\n\nEmpfehlung:\nRerun Test if not ok!\n\n" +
+ "Fragestellung:\nTest immer noch ok?\n\nEmpfehlung:\nDo not rerun Test if ok!"
+ );
}
@Test
- void testShouldReturnMtbProtocolForSID20119() {
- when(settingsService.getSID()).thenReturn(Optional.of("20119"));
- when(settingsService.multipleMtbsInMtbEpisode()).thenReturn(true);
-
+ void testShouldReturnMtbProtocolForMultipleTKVarianteUKW() {
var procedure1 = new Procedure(onkostarApi);
procedure1.setFormName("OS.Tumorkonferenz.VarianteUKW");
procedure1.setStartDate(Date.from(Instant.parse("2023-02-01T00:00:00Z")));
@@ -109,4 +103,64 @@ public class DefaultMtbServiceTest {
);
}
+ @Test
+ void testShouldReturnDistinctProtocolEntries() {
+ var procedure1 = new Procedure(onkostarApi);
+ procedure1.setFormName("OS.Tumorkonferenz.VarianteUKW");
+ procedure1.setStartDate(Date.from(Instant.parse("2023-02-01T00:00:00Z")));
+ procedure1.setValue("Fragestellung", new Item("Fragestellung", "Test immer noch ok?"));
+ procedure1.setValue("Empfehlung", new Item("Empfehlung", "Do not rerun Test if ok!"));
+
+ var procedure2 = new Procedure(onkostarApi);
+ procedure2.setFormName("OS.Tumorkonferenz.VarianteUKW");
+ procedure2.setStartDate(Date.from(Instant.parse("2023-02-01T00:00:00Z")));
+ procedure2.setValue("Fragestellung", new Item("Fragestellung", "Test immer noch ok?"));
+ procedure2.setValue("Empfehlung", new Item("Empfehlung", "Do not rerun Test if ok!"));
+
+ var procedure3 = new Procedure(onkostarApi);
+ procedure3.setFormName("OS.Tumorkonferenz.VarianteUKW");
+ procedure3.setStartDate(Date.from(Instant.parse("2023-01-01T00:00:00Z")));
+ procedure3.setValue("Fragestellung", new Item("Fragestellung", "Test ok?"));
+ procedure3.setValue("Empfehlung", new Item("Empfehlung", "Rerun Test if not ok!"));
+
+
+ var procedures = Arrays.asList(
+ procedure1,
+ procedure2,
+ procedure3
+ );
+
+ var actual = service.getProtocol(procedures);
+
+ assertThat(actual).isEqualTo(
+ "Fragestellung:\nTest ok?\n\nEmpfehlung:\nRerun Test if not ok!\n\n" +
+ "Fragestellung:\nTest immer noch ok?\n\nEmpfehlung:\nDo not rerun Test if ok!"
+ );
+ }
+
+ @Test
+ void testShouldReturnEmptyMtbProtocolForUnknownForm() {
+ var procedure1 = new Procedure(onkostarApi);
+ procedure1.setFormName("OS.Tumorkonferenz.Unbekannt");
+ procedure1.setStartDate(Date.from(Instant.parse("2023-02-01T00:00:00Z")));
+ procedure1.setValue("Fragestellung", new Item("Fragestellung", "Test immer noch ok?"));
+ procedure1.setValue("Empfehlung", new Item("Empfehlung", "Do not rerun Test if ok!"));
+
+ var procedure2 = new Procedure(onkostarApi);
+ procedure2.setFormName("OS.Tumorkonferenz.Unbekannt");
+ procedure2.setStartDate(Date.from(Instant.parse("2023-01-01T00:00:00Z")));
+ procedure2.setValue("Fragestellung", new Item("Fragestellung", "Test ok?"));
+ procedure2.setValue("Empfehlung", new Item("Empfehlung", "Rerun Test if not ok!"));
+
+
+ var procedures = Arrays.asList(
+ procedure1,
+ procedure2
+ );
+
+ var actual = service.getProtocol(procedures);
+
+ assertThat(actual).isEmpty();
+ }
+
}
diff --git a/src/test/java/DNPM/services/mtb/MtbServiceTest.java b/src/test/java/DNPM/services/mtb/MtbServiceTest.java
new file mode 100644
index 0000000..eca9b1a
--- /dev/null
+++ b/src/test/java/DNPM/services/mtb/MtbServiceTest.java
@@ -0,0 +1,47 @@
+package DNPM.services.mtb;
+
+import de.itc.onkostar.api.IOnkostarApi;
+import de.itc.onkostar.api.Procedure;
+import org.junit.jupiter.api.BeforeEach;
+import org.junit.jupiter.api.extension.ExtendWith;
+import org.junit.jupiter.params.ParameterizedTest;
+import org.junit.jupiter.params.provider.MethodSource;
+import org.mockito.Mock;
+import org.mockito.junit.jupiter.MockitoExtension;
+
+import java.util.Map;
+import java.util.Set;
+
+import static org.assertj.core.api.Assertions.assertThat;
+
+@ExtendWith(MockitoExtension.class)
+public class MtbServiceTest {
+
+ private IOnkostarApi onkostarApi;
+
+ @BeforeEach
+ void setup(
+ @Mock IOnkostarApi onkostarApi
+ ) {
+ this.onkostarApi = onkostarApi;
+ }
+
+ private static Set>> expectedMappings() {
+ return Map.ofEntries(
+ Map.entry("OS.Tumorkonferenz", OsTumorkonferenzToProtocolMapper.class),
+ Map.entry("OS.Tumorkonferenz.VarianteUKW", OsTumorkonferenzVarianteUkwToProtocolMapper.class)
+ ).entrySet();
+ }
+
+ @ParameterizedTest
+ @MethodSource("expectedMappings")
+ void testShouldMapFormNameToMapper(Map.Entry> expectedMapping) {
+ var procedure = new Procedure(onkostarApi);
+ procedure.setFormName(expectedMapping.getKey());
+
+ var actual = MtbService.procedureToProtocolMapper(procedure);
+
+ assertThat(actual).isExactlyInstanceOf(expectedMapping.getValue());
+ }
+
+}