From ccf4083862a4520784179bd43c23fea1d5abf9cc Mon Sep 17 00:00:00 2001 From: BAStos525 Date: Wed, 16 Oct 2024 16:33:56 +0300 Subject: [PATCH] use self-hosted & subprojects 9 Signed-off-by: BAStos525 --- build.gradle | 233 +++++++++++++++------------------------------------ 1 file changed, 67 insertions(+), 166 deletions(-) diff --git a/build.gradle b/build.gradle index e14c204e9..d5796ee77 100644 --- a/build.gradle +++ b/build.gradle @@ -33,7 +33,6 @@ subprojects { apply plugin: 'org.jmailen.kotlinter' apply plugin: 'com.github.johnrengelman.shadow' apply plugin: 'jacoco' - apply plugin: 'org.sonarqube' publishing { publications { @@ -57,6 +56,10 @@ subprojects { group = 'jp.co.soramitsu.iroha2-java' version = 'git rev-parse --short HEAD'.execute().text.trim() + test { + useJUnitPlatform() + } + java { toolchain { languageVersion = JavaLanguageVersion.of(8) @@ -97,184 +100,82 @@ subprojects { // it is disabled by default to publish original version by CI, not a fat jar tasks.shadowJar.enabled = false - task testCoverage(type: JacocoReport) { - // Ensure all necessary tasks are complete before running testCoverage - dependsOn "${project.path}:test" - dependsOn "${project.path}:processTestResources" - dependsOn "${project.path}:compileTestKotlin" +} - reports { - xml.required = true - html.required = true - } +task allShadowJars { + subprojects { pr -> allShadowJars.dependsOn("${pr.path}:shadowJar") } +} - def excludes = [ - '**/R.class', - '**/R$*.class', - '**/BuildConfig.*', - '**/Manifest*.*', - '**/*Test*.*', - 'android/**/*.*', - 'androidx/**/*.*', - '**/*$ViewInjector*.*', - '**/*Dagger*.*', - '**/*MembersInjector*.*', - '**/*_Factory.*', - '**/*_Provide*Factory*.*', - '**/*_ViewBinding*.*', - '**/AutoValue_*.*', - '**/R2.class', - '**/R2$*.class', - '**/*Directions$*', - '**/*Directions.*', - '**/*Binding.*' - ] - - executionData tasks.withType(Test) - executionData fileTree(project.rootDir.absolutePath).include("**/build/jacoco/*.exec") - sourceSets sourceSets.main - - // def kotlinClasses = fileTree(dir: "${project.projectDir}/build/classes", excludes: excludes) - - // classDirectories.from = files([kotlinClasses]) - // def sourceDirs = [ - // "${project.projectDir}/src/main/java", - // "${project.projectDir}/src/main/kotlin", - // "${project.projectDir}/src/debug/java", - // "${project.projectDir}/src/debug/kotlin" - // ] - // sourceDirectories.from = files(sourceDirs) - - // executionData.from = files( - // ["${project.buildDir}/jacoco/test.exec", "${project.buildDir}/jacoco/integrationTest.exec"] - // ) - } +check { + dependsOn "installKotlinterPrePushHook" +} - test { - useJUnitPlatform() - failFast = true - testLogging { - events "passed", "skipped", "failed" - } - reports { - junitXml.required = true - } - finalizedBy testCoverage +jacoco { + toolVersion = "0.8.8" + reportsDirectory = file("$buildDir/reports/") +} + +task testCoverage(type: JacocoReport) { + executionData fileTree(project.rootDir.absolutePath).include("**/build/jacoco/*.exec") + + subprojects.each { + sourceSets it.sourceSets.main } - // task testCoverage(type: JacocoReport) { - // // Ensure all necessary tasks are complete before running testCoverage - // dependsOn "${project.path}:test" - // dependsOn "${project.path}:processTestResources" - // dependsOn "${project.path}:compileTestKotlin" - - // executionData fileTree(project.rootDir.absolutePath).include("**/build/jacoco/*.exec") - - // sourceSets sourceSets.main - - // reports { - // xml.required = true - // html.required = true - // } - // } - - - sonar { - properties { - property "sonar.projectKey", "hyperledger:iroha-java" - property "sonar.host.url", "https://sonar.katana.soramitsu.co.jp" - property "sonar.projectName", "${project.group}:${rootProject.name}.${project.name}" - property "sonar.sources", "${project.projectDir}/src/main/java" - property "sonar.tests", "${project.projectDir}/src/test" - // property "sonar.java.binaries", "${project.projectDir}/build/classes" - // property "sonar.java.libraries", "${project.projectDir}/build/libs" - property "sonar.java.test.binaries", "${project.projectDir}/build/test-results/test/binary" - property "sonar.junit.reportPaths", "${project.projectDir}/build/test-results/test/" - property "sonar.coverage.jacoco.xmlReportPaths", "${project.projectDir}/build/reports/testCoverage/*.xml" - property "sonar.exclusions", "${project.projectDir}/**/*.txt" - } + reports { + xml.required = true + html.required = true } +} + + +test { + useJUnitPlatform() + dependsOn testCoverage +} - jacoco { - toolVersion = "0.8.8" - reportsDirectory = file("$buildDir/reports/") +sonar { + properties { + property "sonar.projectKey", "hyperledger:iroha-java" + property "sonar.host.url", "https://sonar.katana.soramitsu.co.jp" + property "sonar.java.coveragePlugin", "jacoco" + property "sonar.projectName", "${project.group}:${rootProject.name}.${project.name}" + property "sonar.sources", "${project.projectDir}/src/main/java" + property "sonar.tests", "${project.projectDir}/src/test" + property "sonar.java.test.binaries", "${project.projectDir}/build/test-results/test/binary" + property "sonar.junit.reportPaths", "${project.projectDir}/build/test-results/test/" + property "sonar.coverage.jacoco.xmlReportPaths", "${project.projectDir}/build/reports/testCoverage/*.xml" } +} +tasks.named('testCoverage') { + dependsOn ":admin-client:processTestResources" } -task allShadowJars { - subprojects { pr -> allShadowJars.dependsOn("${pr.path}:shadowJar") } +tasks.named('testCoverage') { + dependsOn ":block:compileTestKotlin" } -check { - dependsOn "installKotlinterPrePushHook" +tasks.named('testCoverage') { + dependsOn ":block:test" } -// jacoco { -// toolVersion = "0.8.8" -// reportsDirectory = file("$buildDir/reports/") -// } +tasks.named('testCoverage') { + dependsOn ":block:processTestResources" +} -// task testCoverage(type: JacocoReport) { -// executionData fileTree(project.rootDir.absolutePath).include("**/build/jacoco/*.exec") - -// subprojects.each { -// sourceSets it.sourceSets.main -// } - -// reports { -// xml.required = true -// html.required = true -// } -// } - -// test { -// useJUnitPlatform() -// finalizedBy testCoverage -// } - - - -// tasks.configureEach { -// tasks.named('testCoverage') { -// dependsOn ":$name:processTestResources" -// } -// tasks.named('testCoverage') { -// dependsOn ":$name:compileTestKotlin" -// } -// tasks.named('testCoverage') { -// dependsOn ":$name:test" -// } -// } - -// tasks.named('testCoverage') { -// dependsOn ":admin-client:processTestResources" -// } - -// tasks.named('testCoverage') { -// dependsOn ":block:compileTestKotlin" -// } - -// tasks.named('testCoverage') { -// dependsOn ":block:test" -// } - -// tasks.named('testCoverage') { -// dependsOn ":block:processTestResources" -// } - -// tasks.named('testCoverage') { -// dependsOn ":client:processTestResources" -// } - -// tasks.named('testCoverage') { -// dependsOn ":codegen:test" -// } - -// tasks.named('testCoverage') { -// dependsOn ":model:test" -// } - -// tasks.named('testCoverage') { -// dependsOn ":test-tools:processTestResources" -// } +tasks.named('testCoverage') { + dependsOn ":client:processTestResources" +} + +tasks.named('testCoverage') { + dependsOn ":codegen:test" +} + +tasks.named('testCoverage') { + dependsOn ":model:test" +} + +tasks.named('testCoverage') { + dependsOn ":test-tools:processTestResources" +}