-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathbuild.gradle.kts
79 lines (66 loc) · 2.29 KB
/
build.gradle.kts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
buildscript {
repositories {
google()
mavenCentral()
}
}
plugins {
alias(libs.plugins.kotlin.multiplatform) apply false
alias(libs.plugins.android.library) apply false
alias(libs.plugins.kotlinter) apply false
alias(libs.plugins.android.publish) apply false
alias(libs.plugins.api)
alias(libs.plugins.dokka)
}
allprojects {
group = "com.juul.khronicle"
repositories {
google()
mavenCentral()
}
tasks.withType<Test>().configureEach {
testLogging {
events("started", "passed", "skipped", "failed", "standardOut", "standardError")
exceptionFormat = org.gradle.api.tasks.testing.logging.TestExceptionFormat.FULL
showExceptions = true
showStackTraces = true
showCauses = true
}
}
withPluginWhenEvaluated("jacoco") {
tasks.register<JacocoReport>("jacocoTestReport") {
group = "Verification"
description = "Generate JaCoCo test coverage report"
reports {
csv.required.set(false)
html.required.set(true)
xml.required.set(true)
}
classDirectories.setFrom(layout.buildDirectory.file("classes/atomicfu-orig/jvm/main"))
sourceDirectories.setFrom(layout.projectDirectory.files("src/commonMain", "src/jvmMain"))
executionData.setFrom(layout.buildDirectory.file("jacoco/jvmTest.exec"))
dependsOn("jvmTest")
}
configure<JacocoPluginExtension> {
toolVersion = libs.versions.jacoco.get()
}
}
}
tasks.dokkaHtmlMultiModule.configure {
outputDirectory.fileProvider(layout.buildDirectory.file("dokkaHtmlMultiModule").map { it.asFile })
}
apiValidation {
nonPublicMarkers.add("com.juul.khronicle.KhronicleInternal")
ignoredProjects += "khronicle-android-lint"
}
fun Project.withPluginWhenEvaluated(plugin: String, action: Project.() -> Unit) {
pluginManager.withPlugin(plugin) { whenEvaluated(action) }
}
// `afterEvaluate` does nothing when the project is already in executed state, so we need a special check for this case.
fun <T> Project.whenEvaluated(action: Project.() -> T) {
if (state.executed) {
action()
} else {
afterEvaluate { action() }
}
}