1
0
mirror of https://github.com/pcvolkmer/onkostar-plugin-dnpm.git synced 2025-07-04 10:02:55 +00:00

Issue #11: Service und Spring Data JPA Repository für Systemeinstellungen

This commit is contained in:
2023-03-20 14:07:00 +01:00
parent a8a5e1be8a
commit ef5c91a352
10 changed files with 223 additions and 37 deletions

View File

@ -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);
}
}

View File

@ -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();

View 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");
}
}