| . | . | 
|---|---|
| GitHub Actions | |
| Travis | |
| Coveralls | |
| Codecov | 
Note that both a Gradle (build.gradle) and a Gradle Kotlin DSL (build.gradle.kts) build file are present.
This project aims to provide an example of the use of the Gradle Kotlin DSL with some testing frameworks and libraries, since the official documentation is at the moment of writing very minimal.
There are both a Groovy Gradle (build.gradle, not updated recently) and a Kotlin Script Gradle (build.gradle.kts updated recently) build file present which do roughly the same, which may make translation a bit easier.
For other translation examples, see below.
This is the Kotlin equivalent of this (older) java template project.
It makes use of
- Kotlin
- Kotlin Script Gradle or Gradle Kotlin DSL
- A normal, Groovy Gradle build file is also present
- JaCoCo for generating test reports
- Codecov.io which takes the JaCoCo report and shows some statistics
- Coveralls.io coverage reports uploaded by the coveralls-jacoco plugin (https://github.com/nbaztec/coveralls-jacoco-gradle-plugin)
There are tests using
- kotlintest (will be run by Gradle since kotlintest 3)
- JUnit 5
- Spek 2
Decide whether you want to use Groovy Gradle (older and widely used) or the Gradle Kotlin DSL (newer and starting to be used more and more).
- Copy the build.gradle.ktsandsettings.gradle.kts(Gradle Kotlin DSL, as you can see from the.ktsextension) or thebuild.gradle(Groovy Gradle, it this repo it may be namedbuild.gradle.inactivebut just rename it tobuild.gradle)
- Read through the file you just copied and change the relevant names, remove things of which you are sure you don't need them
- Copy the gradlew,gradlew.batandgradle/files and folder.
- Go to File | New | Module from Existing Sources and select your build.gradlefile. Make sure 'Use gradle wrapper' is selected. Select a different Gradle JVM if prompted.
- You should commit all the files you added, but not the generated files in .gradle/.
- You can run Gradle tasks from the Gradle window on the right, for example buildto build your project,runto run the main class if you have one orcheckto run tests.
- It is recommended that you use a continuous integration service like Travis, which will build and run tests on their server when you push a commit. Install the Travis GitHub App by going to the GitHub marketplace, and after that copy the .travis.yml, possibly remove parts you don't need.
This was only tested with IntelliJ.
- 
You can quickly import the project into IntelliJ by importing the build.gradle.ktsfile. Select the Gradle wrapper if needed.
- 
To run Gradle tasks, e.g. to run all tests (the verification/check task) or to start the main class (application/run) open the Gradle toolbar on the right and double-click (or right-click and debug) the task. 
- 
Alternatively, without IntelliJ, you can run gradlew teston the terminal to run the tests via gradle with the gradle wrapper (so you don't have to first install gradle locally by hand).
- 
If you see all gradle keywords greyed out you may want to link the Gradle project in IntelliJ, if you do not see a popup asking you to do so then go to modules - import module and select your build.gradle.kts.
Feel free to use GitHub emojis as for example by François Parmentier.
Groovy Gradle:
// This is a configuration for the shadowJar task.
shadowJar{
  classifier = 'deploy'
}
Kotlin Script Gradle:
import com.github.jengelman.gradle.plugins.shadow.tasks.ShadowJar
tasks {
    // This is a configuration for the shadowJar task.
    "shadowJar"(ShadowJar::class) {
        classifier = "deploy"
    }
}
Run kotlintest and JUnit 5 tests with Gradle
Upload test reports of Kotlin sources to Coveralls
The DefaultSourceDirectorySet constructor has been deprecated. How to use the ObjectFactory service?