mirror of
https://github.com/pcvolkmer/onkostar-plugin-dnpm.git
synced 2025-07-03 17:52:53 +00:00
Issue #4: Verschiebe Backend-Methode in EinzelempfehlungAnalyzer
This commit is contained in:
@ -2,17 +2,21 @@ package DNPM.analyzer;
|
||||
|
||||
import DNPM.security.PermissionType;
|
||||
import DNPM.security.PersonPoolBasedPermissionEvaluator;
|
||||
import DNPM.services.StudienService;
|
||||
import DNPM.services.molekulargenetik.MolekulargenetikFormService;
|
||||
import de.itc.onkostar.api.IOnkostarApi;
|
||||
import de.itc.onkostar.api.Procedure;
|
||||
import org.junit.jupiter.api.BeforeEach;
|
||||
import org.junit.jupiter.api.Test;
|
||||
import org.junit.jupiter.api.extension.ExtendWith;
|
||||
import org.mockito.ArgumentCaptor;
|
||||
import org.mockito.Mock;
|
||||
import org.mockito.junit.jupiter.MockitoExtension;
|
||||
|
||||
import java.util.HashMap;
|
||||
import java.util.Map;
|
||||
|
||||
import static org.assertj.core.api.Assertions.assertThat;
|
||||
import static org.mockito.ArgumentMatchers.any;
|
||||
import static org.mockito.Mockito.*;
|
||||
|
||||
@ -21,6 +25,8 @@ class EinzelempfehlungAnalyzerTest {
|
||||
|
||||
private IOnkostarApi onkostarApi;
|
||||
|
||||
private StudienService studienService;
|
||||
|
||||
private MolekulargenetikFormService molekulargenetikFormService;
|
||||
|
||||
private PersonPoolBasedPermissionEvaluator permissionEvaluator;
|
||||
@ -30,13 +36,15 @@ class EinzelempfehlungAnalyzerTest {
|
||||
@BeforeEach
|
||||
void setup(
|
||||
@Mock IOnkostarApi onkostarApi,
|
||||
@Mock StudienService studienService,
|
||||
@Mock MolekulargenetikFormService molekulargenetikFormService,
|
||||
@Mock PersonPoolBasedPermissionEvaluator permissionEvaluator
|
||||
) {
|
||||
this.onkostarApi = onkostarApi;
|
||||
this.studienService = studienService;
|
||||
this.molekulargenetikFormService = molekulargenetikFormService;
|
||||
this.permissionEvaluator = permissionEvaluator;
|
||||
this.analyzer = new EinzelempfehlungAnalyzer(onkostarApi, molekulargenetikFormService, permissionEvaluator);
|
||||
this.analyzer = new EinzelempfehlungAnalyzer(onkostarApi, studienService, molekulargenetikFormService, permissionEvaluator);
|
||||
}
|
||||
|
||||
@Test
|
||||
@ -49,4 +57,30 @@ class EinzelempfehlungAnalyzerTest {
|
||||
verify(molekulargenetikFormService, times(1)).getVariants(any(Procedure.class));
|
||||
}
|
||||
|
||||
@Test
|
||||
void shouldRequestAllStudienForEmptyQueryString() {
|
||||
var input = Map.of("q", (Object) " ");
|
||||
this.analyzer.getStudien(input);
|
||||
|
||||
verify(studienService, times(1)).findAll();
|
||||
}
|
||||
|
||||
@Test
|
||||
void shouldRequestAllStudienForEmptyInputMap() {
|
||||
var input = new HashMap<String, Object>();
|
||||
this.analyzer.getStudien(input);
|
||||
|
||||
verify(studienService, times(1)).findAll();
|
||||
}
|
||||
|
||||
@Test
|
||||
void shouldRequestFilteredStudien() {
|
||||
var input = Map.of("q", (Object) "NCT-123");
|
||||
this.analyzer.getStudien(input);
|
||||
|
||||
var captor = ArgumentCaptor.forClass(String.class);
|
||||
verify(studienService, times(1)).findByQuery(captor.capture());
|
||||
assertThat(captor.getValue()).isEqualTo("NCT-123");
|
||||
}
|
||||
|
||||
}
|
||||
|
@ -2,7 +2,7 @@ package DNPM.analyzer;
|
||||
|
||||
import DNPM.security.DelegatingDataBasedPermissionEvaluator;
|
||||
import DNPM.security.PermissionType;
|
||||
import DNPM.services.*;
|
||||
import DNPM.services.FormService;
|
||||
import DNPM.services.mtb.MtbService;
|
||||
import DNPM.services.therapieplan.MultipleMtbTherapieplanService;
|
||||
import DNPM.services.therapieplan.TherapieplanService;
|
||||
@ -17,7 +17,6 @@ import org.mockito.ArgumentCaptor;
|
||||
import org.mockito.Mock;
|
||||
import org.mockito.junit.jupiter.MockitoExtension;
|
||||
|
||||
import java.util.HashMap;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
|
||||
@ -33,9 +32,6 @@ class TherapieplanAnalyzerTest {
|
||||
@Mock
|
||||
private FormService formService;
|
||||
|
||||
@Mock
|
||||
private StudienService studienService;
|
||||
|
||||
@Mock
|
||||
private TherapieplanServiceFactory therapieplanServiceFactory;
|
||||
|
||||
@ -52,7 +48,7 @@ class TherapieplanAnalyzerTest {
|
||||
|
||||
@BeforeEach
|
||||
void setUp() {
|
||||
this.therapieplanAnalyzer = new TherapieplanAnalyzer(studienService, therapieplanServiceFactory, mtbService, permissionEvaluator);
|
||||
this.therapieplanAnalyzer = new TherapieplanAnalyzer(therapieplanServiceFactory, mtbService, permissionEvaluator);
|
||||
}
|
||||
|
||||
@Test
|
||||
@ -65,32 +61,6 @@ class TherapieplanAnalyzerTest {
|
||||
verify(this.therapieplanServiceFactory, times(1)).currentUsableInstance();
|
||||
}
|
||||
|
||||
@Test
|
||||
void shouldRequestAllStudienForEmptyQueryString() {
|
||||
var input = Map.of("q", (Object) " ");
|
||||
this.therapieplanAnalyzer.getStudien(input);
|
||||
|
||||
verify(studienService, times(1)).findAll();
|
||||
}
|
||||
|
||||
@Test
|
||||
void shouldRequestAllStudienForEmptyInputMap() {
|
||||
var input = new HashMap<String, Object>();
|
||||
this.therapieplanAnalyzer.getStudien(input);
|
||||
|
||||
verify(studienService, times(1)).findAll();
|
||||
}
|
||||
|
||||
@Test
|
||||
void shouldRequestFilteredStudien() {
|
||||
var input = Map.of("q", (Object) "NCT-123");
|
||||
this.therapieplanAnalyzer.getStudien(input);
|
||||
|
||||
var captor = ArgumentCaptor.forClass(String.class);
|
||||
verify(studienService, times(1)).findByQuery(captor.capture());
|
||||
assertThat(captor.getValue()).isEqualTo("NCT-123");
|
||||
}
|
||||
|
||||
@Test
|
||||
void shouldRequestProtokollauszug() {
|
||||
doAnswer(invocationOnMock -> {
|
||||
|
Reference in New Issue
Block a user