Skip to content

Commit

Permalink
Create checklister-web module.
Browse files Browse the repository at this point in the history
  • Loading branch information
cstroe committed Feb 28, 2019
1 parent a3de1d5 commit a41fcde
Show file tree
Hide file tree
Showing 49 changed files with 142 additions and 152 deletions.
145 changes: 0 additions & 145 deletions build.gradle.kts
Original file line number Diff line number Diff line change
@@ -1,146 +1 @@
import org.jetbrains.kotlin.gradle.tasks.KotlinCompile
import org.springframework.boot.gradle.tasks.bundling.BootJar
import io.swagger.v3.plugins.gradle.tasks.ResolveTask.Format.JSON

plugins {
id("java")
id("com.gradle.build-scan") version "2.0.2"
id("org.springframework.boot") version "2.1.1.RELEASE"
kotlin("jvm") version "1.3.11"
// https://kotlinlang.org/docs/reference/compiler-plugins.html#spring-support
id("org.jetbrains.kotlin.plugin.spring") version "1.3.11"
// https://kotlinlang.org/docs/reference/compiler-plugins.html#jpa-support
id("org.jetbrains.kotlin.plugin.jpa") version "1.3.11"
// https://github.com/swagger-api/swagger-core/tree/master/modules/swagger-gradle-plugin
id("io.swagger.core.v3.swagger-gradle-plugin") version "2.0.6"
}

repositories {
mavenCentral()
}

group = "cloud.cosmin.checklister"

val compileKotlin: KotlinCompile by tasks

compileKotlin.kotlinOptions {
jvmTarget = "1.8"
}

val compileTestKotlin: KotlinCompile by tasks

compileTestKotlin.kotlinOptions {
jvmTarget = "1.8"
}

// unchanging name for boot JAR (referenced in Dockerfile)
val bootJar: BootJar by tasks
bootJar.archiveName = "app.jar"

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

tasks.test {
useJUnitPlatform()
}

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

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

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

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

tasks.resolve {
outputFileName = "PetStoreAPI"
outputFormat = JSON
prettyPrint = true
classpath = sourceSets["main"].runtimeClasspath
resourcePackages = setOf("io.test")
outputPath = "test"
}

val generateBuildConfigResourceTask by tasks.registering {
File("src/main/resources/checklister-build.properties")
.printWriter().use { out ->
out.println("version=${project.version.toString()}")
}
}

val compileKotlinTask = tasks.named("compileKotlin").get()
compileKotlinTask.dependsOn(generateBuildConfigResourceTask)

dependencies {
// Kotlin
implementation(kotlin("stdlib-jdk8"))

// Spring Boot
implementation(enforcedPlatform("org.springframework.boot:spring-boot-dependencies:2.1.1.RELEASE"))

// web
implementation("org.springframework.boot:spring-boot-starter-web")

// Swagger
implementation("io.springfox:springfox-swagger2:2.9.2")
implementation("io.springfox:springfox-swagger-ui:2.9.2")

// database
implementation("org.springframework.boot:spring-boot-starter-data-jpa")
implementation("org.hibernate:hibernate-java8")
runtime("org.postgresql:postgresql:42.2.2")
implementation("org.flywaydb:flyway-core:5.0.7")

implementation("org.bitbucket.cowwoc:requirements-core:4.0.4-RC")

// Jackson
implementation("com.fasterxml.jackson.core:jackson-databind:2.9.7")
implementation("com.fasterxml.jackson.dataformat:jackson-dataformat-yaml:2.9.7")
implementation("com.fasterxml.jackson.module:jackson-module-kotlin:2.9.7")

// because of Java 9+
// https://stackoverflow.com/questions/43574426/how-to-resolve-java-lang-noclassdeffounderror-javax-xml-bind-jaxbexception-in-j#43574427
// https://blog.sourced-bvba.be/article/2017/12/17/java9-spring/
implementation("javax.xml.bind:jaxb-api:2.3.0")
implementation("com.sun.xml.bind:jaxb-impl:2.3.0")
implementation("org.glassfish.jaxb:jaxb-runtime:2.3.0")
implementation("javax.activation:activation:1.1.1")

// JSON Patch
implementation("com.github.fge:json-patch:1.9")

// dev tools
implementation("org.springframework.boot:spring-boot-devtools")

testImplementation("org.springframework.boot:spring-boot-starter-test")
testImplementation("org.springframework.boot:spring-boot-test-autoconfigure")

// JUnit 5
testImplementation("org.junit.jupiter:junit-jupiter-api:5.3.2")
testRuntimeOnly("org.junit.jupiter:junit-jupiter-engine:5.3.2")

// Support running JUnit 4 tests using JUnit 5
testImplementation("junit:junit:4.12")
testRuntimeOnly("org.junit.vintage:junit-vintage-engine:5.3.2")

// H2 in-memory database
testImplementation("com.h2database:h2:1.4.197")

// integrationTestCompile("org.seleniumhq.selenium:selenium-java:3.13.0")
// integrationTestCompile("org.seleniumhq.selenium:selenium-remote-driver:3.13.0")

implementation(project(":checklister-event"))
implementation(project(":checklister-eventsink-logger"))
implementation(project(":checklister-dto"))
}
2 changes: 1 addition & 1 deletion checklister-dto/build.gradle.kts
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
plugins {
`java-library`
kotlin("jvm")
kotlin("jvm") version "1.3.11"
}

repositories {
Expand Down
2 changes: 1 addition & 1 deletion checklister-event/build.gradle.kts
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
plugins {
`java-library`
kotlin("jvm")
kotlin("jvm") version "1.3.11"
}

repositories {
Expand Down
2 changes: 1 addition & 1 deletion checklister-eventsink-kafka/build.gradle.kts
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
plugins {
`java-library`
kotlin("jvm")
kotlin("jvm") version "1.3.11"
}

repositories {
Expand Down
2 changes: 1 addition & 1 deletion checklister-eventsink-logger/build.gradle.kts
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
plugins {
`java-library`
kotlin("jvm")
kotlin("jvm") version "1.3.11"
}

repositories {
Expand Down
135 changes: 135 additions & 0 deletions checklister-web/build.gradle.kts
Original file line number Diff line number Diff line change
@@ -0,0 +1,135 @@
import org.jetbrains.kotlin.gradle.tasks.KotlinCompile
import org.springframework.boot.gradle.tasks.bundling.BootJar
import io.swagger.v3.plugins.gradle.tasks.ResolveTask.Format.JSON

plugins {
id("java")
id("org.springframework.boot") version "2.1.1.RELEASE"
kotlin("jvm") version "1.3.11"
// https://kotlinlang.org/docs/reference/compiler-plugins.html#spring-support
id("org.jetbrains.kotlin.plugin.spring") version "1.3.11"
// https://kotlinlang.org/docs/reference/compiler-plugins.html#jpa-support
id("org.jetbrains.kotlin.plugin.jpa") version "1.3.11"
// https://github.com/swagger-api/swagger-core/tree/master/modules/swagger-gradle-plugin
id("io.swagger.core.v3.swagger-gradle-plugin") version "2.0.6"
}

repositories {
mavenCentral()
}

val compileKotlin: KotlinCompile by tasks

compileKotlin.kotlinOptions {
jvmTarget = "1.8"
}

val compileTestKotlin: KotlinCompile by tasks

compileTestKotlin.kotlinOptions {
jvmTarget = "1.8"
}

// unchanging name for boot JAR (referenced in Dockerfile)
val bootJar: BootJar by tasks
bootJar.archiveName = "app.jar"

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

tasks.test {
useJUnitPlatform()
}


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

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

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

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

val generateBuildConfigResourceTask by tasks.registering {
File("checklister-web/src/main/resources/checklister-build.properties")
.printWriter().use { out ->
out.println("version=${project.version.toString()}")
}
}

val compileKotlinTask = tasks.named("compileKotlin").get()
compileKotlinTask.dependsOn(generateBuildConfigResourceTask)

dependencies {
// Kotlin
implementation(kotlin("stdlib-jdk8"))

// Spring Boot
implementation(enforcedPlatform("org.springframework.boot:spring-boot-dependencies:2.1.1.RELEASE"))

// web
implementation("org.springframework.boot:spring-boot-starter-web")

// Swagger
implementation("io.springfox:springfox-swagger2:2.9.2")
implementation("io.springfox:springfox-swagger-ui:2.9.2")

// database
implementation("org.springframework.boot:spring-boot-starter-data-jpa")
implementation("org.hibernate:hibernate-java8")
runtime("org.postgresql:postgresql:42.2.2")
implementation("org.flywaydb:flyway-core:5.0.7")

implementation("org.bitbucket.cowwoc:requirements-core:4.0.4-RC")

// Jackson
implementation("com.fasterxml.jackson.core:jackson-databind:2.9.7")
implementation("com.fasterxml.jackson.dataformat:jackson-dataformat-yaml:2.9.7")
implementation("com.fasterxml.jackson.module:jackson-module-kotlin:2.9.7")

// because of Java 9+
// https://stackoverflow.com/questions/43574426/how-to-resolve-java-lang-noclassdeffounderror-javax-xml-bind-jaxbexception-in-j#43574427
// https://blog.sourced-bvba.be/article/2017/12/17/java9-spring/
implementation("javax.xml.bind:jaxb-api:2.3.0")
implementation("com.sun.xml.bind:jaxb-impl:2.3.0")
implementation("org.glassfish.jaxb:jaxb-runtime:2.3.0")
implementation("javax.activation:activation:1.1.1")

// JSON Patch
implementation("com.github.fge:json-patch:1.9")

// dev tools
implementation("org.springframework.boot:spring-boot-devtools")

testImplementation("org.springframework.boot:spring-boot-starter-test")
testImplementation("org.springframework.boot:spring-boot-test-autoconfigure")

// JUnit 5
testImplementation("org.junit.jupiter:junit-jupiter-api:5.3.2")
testRuntimeOnly("org.junit.jupiter:junit-jupiter-engine:5.3.2")

// Support running JUnit 4 tests using JUnit 5
testImplementation("junit:junit:4.12")
testRuntimeOnly("org.junit.vintage:junit-vintage-engine:5.3.2")

// H2 in-memory database
testImplementation("com.h2database:h2:1.4.197")

// integrationTestCompile("org.seleniumhq.selenium:selenium-java:3.13.0")
// integrationTestCompile("org.seleniumhq.selenium:selenium-remote-driver:3.13.0")

implementation(project(":checklister-event"))
implementation(project(":checklister-eventsink-logger"))
implementation(project(":checklister-dto"))
}
File renamed without changes.
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
version=0.0.9-SNAPSHOT
File renamed without changes.
3 changes: 2 additions & 1 deletion settings.gradle.kts
Original file line number Diff line number Diff line change
Expand Up @@ -2,4 +2,5 @@ rootProject.name = "checklister"
include("checklister-dto",
"checklister-event",
"checklister-eventsink-logger",
"checklister-eventsink-kafka")
"checklister-eventsink-kafka",
"checklister-web")
2 changes: 0 additions & 2 deletions src/docker-root/entrypoint.sh

This file was deleted.

0 comments on commit a41fcde

Please sign in to comment.