mirror of
https://github.com/pcvolkmer/onkostar-plugin-dnpm.git
synced 2025-07-03 09:42:54 +00:00
Issue #11: Service und Spring Data JPA Repository für Systemeinstellungen
This commit is contained in:
@ -1,6 +1,7 @@
|
||||
package DNPM.config;
|
||||
|
||||
import DNPM.services.FormService;
|
||||
import DNPM.services.SettingsService;
|
||||
import DNPM.services.TherapieplanServiceFactory;
|
||||
import de.itc.onkostar.api.IOnkostarApi;
|
||||
import org.junit.jupiter.api.BeforeEach;
|
||||
@ -17,6 +18,9 @@ public class PluginConfigurationTest {
|
||||
@Mock
|
||||
private IOnkostarApi onkostarApi;
|
||||
|
||||
@Mock
|
||||
private SettingsService settingsService;
|
||||
|
||||
@Mock
|
||||
private FormService formService;
|
||||
|
||||
@ -29,7 +33,7 @@ public class PluginConfigurationTest {
|
||||
|
||||
@Test
|
||||
void testShouldReturnTherapieplanServiceFactory() {
|
||||
var actual = this.configuration.therapieplanServiceFactory(onkostarApi, formService);
|
||||
var actual = this.configuration.therapieplanServiceFactory(onkostarApi, settingsService, formService);
|
||||
assertThat(actual).isInstanceOf(TherapieplanServiceFactory.class);
|
||||
}
|
||||
}
|
||||
|
@ -1,9 +1,6 @@
|
||||
package DNPM.config;
|
||||
|
||||
import DNPM.services.DefaultTherapieplanService;
|
||||
import DNPM.services.FormService;
|
||||
import DNPM.services.MultipleMtbTherapieplanService;
|
||||
import DNPM.services.TherapieplanServiceFactory;
|
||||
import DNPM.services.*;
|
||||
import de.itc.onkostar.api.IOnkostarApi;
|
||||
import org.junit.jupiter.api.BeforeEach;
|
||||
import org.junit.jupiter.api.Test;
|
||||
@ -12,8 +9,6 @@ import org.mockito.Mock;
|
||||
import org.mockito.junit.jupiter.MockitoExtension;
|
||||
|
||||
import static org.assertj.core.api.Assertions.assertThat;
|
||||
import static org.mockito.ArgumentMatchers.anyString;
|
||||
import static org.mockito.Mockito.doAnswer;
|
||||
import static org.mockito.Mockito.when;
|
||||
|
||||
@ExtendWith(MockitoExtension.class)
|
||||
@ -25,32 +20,21 @@ public class TherapieplanServiceFactoryTest {
|
||||
@Mock
|
||||
private FormService formService;
|
||||
|
||||
@Mock
|
||||
private SettingsService settingsService;
|
||||
|
||||
private TherapieplanServiceFactory therapieplanServiceFactory;
|
||||
|
||||
@BeforeEach
|
||||
void setup() {
|
||||
this.therapieplanServiceFactory = new TherapieplanServiceFactory(onkostarApi, formService);
|
||||
this.therapieplanServiceFactory = new TherapieplanServiceFactory(onkostarApi, settingsService, formService);
|
||||
}
|
||||
|
||||
@Test
|
||||
void testShouldReturnDefaultTherapieplanServiceIfSettingIsFalse() {
|
||||
doAnswer(invocationOnMock -> {
|
||||
var settingName = invocationOnMock.getArgument(0, String.class);
|
||||
if (settingName.equals("mehrere_mtb_in_mtbepisode")) {
|
||||
return "false";
|
||||
}
|
||||
return null;
|
||||
}).when(onkostarApi).getGlobalSetting(anyString());
|
||||
|
||||
when(settingsService.multipleMtbsInMtbEpisode()).thenReturn(false);
|
||||
var actual = this.therapieplanServiceFactory.currentUsableInstance();
|
||||
|
||||
assertThat(actual).isInstanceOf(DefaultTherapieplanService.class);
|
||||
}
|
||||
|
||||
@Test
|
||||
void testShouldReturnDefaultTherapieplanServiceIfNoSetting() {
|
||||
when(onkostarApi.getGlobalSetting(anyString())).thenReturn(null);
|
||||
|
||||
var actual = this.therapieplanServiceFactory.currentUsableInstance();
|
||||
|
||||
assertThat(actual).isInstanceOf(DefaultTherapieplanService.class);
|
||||
@ -58,13 +42,7 @@ public class TherapieplanServiceFactoryTest {
|
||||
|
||||
@Test
|
||||
void testShouldReturnMultipleMtbTherapieplanServiceIfSettingIsTrue() {
|
||||
doAnswer(invocationOnMock -> {
|
||||
var settingName = invocationOnMock.getArgument(0, String.class);
|
||||
if (settingName.equals("mehrere_mtb_in_mtbepisode")) {
|
||||
return "true";
|
||||
}
|
||||
return null;
|
||||
}).when(onkostarApi).getGlobalSetting(anyString());
|
||||
when(settingsService.multipleMtbsInMtbEpisode()).thenReturn(true);
|
||||
|
||||
var actual = this.therapieplanServiceFactory.currentUsableInstance();
|
||||
|
||||
|
58
src/test/java/DNPM/services/SettingsServiceTest.java
Normal file
58
src/test/java/DNPM/services/SettingsServiceTest.java
Normal file
@ -0,0 +1,58 @@
|
||||
package DNPM.services;
|
||||
|
||||
import DNPM.database.SettingsRepository;
|
||||
import de.itc.db.dnpm.Setting;
|
||||
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.anyString;
|
||||
import static org.mockito.Mockito.doAnswer;
|
||||
|
||||
@ExtendWith(MockitoExtension.class)
|
||||
public class SettingsServiceTest {
|
||||
|
||||
@Mock
|
||||
private SettingsRepository settingsRepository;
|
||||
|
||||
private SettingsService service;
|
||||
|
||||
@BeforeEach
|
||||
void setUp() {
|
||||
this.service = new SettingsService(settingsRepository);
|
||||
}
|
||||
|
||||
@Test
|
||||
void shouldReturnSID() {
|
||||
doAnswer(invocationOnMock -> {
|
||||
var name = invocationOnMock.getArgument(0, String.class);
|
||||
if (null != name && name.equals("SID")) {
|
||||
return new Setting(1L, "SID", "12345");
|
||||
}
|
||||
return null;
|
||||
}).when(settingsRepository).findByName(anyString());
|
||||
|
||||
var actual = service.getSID();
|
||||
assertThat(actual).isPresent();
|
||||
assertThat(actual.get()).isEqualTo("12345");
|
||||
}
|
||||
|
||||
@Test
|
||||
void shouldReturnSIDByName() {
|
||||
doAnswer(invocationOnMock -> {
|
||||
var name = invocationOnMock.getArgument(0, String.class);
|
||||
if (null != name && name.equals("SID")) {
|
||||
return new Setting(1L, "SID", "12345");
|
||||
}
|
||||
return null;
|
||||
}).when(settingsRepository).findByName(anyString());
|
||||
|
||||
var actual = service.getSetting("SID");
|
||||
assertThat(actual).isPresent();
|
||||
assertThat(actual.get()).isEqualTo("12345");
|
||||
}
|
||||
|
||||
}
|
Reference in New Issue
Block a user