1
0
mirror of https://github.com/pcvolkmer/mv64e-onkostar-data.git synced 2025-09-14 00:12:52 +00:00

feat: load both - patient and patient info from KPA

This commit is contained in:
2025-06-19 15:42:35 +02:00
parent 8168bd40d4
commit e066fc4377
6 changed files with 254 additions and 8 deletions

View File

@@ -0,0 +1,111 @@
package dev.pcvolkmer.onco.datamapper;
import dev.pcvolkmer.mv64e.mtb.*;
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 org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.jdbc.core.RowMapper;
import javax.sql.DataSource;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.time.Instant;
import java.util.Date;
import java.util.List;
import java.util.Map;
import static org.assertj.core.api.Assertions.assertThat;
import static org.mockito.ArgumentMatchers.*;
import static org.mockito.Mockito.doAnswer;
@ExtendWith(MockitoExtension.class)
class KpaPatientDataMapperTest {
JdbcTemplate jdbcTemplate;
KpaPatientDataMapper dataMapper;
@BeforeEach
void setUp(@Mock JdbcTemplate jdbcTemplate) {
this.jdbcTemplate = jdbcTemplate;
this.dataMapper = KpaPatientDataMapper.create(jdbcTemplate);
}
@Test
void shouldCreateDataMapper(@Mock DataSource dataSource) {
assertThat(MtbDataMapper.create(dataSource)).isNotNull();
}
@Test
void shouldCreatePatientAlive(@Mock ResultSet resultSet) throws SQLException {
var testData = Map.of(
"patient_id", "1",
"geschlecht", "m",
"geburtsdatum", new java.sql.Date(Date.from(Instant.parse("2000-01-01T12:00:00Z")).getTime()),
"sterbedatum", new java.sql.Date(Date.from(Instant.parse("2024-06-19T12:00:00Z")).getTime()),
"artderkrankenkasse", "GKV"
);
doAnswer(invocationOnMock -> {
var columnName = invocationOnMock.getArgument(0, String.class);
return testData.get(columnName);
}).when(resultSet).getString(anyString());
doAnswer(invocationOnMock -> {
var columnName = invocationOnMock.getArgument(0, String.class);
return testData.get(columnName);
}).when(resultSet).getDate(anyString());
doAnswer(invocationOnMock -> List.of(resultSet))
.when(jdbcTemplate)
.query(anyString(), any(RowMapper.class), anyInt());
var actual = this.dataMapper.getById(1);
assertThat(actual).isInstanceOf(Patient.class);
assertThat(actual.getId()).isEqualTo("1");
assertThat(actual.getGender().getCode()).isEqualTo(GenderCodingCode.MALE);
assertThat(actual.getBirthDate()).isEqualTo(Date.from(Instant.parse("2000-01-01T12:00:00Z")));
assertThat(actual.getDateOfDeath()).isEqualTo(Date.from(Instant.parse("2024-06-19T12:00:00Z")));
assertThat(actual.getHealthInsurance()).isEqualTo(
HealthInsurance.builder().type(HealthInsuranceCoding.builder().code(HealthInsuranceCodingCode.GKV).build()).build()
);
}
@Test
void shouldCreatePatientDead(@Mock ResultSet resultSet) throws SQLException {
var testData = Map.of(
"patient_id", "1",
"geschlecht", "w",
"geburtsdatum", new java.sql.Date(Date.from(Instant.parse("2000-01-01T12:00:00Z")).getTime()),
"artderkrankenkasse", "PKV"
);
doAnswer(invocationOnMock -> {
var columnName = invocationOnMock.getArgument(0, String.class);
return testData.get(columnName);
}).when(resultSet).getString(anyString());
doAnswer(invocationOnMock -> {
var columnName = invocationOnMock.getArgument(0, String.class);
return testData.get(columnName);
}).when(resultSet).getDate(anyString());
doAnswer(invocationOnMock -> List.of(resultSet))
.when(jdbcTemplate)
.query(anyString(), any(RowMapper.class), anyInt());
var actual = this.dataMapper.getById(1);
assertThat(actual).isInstanceOf(Patient.class);
assertThat(actual.getId()).isEqualTo("1");
assertThat(actual.getGender().getCode()).isEqualTo(GenderCodingCode.FEMALE);
assertThat(actual.getBirthDate()).isEqualTo(Date.from(Instant.parse("2000-01-01T12:00:00Z")));
assertThat(actual.getDateOfDeath()).isNull();
assertThat(actual.getHealthInsurance()).isEqualTo(
HealthInsurance.builder().type(HealthInsuranceCoding.builder().code(HealthInsuranceCodingCode.PKV).build()).build()
);
}
}