summaryrefslogtreecommitdiff
path: root/src/test/java/DNPM/services
diff options
context:
space:
mode:
Diffstat (limited to 'src/test/java/DNPM/services')
-rw-r--r--src/test/java/DNPM/services/TherapieplanServiceFactoryTest.java49
-rw-r--r--src/test/java/DNPM/services/consent/ConsentManagerServiceFactoryTest.java50
2 files changed, 99 insertions, 0 deletions
diff --git a/src/test/java/DNPM/services/TherapieplanServiceFactoryTest.java b/src/test/java/DNPM/services/TherapieplanServiceFactoryTest.java
new file mode 100644
index 0000000..9ba543f
--- /dev/null
+++ b/src/test/java/DNPM/services/TherapieplanServiceFactoryTest.java
@@ -0,0 +1,49 @@
+package DNPM.services;
+
+import de.itc.onkostar.api.IOnkostarApi;
+import org.junit.jupiter.api.BeforeEach;
+import org.junit.jupiter.api.Test;
+import org.junit.jupiter.api.extension.ExtendWith;
+import org.mockito.Mock;
+import org.mockito.junit.jupiter.MockitoExtension;
+
+import static org.assertj.core.api.Assertions.assertThat;
+import static org.mockito.Mockito.when;
+
+@ExtendWith(MockitoExtension.class)
+class TherapieplanServiceFactoryTest {
+
+ @Mock
+ private IOnkostarApi onkostarApi;
+
+ @Mock
+ private FormService formService;
+
+ @Mock
+ private SettingsService settingsService;
+
+ private TherapieplanServiceFactory therapieplanServiceFactory;
+
+ @BeforeEach
+ void setup() {
+ this.therapieplanServiceFactory = new TherapieplanServiceFactory(onkostarApi, settingsService, formService);
+ }
+
+ @Test
+ void testShouldReturnDefaultTherapieplanServiceIfSettingIsFalse() {
+ when(settingsService.multipleMtbsInMtbEpisode()).thenReturn(false);
+
+ var actual = this.therapieplanServiceFactory.currentUsableInstance();
+
+ assertThat(actual).isInstanceOf(DefaultTherapieplanService.class);
+ }
+
+ @Test
+ void testShouldReturnMultipleMtbTherapieplanServiceIfSettingIsTrue() {
+ when(settingsService.multipleMtbsInMtbEpisode()).thenReturn(true);
+
+ var actual = this.therapieplanServiceFactory.currentUsableInstance();
+
+ assertThat(actual).isInstanceOf(MultipleMtbTherapieplanService.class);
+ }
+}
diff --git a/src/test/java/DNPM/services/consent/ConsentManagerServiceFactoryTest.java b/src/test/java/DNPM/services/consent/ConsentManagerServiceFactoryTest.java
new file mode 100644
index 0000000..01d5488
--- /dev/null
+++ b/src/test/java/DNPM/services/consent/ConsentManagerServiceFactoryTest.java
@@ -0,0 +1,50 @@
+package DNPM.services.consent;
+
+import de.itc.onkostar.api.IOnkostarApi;
+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;
+import static org.mockito.ArgumentMatchers.anyString;
+import static org.mockito.Mockito.when;
+
+@ExtendWith(MockitoExtension.class)
+class ConsentManagerServiceFactoryTest {
+
+ private IOnkostarApi onkostarApi;
+
+ private ConsentManagerServiceFactory consentManagerServiceFactory;
+
+ @BeforeEach
+ void setup(
+ @Mock IOnkostarApi onkostarApi
+ ) {
+ this.onkostarApi = onkostarApi;
+ this.consentManagerServiceFactory = new ConsentManagerServiceFactory(onkostarApi);
+ }
+
+ private static Set<Map.Entry<String, Class<? extends ConsentManagerService>>> expectedMappings() {
+ return Map.ofEntries(
+ Map.entry("MR.Consent", MrConsentManagerService.class),
+ Map.entry("Excel-Formular", UkwConsentManagerService.class)
+ ).entrySet();
+ }
+
+ @ParameterizedTest
+ @MethodSource("expectedMappings")
+ void testShouldMapFormNameToService(Map.Entry<String, Class<?>> expectedMapping) {
+ when(onkostarApi.getGlobalSetting(anyString())).thenReturn(expectedMapping.getKey());
+
+ var actual = consentManagerServiceFactory.currentUsableInstance();
+
+ assertThat(actual).isExactlyInstanceOf(expectedMapping.getValue());
+ }
+
+}