Skip to content

Feat/31 integration test #44

New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Merged
merged 13 commits into from
Jul 20, 2023
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
10 changes: 9 additions & 1 deletion .devcontainer/devcontainer.json
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,13 @@
"gradleVersion": "latest",
"mavenVersion": "latest",
"antVersion": "latest"
},
"ghcr.io/devcontainers/features/docker-in-docker:2": {
"moby": true,
"azureDnsAutoDetection": true,
"installDockerBuildx": true,
"version": "20.10",
"dockerDashComposeVersion": "v1"
}
},

Expand All @@ -31,7 +38,8 @@
"extensions": [
"mathiasfrohlich.Kotlin",
"GitHub.copilot",
"vscjava.vscode-gradle"
"vscjava.vscode-gradle",
"ritwickdey.LiveServer"
]
}
}
Expand Down
18 changes: 18 additions & 0 deletions .github/workflows/gradle-build-test-lint.yml
Original file line number Diff line number Diff line change
Expand Up @@ -50,6 +50,24 @@ jobs:
if: always()
with:
arguments: test -x jacocoTestReport

integrationTest:
runs-on: ubuntu-latest
needs: set-up
if: always()
steps:
- uses: actions/checkout@v3
- name: Set up JDK 17
uses: actions/setup-java@v3
with:
java-version: '17'
distribution: 'temurin'

- name: integrationTest
uses: gradle/gradle-build-action@749f47bda3e44aa060e82d7b3ef7e40d953bd629
if: always()
with:
arguments: integrationTest

coverage:
runs-on: ubuntu-latest
Expand Down
32 changes: 30 additions & 2 deletions build.gradle.kts
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,31 @@ repositories {
mavenCentral()
}

sourceSets {
create("integrationTest") {
compileClasspath += sourceSets.main.get().output
runtimeClasspath += sourceSets.main.get().output
}
}

val integrationTestImplementation by configurations.getting {
extendsFrom(configurations.implementation.get())
}

configurations["integrationTestRuntimeOnly"].extendsFrom(configurations.runtimeOnly.get())
configurations["integrationTestImplementation"].extendsFrom(configurations.testImplementation.get())

val integrationTest = task<Test>("integrationTest") {
description = "Runs integration tests."
group = "verification"

testClassesDirs = sourceSets["integrationTest"].output.classesDirs
classpath = sourceSets["integrationTest"].runtimeClasspath
shouldRunAfter("test")
}

tasks.check { dependsOn(integrationTest) }

dependencies {
implementation("org.springframework.boot:spring-boot-starter-data-jpa")
implementation("org.springframework.boot:spring-boot-starter-web")
Expand All @@ -32,8 +57,11 @@ dependencies {
developmentOnly("org.springframework.boot:spring-boot-devtools")
runtimeOnly("com.mysql:mysql-connector-j")
testImplementation("org.springframework.boot:spring-boot-starter-test")
testImplementation("com.h2database:h2")
implementation("org.modelmapper:modelmapper:2.4.2")
integrationTestImplementation("org.springframework.boot:spring-boot-testcontainers")
integrationTestImplementation("org.testcontainers:junit-jupiter")
integrationTestImplementation("org.testcontainers:mysql")
implementation("com.ninja-squad:springmockk:4.0.2")
}

tasks.withType<KotlinCompile> {
Expand Down Expand Up @@ -92,7 +120,7 @@ tasks.jacocoTestReport {

tasks.jacocoTestCoverageVerification {

var Qdomains = mutableListOf<String>()
val Qdomains = mutableListOf<String>()

for (qPattern in 'A'..'Z') {
Qdomains.add("*.Q$qPattern*")
Expand Down
45 changes: 45 additions & 0 deletions docker-compose.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,45 @@
version: "3"

services:
db:
container_name: mysqldb
image: mysql:8.0.33
restart: "no"
environment:
MYSQL_ROOT_PASSWORD: test
ports:
- 3306:3306
volumes:
- ./src/intTest/resources/db/mysql/conf.d:/etc/mysql/conf.d
- ./src/intTest/resources/db/mysql/initdb.d:/docker-entrypoint-initdb.d
healthcheck:
test: ['CMD-SHELL', 'mysqladmin ping -h 127.0.0.1 -u root --password=$$MYSQL_ROOT_PASSWORD']
interval: 10s
timeout: 2s
retries: 100

networks:
- spring-network

api:
container_name: api
build:
context: .
dockerfile: Dockerfile
restart: "no"
ports:
- 8080:8080
environment:
MYSQL_HOST: mysqldb
MYSQL_PORT: 3306
MYSQL_USERNAME: root
MYSQL_PASSWORD: test
MYSQL_SCHEMA: test
depends_on:
db:
condition: service_healthy
networks:
- spring-network

networks:
spring-network:
2 changes: 1 addition & 1 deletion gradlew
Original file line number Diff line number Diff line change
Expand Up @@ -242,4 +242,4 @@ eval "set -- $(
tr '\n' ' '
)" '"$@"'

exec "$JAVACMD" "$@"
exec "$JAVACMD" "$@"
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
package com.group4.ticketingservice

import org.springframework.boot.test.context.SpringBootTest
import org.springframework.test.context.DynamicPropertyRegistry
import org.springframework.test.context.DynamicPropertySource
import org.testcontainers.containers.MySQLContainer
import org.testcontainers.junit.jupiter.Container
import org.testcontainers.junit.jupiter.Testcontainers

@SpringBootTest
@Testcontainers
abstract class AbstractIntegrationTest {

companion object {
@Container
val mysqlContainer = MySQLContainer("mysql:8.0.33")
.withConfigurationOverride("./db/mysql/conf.d")

@JvmStatic
@DynamicPropertySource
fun datasourceConfig(registry: DynamicPropertyRegistry) {
registry.add("spring.datasource.url", mysqlContainer::getJdbcUrl)
registry.add("spring.datasource.username", mysqlContainer::getUsername)
registry.add("spring.datasource.password", mysqlContainer::getPassword)
}
}
}
Original file line number Diff line number Diff line change
@@ -1,18 +1,16 @@
package com.group4.ticketingservice.bookmark
package com.group4.ticketingservice

import com.group4.ticketingservice.entity.Bookmark
import com.group4.ticketingservice.repository.BookmarkRepository
import org.assertj.core.api.Assertions.assertThat
import org.junit.jupiter.api.Assertions.assertInstanceOf
import org.junit.jupiter.api.Test
import org.springframework.beans.factory.annotation.Autowired
import org.springframework.boot.test.autoconfigure.orm.jpa.DataJpaTest
import org.springframework.data.repository.findByIdOrNull

@DataJpaTest
class BookmarkRepositoryTest(
@Autowired val bookmarkRepository: BookmarkRepository
) {
) : AbstractIntegrationTest() {

@Test
fun `bookmarkRepository_save should return savedBookmark`() {
Expand Down Expand Up @@ -43,7 +41,7 @@ class BookmarkRepositoryTest(
val foundBookmark = bookmarkRepository.findByIdOrNull(savedBookmark.id?.toLong())

// then
assertThat(foundBookmark).isEqualTo(savedBookmark)
assert(savedBookmark.id == foundBookmark?.id)
}

@Test
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
package com.group4.ticketingservice

import org.junit.jupiter.api.Test
import org.springframework.beans.factory.annotation.Autowired
import org.springframework.boot.test.autoconfigure.web.servlet.AutoConfigureMockMvc
import org.springframework.test.web.servlet.MockMvc
import org.springframework.test.web.servlet.request.MockMvcRequestBuilders
import org.springframework.test.web.servlet.result.MockMvcResultMatchers.status

@AutoConfigureMockMvc
class TestControllerTest : AbstractIntegrationTest() {
@Autowired private lateinit var mockMvc: MockMvc

@Test
fun contextLoads() {
}

@Test
fun `E2E test`() {
mockMvc.perform(MockMvcRequestBuilders.get("/bookmarks"))
.andExpect(status().isOk)
}
}
1 change: 1 addition & 0 deletions src/integrationTest/resources/application.properties
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
spring.jpa.hibernate.ddl-auto=create
10 changes: 10 additions & 0 deletions src/integrationTest/resources/db/mysql/conf.d/my.cnf
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
[client]
default-character-set = utf8mb4

[mysql]
default-character-set = utf8mb4

[mysqld]
character-set-client-handshake = FALSE
character-set-server = utf8mb4
collation-server = utf8mb4_unicode_ci
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
-- use ddl-auto

This file was deleted.

1 change: 0 additions & 1 deletion src/main/resources/application.properties

This file was deleted.

This file was deleted.

Empty file.