summaryrefslogtreecommitdiff
path: root/src/test/java/DNPM/services/consent/MrConsentManagerServiceTest.java
diff options
context:
space:
mode:
authorPaul-Christian Volkmer2023-04-03 14:34:32 +0200
committerPaul-Christian Volkmer2023-04-03 14:35:31 +0200
commita97d76e5bbe42cde2a5729efedcdcdcd7c26bbe9 (patch)
treea1d835ea86ba24a13bf5904c49cdb16e1085e0cb /src/test/java/DNPM/services/consent/MrConsentManagerServiceTest.java
parentd548c5e5a3cb190fd68b90e2c12dc775da5edf5f (diff)
Issue #20: Detailimplementierungen für Consent Management
Diffstat (limited to 'src/test/java/DNPM/services/consent/MrConsentManagerServiceTest.java')
-rw-r--r--src/test/java/DNPM/services/consent/MrConsentManagerServiceTest.java61
1 files changed, 61 insertions, 0 deletions
diff --git a/src/test/java/DNPM/services/consent/MrConsentManagerServiceTest.java b/src/test/java/DNPM/services/consent/MrConsentManagerServiceTest.java
new file mode 100644
index 0000000..2c8448e
--- /dev/null
+++ b/src/test/java/DNPM/services/consent/MrConsentManagerServiceTest.java
@@ -0,0 +1,61 @@
+package DNPM.services.consent;
+
+import de.itc.onkostar.api.IOnkostarApi;
+import de.itc.onkostar.api.Procedure;
+import org.hibernate.SQLQuery;
+import org.hibernate.Session;
+import org.hibernate.SessionFactory;
+import org.hibernate.type.Type;
+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 static org.assertj.core.api.Assertions.assertThat;
+import static org.mockito.ArgumentMatchers.any;
+import static org.mockito.ArgumentMatchers.anyString;
+import static org.mockito.Mockito.*;
+
+@ExtendWith(MockitoExtension.class)
+public class MrConsentManagerServiceTest {
+
+ private IOnkostarApi onkostarApi;
+
+ private MrConsentManagerService service;
+
+ @BeforeEach
+ void setup(
+ @Mock IOnkostarApi onkostarApi
+ ) {
+ this.onkostarApi = onkostarApi;
+ this.service = new MrConsentManagerService(onkostarApi);
+ }
+
+ @Test
+ void testShouldCreateSqlQueriesWithRelatedEntityIds() {
+ var sessionFactory = mock(SessionFactory.class);
+ var session = mock(Session.class);
+ var query = mock(SQLQuery.class);
+
+ when(onkostarApi.getSessionFactory()).thenReturn(sessionFactory);
+ when(sessionFactory.getCurrentSession()).thenReturn(session);
+ when(session.createSQLQuery(anyString())).thenReturn(query);
+ when(query.addScalar(anyString(), any(Type.class))).thenReturn(query);
+ when(query.uniqueResult()).thenReturn("");
+
+ var dummyProzedur = new Procedure(this.onkostarApi);
+ dummyProzedur.setId(111);
+ dummyProzedur.setPatientId(123);
+
+ this.service.applyConsent(dummyProzedur);
+
+ var argumentCaptor = ArgumentCaptor.forClass(String.class);
+ verify(session, times(2)).createSQLQuery(argumentCaptor.capture());
+ assertThat(argumentCaptor.getAllValues()).hasSize(2);
+ assertThat(argumentCaptor.getAllValues().get(0)).contains("where entity_id = '111'");
+ assertThat(argumentCaptor.getAllValues().get(1)).contains("WHERE patient_id = 123 AND geloescht = 0");
+ }
+
+}