/* * Hibernate, Relational Persistence for Idiomatic Java * * License: GNU Lesser General Public License (LGPL), version 2.1 or later * See the lgpl.txt file in the root directory or http://www.gnu.org/licenses/lgpl-2.1.html */ buildscript { repositories { mavenCentral() } dependencies { classpath 'de.thetaphi:forbiddenapis:2.6' } } import de.thetaphi.forbiddenapis.gradle.CheckForbiddenApis import org.apache.tools.ant.filters.ReplaceTokens /** * Support for modules that contain Java code */ apply from: rootProject.file( 'gradle/base-information.gradle' ) apply from: rootProject.file( 'gradle/libraries.gradle' ) apply from: rootProject.file( 'gradle/databases.gradle' ) apply plugin: 'java' apply plugin: 'osgi' apply plugin: 'checkstyle' apply plugin: 'build-dashboard' apply plugin: 'project-report' ext { java9ModuleNameBase = project.name.startsWith( 'hibernate-' ) ? name.drop( 'hibernate-'.length() ): name java9ModuleName = "org.hibernate.orm.$project.java9ModuleNameBase" forbiddenAPITargetJDKCompatibility = '11' } sourceCompatibility = project.baselineJavaVersion targetCompatibility = project.baselineJavaVersion afterEvaluate { if ( !project.description ) { project.description = "The Hibernate ORM $project.name module" } } // ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ // Configurations and Dependencies configurations { provided { description = 'Non-exported compile-time dependencies.' } asciidoclet { description = "Dependencies for Asciidoctor Javadoc taglet" } } configurations.all*.exclude group: 'xml-apis', module: 'xml-apis' dependencies { compile libraries.logging provided libraries.logging_annotations annotationProcessor( libraries.logging_processor ) annotationProcessor( libraries.logging ) annotationProcessor( libraries.logging_annotations ) testCompile( libraries.junit ) testCompile( libraries.byteman ) testCompile( libraries.byteman_install ) testCompile( libraries.byteman_bmunit ) testRuntime( libraries.log4j ) testRuntime( libraries.javassist ) testRuntime( libraries.byteBuddy ) testRuntime( libraries.woodstox ) //Databases testRuntime( libraries.h2 ) testRuntime( libraries.hsqldb ) testRuntime( libraries.postgresql ) testRuntime( libraries.mysql ) testRuntime( libraries.mariadb ) testRuntime( libraries.mssql ) testRuntime( libraries.informix ) testRuntime( libraries.hana ) asciidoclet 'org.asciidoctor:asciidoclet:1.+' if ( db.equalsIgnoreCase( 'oracle' ) ) { testRuntime( libraries.oracle ) { exclude group: 'com.oracle.jdbc', module: 'xmlparserv2' } } else if ( db.equalsIgnoreCase( 'db2' ) ) { testRuntime( libraries.db2 ) } else if ( db.equalsIgnoreCase( 'hana' ) ) { testRuntime( libraries.hana ) } // Mac-specific project.ext.toolsJar = file("${System.getProperty('java.home')}/../lib/tools.jar") if ( project.toolsJar.exists() ) { testCompile files( project.toolsJar ) } } // ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ // Compilation tasks.withType(JavaCompile) { options.encoding = 'UTF-8' } task compile(dependsOn: [compileJava, processResources, compileTestJava, processTestResources] ) sourceSets.main { compileClasspath += configurations.provided } convention.findPlugin( JavaPluginConvention.class ).sourceSets.each { sourceSet -> JavaCompile javaCompileTask = project.tasks.findByName( sourceSet.compileJavaTaskName ) as JavaCompile // NOTE : this aptDir stuff is needed until we can have IntelliJ run annotation processors for us // which cannot happen until we can fold hibernate-testing back into hibernate-core/src/test // which cannot happen until... ugh File aptDir = file( "${buildDir}/generated-src/apt/${sourceSet.name}" ) sourceSet.allJava.srcDir( aptDir ) javaCompileTask.options.compilerArgs += [ "-nowarn", "-encoding", "UTF-8", "-s", "${aptDir.absolutePath}" ] javaCompileTask.doFirst { aptDir.mkdirs() } } // ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ // mac-specific stuff final File toolsJar = file("${System.getProperty('java.home')}/../lib/tools.jar") if ( ext.toolsJar.exists() ) { dependencies{ testCompile files( toolsJar ) } } // ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ // Testing tasks.withType( Test.class ).all { task -> if ( JavaVersion.current().isJava9Compatible() ) { // Byteman needs this property to be set, https://developer.jboss.org/thread/274997 task.jvmArgs += ["-Djdk.attach.allowAttachSelf=true"] } task.jvmArgs += [ '-XX:+HeapDumpOnOutOfMemoryError', "-XX:HeapDumpPath=${file( "${buildDir}/OOM-dump.hprof" ).absolutePath}", '-XX:MetaspaceSize=512M' ] task.maxHeapSize = '4G' task.systemProperties['hibernate.test.validatefailureexpected'] = true task.systemProperties += System.properties.findAll { it.key.startsWith( "hibernate." ) } } processTestResources { inputs.property( "db", db ) doLast { copy { from( sourceSets.test.java.srcDirs ) { include '**/*.properties' include '**/*.xml' } into sourceSets.test.java.outputDir } copy { from file( 'src/test/resources' ) into file( "${buildDir}/resources/test" ) exclude 'src/test/resources/arquillian.xml' exclude 'src/test/resources/hibernate.properties' } copy { from file( 'src/test/resources/hibernate.properties' ) into file( "${buildDir}/resources/test" ) filter( ReplaceTokens, tokens: dbBundle[db] ) } } } // Enable the experimental features of ByteBuddy with JDK 12+ test { //Only safe to attempt to parse the version as an integer since JDK11 if ( JavaVersion.current().isJava11Compatible() ) { int majorJVMVersionInt = Integer.valueOf(JavaVersion.current().toString()); //Set the -Dnet.bytebuddy.experimental=true property only when we need it: if (majorJVMVersionInt >= 12) { systemProperty 'net.bytebuddy.experimental', true } } } // ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ // IDE //idea { // module { // jdkName = project.sourceCompatibility // // excludeDirs = [file( ".gradle" )] // excludeDirs += file( "$buildDir/classes" ) // excludeDirs += file( "$buildDir/bundles" ) // excludeDirs += file( "$buildDir/packages" ) // excludeDirs += file( "$buildDir/dependency-cache" ) // excludeDirs += file( "$buildDir/libs" ) // excludeDirs += file( "$buildDir/reports" ) // excludeDirs += file( "$buildDir/test-results" ) // excludeDirs += file( "$buildDir/tmp" ) // excludeDirs += file( "$buildDir/matrix" ) // excludeDirs += file( "$buildDir/resources" ) // // downloadSources = true // scopes.PROVIDED.plus += [configurations.provided] // } //} // /* The latest versions of IntelliJ copy and use the test resources into out/test/resources this occurs before the placeholder in the test config file are substituted with the testing values. This behaviour prevents the execution of the hibernate tests from inside the IDE. A solution is to enable the 'After Build' Execution of the copyResourcesToIntelliJOutFolder task from the 'Gradle project' IntelliJ tool window ( The task can be found under hibernate-orm > Task > other) */ task copyResourcesToIntelliJOutFolder { doLast { copy { from "$buildDir/resources/test" into 'out/test/resources' } } } // // // //eclipse { // jdt { // sourceCompatibility = project.sourceCompatibility // targetCompatibility = project.targetCompatibility // } // classpath { // plusConfigurations.add( configurations.provided ) // } //} // //// eclipseClasspath will not add sources to classpath unless the dirs actually exist. //// TODO: Eclipse's annotation processor handling is also fairly stupid (and completely lacks in the //// Gradle plugin). For now, just compile first in order to get the logging classes. //eclipseClasspath.dependsOn compile /* Use this task to set the current DB in a given module. > gradlew sDB -Pdb=mysql Afterward, you can run any test from the IDE against that particular DB. */ task setDataBase { inputs.property( "db", db ) doLast { processTestResources.execute() copyResourcesToIntelliJOutFolder.execute() println( 'Setting current database to ' + db ) } } // ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ // Report configs checkstyle { sourceSets = [ project.sourceSets.main ] configFile = rootProject.file( 'shared/config/checkstyle/checkstyle.xml' ) showViolations = false } // exclude generated java sources - by explicitly setting the base source dir checkstyleMain.source = 'src/main/java' // define a second checkstyle task for checking non-fatal violations task nonFatalCheckstyle(type:Checkstyle) { source = project.sourceSets.main.java classpath = project.configurations.checkstyle showViolations = false configFile = rootProject.file( 'shared/config/checkstyle/checkstyle-non-fatal.xml' ) } // because cfg package is a mess mainly from annotation stuff checkstyleMain.exclude '**/org/hibernate/cfg/**' checkstyleMain.exclude '**/org/hibernate/cfg/*' task forbiddenApisSystemOut(type: CheckForbiddenApis, dependsOn: compileJava) { classesDirs = project.sourceSets.main.output.classesDirs classpath = project.sourceSets.main.compileClasspath + project.sourceSets.main.runtimeClasspath targetCompatibility = project.forbiddenAPITargetJDKCompatibility bundledSignatures += 'jdk-system-out' suppressAnnotations += ['org.hibernate.internal.build.AllowSysOut', 'org.hibernate.internal.build.AllowPrintStacktrace'] } task forbiddenApisUnsafe(type: CheckForbiddenApis, dependsOn: compileJava) { classesDirs = project.sourceSets.main.output.classesDirs classpath = project.sourceSets.main.compileClasspath + project.sourceSets.main.runtimeClasspath targetCompatibility = project.forbiddenAPITargetJDKCompatibility bundledSignatures += "jdk-unsafe-${baselineJavaVersion}".toString() // unfortunately we currently have many uses of default Locale implicitly (~370) which need to be fixed // before we can fully enabled this check // // No idea how findbugs was missing these b4 ignoreFailures = true } task forbiddenApisNonPortable(type: CheckForbiddenApis, dependsOn: compileJava) { classesDirs = project.sourceSets.main.output.classesDirs classpath = project.sourceSets.main.compileClasspath + project.sourceSets.main.runtimeClasspath targetCompatibility = project.forbiddenAPITargetJDKCompatibility bundledSignatures += 'jdk-non-portable' } task forbiddenApis project.tasks.withType( CheckForbiddenApis ).each { task -> forbiddenApis.finalizedBy task } project.tasks.check.finalizedBy forbiddenApis