From b75328b74d361b7afd6197a5b240f5f76ce2c5e0 Mon Sep 17 00:00:00 2001
From: Paul-Christian Volkmer
Date: Tue, 8 Aug 2023 15:16:58 +0200
Subject: Move integration tests into own source-set
---
.../etl/processor/AbstractTestcontainerTest.kt | 51 ++++++++
.../etl/processor/EtlProcessorApplicationTests.kt | 37 ++++++
.../services/RequestServiceIntegrationTest.kt | 131 +++++++++++++++++++++
3 files changed, 219 insertions(+)
create mode 100644 src/integrationTest/kotlin/dev/dnpm/etl/processor/AbstractTestcontainerTest.kt
create mode 100644 src/integrationTest/kotlin/dev/dnpm/etl/processor/EtlProcessorApplicationTests.kt
create mode 100644 src/integrationTest/kotlin/dev/dnpm/etl/processor/services/RequestServiceIntegrationTest.kt
(limited to 'src/integrationTest')
diff --git a/src/integrationTest/kotlin/dev/dnpm/etl/processor/AbstractTestcontainerTest.kt b/src/integrationTest/kotlin/dev/dnpm/etl/processor/AbstractTestcontainerTest.kt
new file mode 100644
index 0000000..13b57d0
--- /dev/null
+++ b/src/integrationTest/kotlin/dev/dnpm/etl/processor/AbstractTestcontainerTest.kt
@@ -0,0 +1,51 @@
+/*
+ * This file is part of ETL-Processor
+ *
+ * Copyright (c) 2023 Comprehensive Cancer Center Mainfranken, Datenintegrationszentrum Philipps-Universität Marburg and Contributors
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Affero General Public License as published
+ * by the Free Software Foundation, either version 3 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU Affero General Public License for more details.
+ *
+ * You should have received a copy of the GNU Affero General Public License
+ * along with this program. If not, see .
+ */
+
+package dev.dnpm.etl.processor
+
+import org.springframework.test.context.DynamicPropertyRegistry
+import org.springframework.test.context.DynamicPropertySource
+import org.testcontainers.containers.PostgreSQLContainer
+import org.testcontainers.junit.jupiter.Container
+
+abstract class AbstractTestcontainerTest {
+
+ companion object {
+ @Container
+ val dbContainer = CustomPostgreSQLContainer("postgres:10-alpine")
+ .withDatabaseName("test")
+ .withUsername("test")
+ .withPassword("test") ?: throw RuntimeException("Failed to create testcontainer!")
+
+ @DynamicPropertySource
+ @JvmStatic
+ fun registerDynamicProperties(registry: DynamicPropertyRegistry) {
+ registry.add("spring.datasource.url", dbContainer::getJdbcUrl)
+ registry.add("spring.datasource.username", dbContainer::getUsername)
+ registry.add("spring.datasource.password", dbContainer::getPassword)
+ }
+ }
+
+}
+
+class CustomPostgreSQLContainer(dockerImageName: String) : PostgreSQLContainer(dockerImageName) {
+ override fun stop() {
+ // Keep Testcontainer alive until JVM destroys it
+ }
+}
\ No newline at end of file
diff --git a/src/integrationTest/kotlin/dev/dnpm/etl/processor/EtlProcessorApplicationTests.kt b/src/integrationTest/kotlin/dev/dnpm/etl/processor/EtlProcessorApplicationTests.kt
new file mode 100644
index 0000000..07a201b
--- /dev/null
+++ b/src/integrationTest/kotlin/dev/dnpm/etl/processor/EtlProcessorApplicationTests.kt
@@ -0,0 +1,37 @@
+/*
+ * This file is part of ETL-Processor
+ *
+ * Copyright (c) 2023 Comprehensive Cancer Center Mainfranken, Datenintegrationszentrum Philipps-Universität Marburg and Contributors
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Affero General Public License as published
+ * by the Free Software Foundation, either version 3 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU Affero General Public License for more details.
+ *
+ * You should have received a copy of the GNU Affero General Public License
+ * along with this program. If not, see .
+ */
+
+package dev.dnpm.etl.processor
+
+import org.junit.jupiter.api.Test
+import org.junit.jupiter.api.extension.ExtendWith
+import org.springframework.boot.test.context.SpringBootTest
+import org.springframework.test.context.junit.jupiter.SpringExtension
+import org.testcontainers.junit.jupiter.Testcontainers
+
+@Testcontainers
+@ExtendWith(SpringExtension::class)
+@SpringBootTest
+class EtlProcessorApplicationTests : AbstractTestcontainerTest() {
+
+ @Test
+ fun contextLoads() {
+ }
+
+}
diff --git a/src/integrationTest/kotlin/dev/dnpm/etl/processor/services/RequestServiceIntegrationTest.kt b/src/integrationTest/kotlin/dev/dnpm/etl/processor/services/RequestServiceIntegrationTest.kt
new file mode 100644
index 0000000..d71e011
--- /dev/null
+++ b/src/integrationTest/kotlin/dev/dnpm/etl/processor/services/RequestServiceIntegrationTest.kt
@@ -0,0 +1,131 @@
+/*
+ * This file is part of ETL-Processor
+ *
+ * Copyright (c) 2023 Comprehensive Cancer Center Mainfranken, Datenintegrationszentrum Philipps-Universität Marburg and Contributors
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Affero General Public License as published
+ * by the Free Software Foundation, either version 3 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU Affero General Public License for more details.
+ *
+ * You should have received a copy of the GNU Affero General Public License
+ * along with this program. If not, see .
+ */
+
+package dev.dnpm.etl.processor.services
+
+import dev.dnpm.etl.processor.AbstractTestcontainerTest
+import dev.dnpm.etl.processor.monitoring.Request
+import dev.dnpm.etl.processor.monitoring.RequestRepository
+import dev.dnpm.etl.processor.monitoring.RequestStatus
+import dev.dnpm.etl.processor.monitoring.RequestType
+import org.assertj.core.api.Assertions.assertThat
+import org.junit.jupiter.api.BeforeEach
+import org.junit.jupiter.api.Test
+import org.junit.jupiter.api.extension.ExtendWith
+import org.springframework.beans.factory.annotation.Autowired
+import org.springframework.boot.test.context.SpringBootTest
+import org.springframework.test.context.junit.jupiter.SpringExtension
+import org.springframework.transaction.annotation.Transactional
+import org.testcontainers.junit.jupiter.Testcontainers
+import java.time.Instant
+import java.util.*
+
+@Testcontainers
+@ExtendWith(SpringExtension::class)
+@SpringBootTest
+@Transactional
+class RequestServiceIntegrationTest : AbstractTestcontainerTest() {
+
+ private lateinit var requestRepository: RequestRepository
+
+ private lateinit var requestService: RequestService
+
+ @BeforeEach
+ fun setup(
+ @Autowired requestRepository: RequestRepository
+ ) {
+ this.requestRepository = requestRepository
+ this.requestService = RequestService(requestRepository)
+ }
+
+ @Test
+ fun shouldResultInEmptyRequestList() {
+ val actual = requestService.allRequestsByPatientPseudonym("TEST_12345678901")
+
+ assertThat(actual).isEmpty()
+ }
+
+ private fun setupTestData() {
+ // Prepare DB
+ this.requestRepository.saveAll(
+ listOf(
+ Request(
+ uuid = UUID.randomUUID().toString(),
+ patientId = "TEST_12345678901",
+ pid = "P1",
+ fingerprint = "0123456789abcdef1",
+ type = RequestType.MTB_FILE,
+ status = RequestStatus.SUCCESS,
+ processedAt = Instant.parse("2023-07-07T02:00:00Z")
+ ),
+ // Should be ignored - wrong patient ID -->
+ Request(
+ uuid = UUID.randomUUID().toString(),
+ patientId = "TEST_12345678902",
+ pid = "P2",
+ fingerprint = "0123456789abcdef2",
+ type = RequestType.MTB_FILE,
+ status = RequestStatus.WARNING,
+ processedAt = Instant.parse("2023-08-08T00:00:00Z")
+ ),
+ // <--
+ Request(
+ uuid = UUID.randomUUID().toString(),
+ patientId = "TEST_12345678901",
+ pid = "P2",
+ fingerprint = "0123456789abcdee1",
+ type = RequestType.DELETE,
+ status = RequestStatus.SUCCESS,
+ processedAt = Instant.parse("2023-08-08T02:00:00Z")
+ )
+ )
+ )
+ }
+
+ @Test
+ fun shouldResultInSortedRequestList() {
+ setupTestData()
+
+ val actual = requestService.allRequestsByPatientPseudonym("TEST_12345678901")
+
+ assertThat(actual).hasSize(2)
+ assertThat(actual[0].fingerprint).isEqualTo("0123456789abcdee1")
+ assertThat(actual[1].fingerprint).isEqualTo("0123456789abcdef1")
+ }
+
+ @Test
+ fun shouldReturnDeleteRequestAsLastRequest() {
+ setupTestData()
+
+ val actual = requestService.isLastRequestDeletion("TEST_12345678901")
+
+ assertThat(actual).isTrue()
+ }
+
+ @Test
+ fun shouldReturnLastMtbFileRequest() {
+ setupTestData()
+
+ val actual = requestService.lastMtbFileRequestForPatientPseudonym("TEST_12345678901")
+
+ assertThat(actual).isNotNull
+ assertThat(actual?.fingerprint).isEqualTo("0123456789abcdef1")
+ }
+
+}
\ No newline at end of file
--
cgit v1.2.3
From 13bfa0018d6c9b48893ef96945659be9e7eec6c0 Mon Sep 17 00:00:00 2001
From: Paul-Christian Volkmer
Date: Wed, 9 Aug 2023 10:20:20 +0200
Subject: Change endpoint configuration to select single endpoint
* If REST endpoint is configured, it will be used
* If Kafka endpoint is configured, it will be used
* If both endpoints are configured, REST configuration has precedence and will be used
---
.../etl/processor/config/AppConfigurationTest.kt | 102 +++++++++++++++++++++
1 file changed, 102 insertions(+)
create mode 100644 src/integrationTest/kotlin/dev/dnpm/etl/processor/config/AppConfigurationTest.kt
(limited to 'src/integrationTest')
diff --git a/src/integrationTest/kotlin/dev/dnpm/etl/processor/config/AppConfigurationTest.kt b/src/integrationTest/kotlin/dev/dnpm/etl/processor/config/AppConfigurationTest.kt
new file mode 100644
index 0000000..8bdaa60
--- /dev/null
+++ b/src/integrationTest/kotlin/dev/dnpm/etl/processor/config/AppConfigurationTest.kt
@@ -0,0 +1,102 @@
+/*
+ * This file is part of ETL-Processor
+ *
+ * Copyright (c) 2023 Comprehensive Cancer Center Mainfranken, Datenintegrationszentrum Philipps-Universität Marburg and Contributors
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Affero General Public License as published
+ * by the Free Software Foundation, either version 3 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU Affero General Public License for more details.
+ *
+ * You should have received a copy of the GNU Affero General Public License
+ * along with this program. If not, see .
+ */
+
+package dev.dnpm.etl.processor.config
+
+import com.fasterxml.jackson.databind.ObjectMapper
+import dev.dnpm.etl.processor.monitoring.RequestRepository
+import dev.dnpm.etl.processor.output.KafkaMtbFileSender
+import dev.dnpm.etl.processor.output.RestMtbFileSender
+import org.assertj.core.api.Assertions.assertThat
+import org.junit.jupiter.api.Nested
+import org.junit.jupiter.api.Test
+import org.junit.jupiter.api.assertThrows
+import org.springframework.beans.factory.NoSuchBeanDefinitionException
+import org.springframework.boot.autoconfigure.kafka.KafkaAutoConfiguration
+import org.springframework.boot.test.context.SpringBootTest
+import org.springframework.boot.test.mock.mockito.MockBean
+import org.springframework.boot.test.mock.mockito.MockBeans
+import org.springframework.context.ApplicationContext
+import org.springframework.test.context.ContextConfiguration
+import org.springframework.test.context.TestPropertySource
+
+@SpringBootTest
+@ContextConfiguration(classes = [KafkaAutoConfiguration::class, AppKafkaConfiguration::class, AppRestConfiguration::class])
+class AppConfigurationTest {
+
+ @Nested
+ @TestPropertySource(
+ properties = [
+ "app.rest.uri=http://localhost:9000"
+ ]
+ )
+ inner class AppConfigurationRestTest(private val context: ApplicationContext) {
+
+ @Test
+ fun shouldUseRestMtbFileSenderNotKafkaMtbFileSender() {
+ assertThat(context.getBean(RestMtbFileSender::class.java)).isNotNull
+ assertThrows { context.getBean(KafkaMtbFileSender::class.java) }
+ }
+
+ }
+
+ @Nested
+ @TestPropertySource(
+ properties = [
+ "app.kafka.servers=localhost:9092",
+ "app.kafka.topic=test",
+ "app.kafka.response-topic=test-response",
+ "app.kafka.group-id=test"
+ ]
+ )
+ @MockBeans(value = [
+ MockBean(ObjectMapper::class),
+ MockBean(RequestRepository::class)
+ ])
+ inner class AppConfigurationKafkaTest(private val context: ApplicationContext) {
+
+ @Test
+ fun shouldUseKafkaMtbFileSenderNotRestMtbFileSender() {
+ assertThrows { context.getBean(RestMtbFileSender::class.java) }
+ assertThat(context.getBean(KafkaMtbFileSender::class.java)).isNotNull
+ }
+
+ }
+
+ @Nested
+ @TestPropertySource(
+ properties = [
+ "app.rest.uri=http://localhost:9000",
+ "app.kafka.servers=localhost:9092",
+ "app.kafka.topic=test",
+ "app.kafka.response-topic=test-response",
+ "app.kafka.group-id=test"
+ ]
+ )
+ inner class AppConfigurationRestInPrecedenceTest(private val context: ApplicationContext) {
+
+ @Test
+ fun shouldUseRestMtbFileSenderNotKafkaMtbFileSender() {
+ assertThat(context.getBean(RestMtbFileSender::class.java)).isNotNull
+ assertThrows { context.getBean(KafkaMtbFileSender::class.java) }
+ }
+
+ }
+
+}
\ No newline at end of file
--
cgit v1.2.3
From 47830ed9f7774c84674e9399cd347d12424f4f42 Mon Sep 17 00:00:00 2001
From: Paul-Christian Volkmer
Date: Wed, 9 Aug 2023 10:34:23 +0200
Subject: Use single MtbFileSender
---
.../kotlin/dev/dnpm/etl/processor/EtlProcessorApplicationTests.kt | 5 ++++-
.../dev/dnpm/etl/processor/services/RequestServiceIntegrationTest.kt | 3 +++
2 files changed, 7 insertions(+), 1 deletion(-)
(limited to 'src/integrationTest')
diff --git a/src/integrationTest/kotlin/dev/dnpm/etl/processor/EtlProcessorApplicationTests.kt b/src/integrationTest/kotlin/dev/dnpm/etl/processor/EtlProcessorApplicationTests.kt
index 07a201b..6c5b150 100644
--- a/src/integrationTest/kotlin/dev/dnpm/etl/processor/EtlProcessorApplicationTests.kt
+++ b/src/integrationTest/kotlin/dev/dnpm/etl/processor/EtlProcessorApplicationTests.kt
@@ -19,19 +19,22 @@
package dev.dnpm.etl.processor
+import dev.dnpm.etl.processor.output.MtbFileSender
import org.junit.jupiter.api.Test
import org.junit.jupiter.api.extension.ExtendWith
import org.springframework.boot.test.context.SpringBootTest
+import org.springframework.boot.test.mock.mockito.MockBean
import org.springframework.test.context.junit.jupiter.SpringExtension
import org.testcontainers.junit.jupiter.Testcontainers
@Testcontainers
@ExtendWith(SpringExtension::class)
@SpringBootTest
+@MockBean(MtbFileSender::class)
class EtlProcessorApplicationTests : AbstractTestcontainerTest() {
@Test
- fun contextLoads() {
+ fun contextLoadsIfMtbFileSenderConfigured() {
}
}
diff --git a/src/integrationTest/kotlin/dev/dnpm/etl/processor/services/RequestServiceIntegrationTest.kt b/src/integrationTest/kotlin/dev/dnpm/etl/processor/services/RequestServiceIntegrationTest.kt
index d71e011..3af218e 100644
--- a/src/integrationTest/kotlin/dev/dnpm/etl/processor/services/RequestServiceIntegrationTest.kt
+++ b/src/integrationTest/kotlin/dev/dnpm/etl/processor/services/RequestServiceIntegrationTest.kt
@@ -24,12 +24,14 @@ import dev.dnpm.etl.processor.monitoring.Request
import dev.dnpm.etl.processor.monitoring.RequestRepository
import dev.dnpm.etl.processor.monitoring.RequestStatus
import dev.dnpm.etl.processor.monitoring.RequestType
+import dev.dnpm.etl.processor.output.MtbFileSender
import org.assertj.core.api.Assertions.assertThat
import org.junit.jupiter.api.BeforeEach
import org.junit.jupiter.api.Test
import org.junit.jupiter.api.extension.ExtendWith
import org.springframework.beans.factory.annotation.Autowired
import org.springframework.boot.test.context.SpringBootTest
+import org.springframework.boot.test.mock.mockito.MockBean
import org.springframework.test.context.junit.jupiter.SpringExtension
import org.springframework.transaction.annotation.Transactional
import org.testcontainers.junit.jupiter.Testcontainers
@@ -40,6 +42,7 @@ import java.util.*
@ExtendWith(SpringExtension::class)
@SpringBootTest
@Transactional
+@MockBean(MtbFileSender::class)
class RequestServiceIntegrationTest : AbstractTestcontainerTest() {
private lateinit var requestRepository: RequestRepository
--
cgit v1.2.3
From 6ecb439007b4fa6dec9af1e0334b89fd235a97be Mon Sep 17 00:00:00 2001
From: Paul-Christian Volkmer
Date: Fri, 11 Aug 2023 09:22:54 +0200
Subject: Issue #3: Detect the request type of request with last known status
(#5)
---
.../dev/dnpm/etl/processor/services/RequestServiceIntegrationTest.kt | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
(limited to 'src/integrationTest')
diff --git a/src/integrationTest/kotlin/dev/dnpm/etl/processor/services/RequestServiceIntegrationTest.kt b/src/integrationTest/kotlin/dev/dnpm/etl/processor/services/RequestServiceIntegrationTest.kt
index 3af218e..ff85296 100644
--- a/src/integrationTest/kotlin/dev/dnpm/etl/processor/services/RequestServiceIntegrationTest.kt
+++ b/src/integrationTest/kotlin/dev/dnpm/etl/processor/services/RequestServiceIntegrationTest.kt
@@ -116,7 +116,7 @@ class RequestServiceIntegrationTest : AbstractTestcontainerTest() {
fun shouldReturnDeleteRequestAsLastRequest() {
setupTestData()
- val actual = requestService.isLastRequestDeletion("TEST_12345678901")
+ val actual = requestService.isLastRequestWithKnownStatusDeletion("TEST_12345678901")
assertThat(actual).isTrue()
}
--
cgit v1.2.3
From 72295202ec37a76b90a919e39ae094bb7e56d202 Mon Sep 17 00:00:00 2001
From: Paul-Christian Volkmer
Date: Sat, 12 Aug 2023 22:19:29 +0200
Subject: Code cleanup
---
.../kotlin/dev/dnpm/etl/processor/EtlProcessorApplicationTests.kt | 7 ++++++-
1 file changed, 6 insertions(+), 1 deletion(-)
(limited to 'src/integrationTest')
diff --git a/src/integrationTest/kotlin/dev/dnpm/etl/processor/EtlProcessorApplicationTests.kt b/src/integrationTest/kotlin/dev/dnpm/etl/processor/EtlProcessorApplicationTests.kt
index 6c5b150..c5a20bb 100644
--- a/src/integrationTest/kotlin/dev/dnpm/etl/processor/EtlProcessorApplicationTests.kt
+++ b/src/integrationTest/kotlin/dev/dnpm/etl/processor/EtlProcessorApplicationTests.kt
@@ -20,10 +20,13 @@
package dev.dnpm.etl.processor
import dev.dnpm.etl.processor.output.MtbFileSender
+import org.assertj.core.api.Assertions.assertThat
import org.junit.jupiter.api.Test
import org.junit.jupiter.api.extension.ExtendWith
+import org.springframework.beans.factory.annotation.Autowired
import org.springframework.boot.test.context.SpringBootTest
import org.springframework.boot.test.mock.mockito.MockBean
+import org.springframework.context.ApplicationContext
import org.springframework.test.context.junit.jupiter.SpringExtension
import org.testcontainers.junit.jupiter.Testcontainers
@@ -34,7 +37,9 @@ import org.testcontainers.junit.jupiter.Testcontainers
class EtlProcessorApplicationTests : AbstractTestcontainerTest() {
@Test
- fun contextLoadsIfMtbFileSenderConfigured() {
+ fun contextLoadsIfMtbFileSenderConfigured(@Autowired context: ApplicationContext) {
+ // Simply check bean configuration
+ assertThat(context).isNotNull
}
}
--
cgit v1.2.3