X-Git-Url: https://git.pterodactylus.net/?p=Sone.git;a=blobdiff_plain;f=build.gradle;h=db5af2b88a2a3c6cbdfacfa7d8fc5410a7499490;hp=453a26296171f6839b0ea3dfc97f734dff6310a8;hb=HEAD;hpb=0d0cf0126bce3fa60926dfdd8507548a677bb3f2 diff --git a/build.gradle b/build.gradle index 453a262..db5af2b 100644 --- a/build.gradle +++ b/build.gradle @@ -1,33 +1,33 @@ -group = 'net.pterodactylus' -version = '0.9.7' +import org.jetbrains.kotlin.gradle.tasks.KotlinCompile -buildscript { - ext.kotlinVersion = '1.1.51' - repositories { - mavenCentral() - } - dependencies { - classpath group: 'info.solidsoft.gradle.pitest', name: 'gradle-pitest-plugin', version: '1.1.11' - classpath group: 'org.jetbrains.kotlin', name: 'kotlin-gradle-plugin', version: kotlinVersion - classpath group: 'org.jetbrains.kotlin', name: 'kotlin-noarg', version: kotlinVersion - } +plugins { + id 'org.jetbrains.kotlin.jvm' version '1.3.70' + id 'org.jetbrains.kotlin.plugin.noarg' version '1.3.70' + id 'info.solidsoft.pitest' version '1.4.5' } +group = 'net.pterodactylus' +version = '82' + repositories { - maven { url "http://maven.pterodactylus.net/" } mavenCentral() + maven { url "https://maven.pterodactylus.net/" } } apply plugin: 'java' -sourceCompatibility = 1.7 -targetCompatibility = 1.7 +sourceCompatibility = 1.8 +targetCompatibility = 1.8 tasks.withType(JavaCompile) { options.encoding = 'UTF-8' } -apply plugin: 'kotlin' +tasks.withType(KotlinCompile) { + kotlinOptions { + jvmTarget = "1.8" + } +} configurations { provided { @@ -37,31 +37,55 @@ configurations { } compile.extendsFrom provided } - + dependencies { provided group: 'org.freenetproject', name: 'fred', version: '0.7.5.1475' provided group: 'org.freenetproject', name: 'freenet-ext', version: '29' provided group: 'org.bouncycastle', name: 'bcprov-jdk15on', version: '1.54' - compile group: 'org.jetbrains.kotlin', name: 'kotlin-stdlib' - compile group: 'net.pterodactylus', name: 'utils', version: '0.12.4' - compile group: 'com.google.inject', name: 'guice', version: '3.0' - compile group: 'com.google.guava', name: 'guava', version: '14.0.1' + compile group: 'org.jetbrains.kotlin', name: 'kotlin-stdlib-jdk8' + compile group: 'org.jetbrains.kotlinx', name: 'kotlinx-coroutines-core', version: '1.3.0-RC' + + compile group: 'net.pterodactylus', name: 'utils', version: '0.13.1' + compile group: 'com.google.inject', name: 'guice', version: '4.2.2' + compile group: 'com.google.guava', name: 'guava', version: '27.0.1-jre' compile group: 'com.fasterxml.jackson.core', name: 'jackson-databind', version: '2.9.1' compile group: 'com.fasterxml.jackson.dataformat', name: 'jackson-dataformat-yaml', version: '2.9.1' compile group: 'com.google.code.findbugs', name: 'jsr305', version: '3.0.2' compile group: 'org.jsoup', name: 'jsoup', version: '1.10.2' + compile group: 'io.dropwizard.metrics', name: 'metrics-core', version: '4.1.0' + compile group: 'javax.activation', name: 'javax.activation-api', version: '1.2.0' - testCompile group: 'org.jetbrains.kotlin', name: 'kotlin-test' + testCompile group: 'org.jetbrains.kotlin', name: 'kotlin-test-junit' testCompile group: 'junit', name: 'junit', version: '4.11' - testCompile group: 'org.mockito', name: 'mockito-core', version: '2.10.0' + testCompile group: 'org.mockito', name: 'mockito-core', version: '2.28.2' testCompile group: 'org.hamcrest', name: 'hamcrest-all', version: '1.3' } apply from: 'version.gradle' +task parallelTest(type: Test) { + maxParallelForks = Runtime.runtime.availableProcessors().intdiv(2) ?: 1 + useJUnit { + excludeCategories 'net.pterodactylus.sone.test.NotParallel' + } +} + +task notParallelTest(type: Test) { + maxParallelForks = 1 + useJUnit { + includeCategories 'net.pterodactylus.sone.test.NotParallel' + } + dependsOn parallelTest +} + +test { + exclude '**' + dependsOn parallelTest, notParallelTest +} + task fatJar(type: Jar) { - archiveName = project.name + '-jar-with-dependencies.jar' + archiveFileName = project.name.toLowerCase() + '-jar-with-dependencies.jar' from { (configurations.runtime - configurations.provided).collect { it.isDirectory() ? it : zipTree(it) } } manifest { attributes('Plugin-Main-Class': 'net.pterodactylus.sone.main.SonePlugin') @@ -82,14 +106,13 @@ javadoc { apply plugin: 'jacoco' jacoco { - toolVersion = '0.7.9' + toolVersion = '0.8.4' } jacocoTestReport.dependsOn test -apply plugin: 'info.solidsoft.pitest' - pitest { + pitestVersion = '1.4.10' outputFormats = ['HTML', 'XML'] timestampedReports = false timeoutFactor = 3.0 @@ -121,8 +144,6 @@ task countLines { dependsOn tasks.countLinesTest } -apply plugin: 'kotlin-noarg' - noArg { annotation('net.pterodactylus.sone.main.NoArg') }