add service, service-container, service-process-resource, and test-integration
This commit is contained in:
@@ -0,0 +1,66 @@
|
||||
import com.bmuschko.gradle.docker.tasks.container.DockerCreateContainer
|
||||
import com.bmuschko.gradle.docker.tasks.container.DockerStartContainer
|
||||
import com.bmuschko.gradle.docker.tasks.container.DockerStopContainer
|
||||
import com.bmuschko.gradle.docker.tasks.network.DockerCreateNetwork
|
||||
import com.bmuschko.gradle.docker.tasks.network.DockerInspectNetwork
|
||||
import com.bmuschko.gradle.docker.tasks.network.DockerRemoveNetwork
|
||||
|
||||
plugins {
|
||||
id("com.bmuschko.docker-spring-boot-application")
|
||||
id("ltd.lulz.plugin.core-plugin")
|
||||
}
|
||||
|
||||
fun configurationPorts(
|
||||
property: String,
|
||||
environment: String,
|
||||
): List<String> = config.findOrDefault(property, environment, "8080").split(',')
|
||||
|
||||
fun exposeDockerPorts(): List<Int> = configurationPorts("docker.port.expose", "DOCKER_PORT_EXPOSE")
|
||||
.mapNotNull { it.toIntOrNull() }
|
||||
|
||||
fun exposeContainerPorts(): List<String> = configurationPorts("container.port.host", "CONTAINER_PORT_HOST")
|
||||
.zip(configurationPorts("container.port.expose", "CONTAINER_PORT_EXPOSE"))
|
||||
.map { (containerPort, exposedPort) -> "$containerPort:$exposedPort" }
|
||||
|
||||
docker.springBootApplication {
|
||||
baseImage.set("eclipse-temurin:17-jre-alpine")
|
||||
ports.set(exposeDockerPorts())
|
||||
images.set(listOf("${project.name}:${project.version}"))
|
||||
}
|
||||
|
||||
tasks {
|
||||
register("containerCreate", DockerCreateContainer::class) {
|
||||
group = "container"
|
||||
targetImageId("${project.name}:${project.version}")
|
||||
containerName.set(project.name)
|
||||
hostConfig.autoRemove.set(true)
|
||||
hostConfig.network.set(config.findOrDefault("container.network", "CONTAINER_NETWORK", "develop"))
|
||||
hostConfig.portBindings.set(exposeContainerPorts())
|
||||
withEnvVar(
|
||||
"SPRING_PROFILES_ACTIVE",
|
||||
config.findOrDefault("container.profiles", "CONTAINER_PROFILES", "docker"),
|
||||
)
|
||||
}
|
||||
register("containerStart", DockerStartContainer::class) {
|
||||
group = "container"
|
||||
dependsOn(findByPath("containerCreate"))
|
||||
targetContainerId(project.name)
|
||||
}
|
||||
register("containerStop", DockerStopContainer::class) {
|
||||
group = "container"
|
||||
targetContainerId(project.name)
|
||||
}
|
||||
register("containerNetworkCheck", DockerInspectNetwork::class) {
|
||||
group = "container"
|
||||
targetNetworkId(config.findOrDefault("container.network", "CONTAINER_NETWORK", "develop"))
|
||||
onError { println("Network does not exist.") }
|
||||
}
|
||||
register("containerNetworkCreate", DockerCreateNetwork::class) {
|
||||
group = "container"
|
||||
networkName.set(config.findOrDefault("container.network", "CONTAINER_NETWORK", "develop"))
|
||||
}
|
||||
register("containerNetworkRemove", DockerRemoveNetwork::class) {
|
||||
group = "container"
|
||||
targetNetworkId(config.findOrDefault("container.network", "CONTAINER_NETWORK", "develop"))
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,27 @@
|
||||
import org.gradle.kotlin.dsl.support.uppercaseFirstChar
|
||||
|
||||
plugins {
|
||||
id("ltd.lulz.plugin.core-plugin")
|
||||
}
|
||||
|
||||
tasks {
|
||||
withType<ProcessResources> {
|
||||
val projectName = project.name
|
||||
val projectVersion = project.version
|
||||
filesMatching("**/application.yml") {
|
||||
filter {
|
||||
it.replace(
|
||||
"%APP_NAME%",
|
||||
projectName.split("-").joinToString(" ") { word -> word.uppercaseFirstChar() },
|
||||
)
|
||||
}
|
||||
filter { it.replace("%APP_VERSION%", projectVersion as String) }
|
||||
filter { it.replace("%APP_BUILD_TIME%", info.utcTimestamp) }
|
||||
filter { it.replace("%APP_BUILD_OS_NAME%", System.getProperty("os.name")) }
|
||||
filter { it.replace("%APP_BUILD_OS_VERSION%", System.getProperty("os.version")) }
|
||||
filter { it.replace("%APP_BUILD_GIT_COMMIT%", git.currentShortHash()) }
|
||||
filter { it.replace("%APP_BUILD_GIT_BRANCH%", git.currentBranch()) }
|
||||
}
|
||||
onlyIf { file("src/main/resources/application.yml").exists() }
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,38 @@
|
||||
plugins {
|
||||
id("idea")
|
||||
|
||||
kotlin("jvm")
|
||||
}
|
||||
|
||||
@Suppress("unused")
|
||||
fun DependencyHandler.testIntegrationImplementation(
|
||||
dependencyNotation: Any,
|
||||
): Dependency? = add("testIntegrationImplementation", dependencyNotation)
|
||||
|
||||
@Suppress("unused")
|
||||
fun DependencyHandler.testIntegrationRuntimeOnly(
|
||||
dependencyNotation: Any,
|
||||
): Dependency? = add("testIntegrationRuntimeOnly", dependencyNotation)
|
||||
|
||||
sourceSets.create("test-integration") {
|
||||
compileClasspath += sourceSets["main"].output
|
||||
runtimeClasspath += sourceSets["main"].output
|
||||
idea.module {
|
||||
testSources.from(sourceSets["test-integration"].kotlin.srcDirs, sourceSets["test-integration"].java.srcDirs)
|
||||
testResources.from(sourceSets["test-integration"].resources.srcDirs)
|
||||
}
|
||||
configurations.let {
|
||||
it["testIntegrationImplementation"].extendsFrom(configurations.implementation.get())
|
||||
it["testIntegrationRuntimeOnly"].extendsFrom(configurations.runtimeOnly.get())
|
||||
}
|
||||
}
|
||||
|
||||
tasks {
|
||||
register<Test>("testIntegration") {
|
||||
description = "Runs test integration."
|
||||
group = "verification"
|
||||
testClassesDirs = sourceSets["test-integration"].output.classesDirs
|
||||
classpath = sourceSets["test-integration"].runtimeClasspath
|
||||
}
|
||||
check { dependsOn(getByName("testIntegration")) }
|
||||
}
|
||||
@@ -0,0 +1,6 @@
|
||||
plugins {
|
||||
id("ltd.lulz.plugin.common-plugin.common")
|
||||
id("ltd.lulz.plugin.common-plugin.service-container")
|
||||
id("ltd.lulz.plugin.common-plugin.service-process-resource")
|
||||
id("ltd.lulz.plugin.common-plugin.service-test-integration")
|
||||
}
|
||||
Reference in New Issue
Block a user