Skip to content

Commit

Permalink
FINERACT-2122: Add devRun gradle task, optimize build caching, fix de…
Browse files Browse the repository at this point in the history
…precations
  • Loading branch information
kjozsa committed Jan 6, 2025
1 parent dfc1d3e commit 0b0f02d
Show file tree
Hide file tree
Showing 22 changed files with 606 additions and 124 deletions.
106 changes: 94 additions & 12 deletions build.gradle
Original file line number Diff line number Diff line change
Expand Up @@ -150,11 +150,39 @@ allprojects {
mavenCentral()
}

configurations {
api {
canBeResolved = true
}
}

apply plugin: 'com.adarshr.test-logger'
apply plugin: 'com.diffplug.spotless'
apply plugin: 'com.github.hierynomus.license'
apply plugin: 'net.ltgt.errorprone'

tasks.withType(JavaCompile).configureEach {
options.errorprone {
disableWarningsInGeneratedCode = true
disable(
"CanIgnoreReturnValueSuggester",
"SameNameButDifferent", // Until errorprone recognizes Lombok
"MultiVariableDeclaration", // Until errorprone recognizes Lombok
"UnnecessaryDefaultInEnumSwitch", // FINERACT-1911
"AssertEqualsArgumentOrderChecker",
"RemoveUnusedImports" // For generated code
)
error(
"DefaultCharset",
"StringSplitter",
"MutablePublicArray",
"EqualsGetClass",
"FutureReturnValueIgnored"
)
}
}

apply plugin: 'org.nosphere.apache.rat'
apply plugin: 'project-report'
apply plugin: 'com.github.jk1.dependency-license-report'

// Configuration for the sonarqube plugin is now in GitHub Actions
Expand Down Expand Up @@ -324,20 +352,59 @@ configure(project.fineractJavaProjects) {

apply plugin: 'java'
apply plugin: 'idea'

java {
sourceCompatibility = JavaVersion.VERSION_17
targetCompatibility = JavaVersion.VERSION_17
withSourcesJar()
withJavadocJar()
}

tasks.withType(ProcessResources) {
destinationDir = layout.buildDirectory.dir('classes/java/main').get().asFile
}

// Add performance optimizations
configurations.all {
resolutionStrategy {
cacheChangingModulesFor 0, 'seconds'
cacheDynamicVersionsFor 0, 'seconds'
}
}

tasks.withType(JavaCompile).configureEach {
options.incremental = true
options.fork = true
outputs.cacheIf { true }
options.compilerArgs << '-parameters'
options.encoding = 'UTF-8'
options.compilerArgs << '-Xlint:unchecked'
options.compilerArgs << '-Xlint:deprecation'
if (project.hasProperty('warnings') && project.warnings.contains('fail')) {
options.compilerArgs << '-Werror'
}
if (project.hasProperty('warnings') && project.warnings.contains('none')) {
options.compilerArgs << '-nowarn'
}
if (project.plugins.hasPlugin('org.springframework.boot')) {
options.generatedSourceOutputDirectory = file("$buildDir/generated/sources/annotationProcessor/java/main")
}
options.generatedSourceOutputDirectory = file("$buildDir/generated/sources/annotationProcessor/java/main")
}

apply plugin: 'eclipse'
apply plugin: 'checkstyle'
apply plugin: 'jacoco'
apply plugin: 'net.ltgt.errorprone'
apply plugin: 'com.github.spotbugs'
apply plugin: 'com.github.andygoossens.modernizer'
apply from: "${rootDir}/buildSrc/src/main/groovy/org.apache.fineract.dependencies.gradle"

group = 'org.apache.fineract'

/* define the valid syntax level for source files */
sourceCompatibility = JavaVersion.VERSION_17
/* define binary compatibility version */
targetCompatibility = JavaVersion.VERSION_17
// sourceCompatibility = JavaVersion.VERSION_17
// /* define binary compatibility version */
// targetCompatibility = JavaVersion.VERSION_17

/* http://stackoverflow.com/questions/19653311/jpa-repository-works-in-idea-and-production-but-not-in-gradle */
sourceSets.main.output.resourcesDir = sourceSets.main.java.classesDirectory
Expand All @@ -353,18 +420,15 @@ configure(project.fineractJavaProjects) {
}

configurations {
implementation.setCanBeResolved(true)
api.setCanBeResolved(true)
}
tasks.withType(Copy) {
duplicatesStrategy = DuplicatesStrategy.EXCLUDE
}
tasks.withType(JavaCompile) {
options.compilerArgs += [
"-Xlint:unchecked",
"-Xlint:cast",
"-Xlint:auxiliaryclass",
"-Xlint:deprecation",
"-Xlint:dep-ann",
"-Xlint:divzero",
"-Xlint:empty",
Expand Down Expand Up @@ -398,6 +462,10 @@ configure(project.fineractJavaProjects) {
options.deprecation = true
}

check {
dependsOn(rat, licenseMain, licenseTest)
}

dependencies {
spotbugsPlugins 'jp.skypencil.findbugs.slf4j:bug-pattern:1.5.0@jar'
}
Expand Down Expand Up @@ -469,7 +537,7 @@ configure(project.fineractJavaProjects) {
reports {
html.required = true
xml.required = true
html.destination file("${buildDir}/code-coverage")
html.outputLocation = layout.buildDirectory.dir('code-coverage')
}
}

Expand All @@ -479,11 +547,12 @@ configure(project.fineractJavaProjects) {
errorprone "com.google.errorprone:error_prone_core:2.35.1"
}

tasks.withType(JavaCompile) {
tasks.withType(JavaCompile).configureEach {
options.errorprone {
enabled = project.gradle.startParameter.taskNames.contains('build') || project.gradle.startParameter.taskNames.contains('check')
disableWarningsInGeneratedCode = true
excludedPaths = ".*/build/.*"
if (project.path == ':fineract-client') {
excludedPaths = '.*/build/generated/java/src/main/java/.*'
}
disable(
// TODO Remove disabled checks from this list, by fixing remaining usages
"UnusedVariable",
Expand Down Expand Up @@ -666,6 +735,19 @@ configure(project.fineractJavaProjects) {
'java/util/Optional.get:()Ljava/lang/Object;' // Disable forcing the usage of Optional.orElseThrow(java.util.function.Supplier<? extends X>)
]
}

tasks.withType(Javadoc) {
options.addStringOption('Xdoclint:none', '-quiet')
options.encoding = 'UTF-8'
// Disable strict checking to prevent build failures on invalid javadoc
options.addBooleanOption('html5', true)
// Add this if you're using Java 17 records or other modern features
if (JavaVersion.current().isCompatibleWith(JavaVersion.VERSION_17)) {
options.addBooleanOption('html5', true)
}
// Ignore any errors during javadoc generation
failOnError = false
}
}

configure(project.fineractCustomProjects) {
Expand Down
8 changes: 5 additions & 3 deletions custom/acme/event/externalevent/build.gradle
Original file line number Diff line number Diff line change
Expand Up @@ -16,10 +16,12 @@
* specific language governing permissions and limitations
* under the License.
*/
description = 'ACME Corp.: Fineract external events'
description = 'ACME Fineract Event External Event'

group = 'com.acme.fineract.event'
group = 'com.acme.fineract'

archivesBaseName = 'acme-fineract-event-externalevent'
base {
archivesName = 'acme-fineract-event-externalevent'
}

apply from: 'dependencies.gradle'
8 changes: 5 additions & 3 deletions custom/acme/event/starter/build.gradle
Original file line number Diff line number Diff line change
Expand Up @@ -16,10 +16,12 @@
* specific language governing permissions and limitations
* under the License.
*/
description = 'ACME Corp.: Fineract Event Starter'
description = 'ACME Fineract Event Starter'

group = 'com.acme.fineract.event'
group = 'com.acme.fineract'

archivesBaseName = 'acme-fineract-event-starter'
base {
archivesName = 'acme-fineract-event-starter'
}

apply from: 'dependencies.gradle'
6 changes: 4 additions & 2 deletions custom/acme/loan/cob/build.gradle
Original file line number Diff line number Diff line change
Expand Up @@ -16,10 +16,12 @@
* specific language governing permissions and limitations
* under the License.
*/
description = 'ACME Corp.: Fineract COB Loan'
description = 'ACME Fineract Loan COB'

group = 'com.acme.fineract'

archivesBaseName = 'acme-fineract-loan-cob'
base {
archivesName = 'acme-fineract-loan-cob'
}

apply from: 'dependencies.gradle'
6 changes: 4 additions & 2 deletions custom/acme/loan/job/build.gradle
Original file line number Diff line number Diff line change
Expand Up @@ -16,10 +16,12 @@
* specific language governing permissions and limitations
* under the License.
*/
description = 'ACME Corp.: Fineract Loan Job'
description = 'ACME Fineract Loan Job'

group = 'com.acme.fineract'

archivesBaseName = 'acme-fineract-loan-job'
base {
archivesName = 'acme-fineract-loan-job'
}

apply from: 'dependencies.gradle'
6 changes: 4 additions & 2 deletions custom/acme/loan/processor/build.gradle
Original file line number Diff line number Diff line change
Expand Up @@ -16,10 +16,12 @@
* specific language governing permissions and limitations
* under the License.
*/
description = 'ACME Corp.: Fineract Loan Transaction Processors'
description = 'ACME Fineract Loan Processor'

group = 'com.acme.fineract'

archivesBaseName = 'acme-fineract-loan-processor'
base {
archivesName = 'acme-fineract-loan-processor'
}

apply from: 'dependencies.gradle'
6 changes: 4 additions & 2 deletions custom/acme/loan/starter/build.gradle
Original file line number Diff line number Diff line change
Expand Up @@ -16,10 +16,12 @@
* specific language governing permissions and limitations
* under the License.
*/
description = 'ACME Corp.: Fineract COB Starter'
description = 'ACME Fineract Loan Starter'

group = 'com.acme.fineract'

archivesBaseName = 'acme-fineract-loan-starter'
base {
archivesName = 'acme-fineract-loan-starter'
}

apply from: 'dependencies.gradle'
8 changes: 5 additions & 3 deletions custom/acme/note/service/build.gradle
Original file line number Diff line number Diff line change
Expand Up @@ -16,10 +16,12 @@
* specific language governing permissions and limitations
* under the License.
*/
description = 'ACME Corp.: Fineract Note Service'
description = 'ACME Fineract Note Service'

group = 'com.acme.fineract.portfolio.note'
group = 'com.acme.fineract'

archivesBaseName = 'acme-fineract-note-service'
base {
archivesName = 'acme-fineract-note-service'
}

apply from: 'dependencies.gradle'
8 changes: 5 additions & 3 deletions custom/acme/note/starter/build.gradle
Original file line number Diff line number Diff line change
Expand Up @@ -16,10 +16,12 @@
* specific language governing permissions and limitations
* under the License.
*/
description = 'ACME Corp.: Fineract Note Starter'
description = 'ACME Fineract Note Starter'

group = 'com.acme.fineract.portfolio.note'
group = 'com.acme.fineract'

archivesBaseName = 'acme-fineract-note-starter'
base {
archivesName = 'acme-fineract-note-starter'
}

apply from: 'dependencies.gradle'
2 changes: 1 addition & 1 deletion fineract-accounting/build.gradle
Original file line number Diff line number Diff line change
Expand Up @@ -31,7 +31,7 @@ compileJava.doLast {
javaexec {
description = 'Performs EclipseLink static weaving of entity classes'
def target = source
main 'org.eclipse.persistence.tools.weaving.jpa.StaticWeave'
mainClass = 'org.eclipse.persistence.tools.weaving.jpa.StaticWeave'
args '-persistenceinfo', source, source, target
classpath sourceSets.main.runtimeClasspath
}
Expand Down
44 changes: 36 additions & 8 deletions fineract-avro-schemas/build.gradle
Original file line number Diff line number Diff line change
Expand Up @@ -26,18 +26,39 @@ apply plugin: 'com.github.davidmc24.gradle.plugin.avro-base'

apply from: 'dependencies.gradle'

task preprocessAvroSchemas() {
doLast {
copy {
from "$projectDir/src/main/avro"
into "$buildDir/generated/avro/src/main/avro"
filter { line ->
line.replaceAll("\"bigdecimal\"", new File("$projectDir/src/main/resources/avro-templates/bigdecimal.avsc").getText("UTF-8"))
abstract class PreprocessAvroSchemasTask extends DefaultTask {
@InputDirectory
abstract DirectoryProperty getInputDir()

@InputFile
abstract RegularFileProperty getBigDecimalTemplate()

@OutputDirectory
abstract DirectoryProperty getOutputDir()

@TaskAction
def preprocess() {
def template = getBigDecimalTemplate().get().asFile.getText("UTF-8")
def input = getInputDir().get().asFile
def output = getOutputDir().get().asFile

input.eachFileRecurse { file ->
if (file.isFile()) {
def relativePath = input.toPath().relativize(file.toPath())
def targetFile = output.toPath().resolve(relativePath).toFile()
targetFile.parentFile.mkdirs()
targetFile.text = file.text.replaceAll("\"bigdecimal\"", template)
}
}
}
}

tasks.register('preprocessAvroSchemas', PreprocessAvroSchemasTask) {
inputDir = file("$projectDir/src/main/avro")
bigDecimalTemplate = file("$projectDir/src/main/resources/avro-templates/bigdecimal.avsc")
outputDir = file("$buildDir/generated/avro/src/main/avro")
}

task buildJavaSdk(type: GenerateAvroJavaTask) {
source("$buildDir/generated/avro/src/main/avro")
outputDir = file("$buildDir/generated/java/src/main/java")
Expand All @@ -61,7 +82,10 @@ java {
targetCompatibility = JavaVersion.VERSION_1_8
}

tasks.withType(JavaCompile) {
tasks.withType(JavaCompile).configureEach {
options.errorprone {
enabled = false // Disable ErrorProne for this module since it contains generated code
}
options.compilerArgs -= ["-Werror"]
}

Expand All @@ -78,3 +102,7 @@ sourceSets.main.java.srcDir new File(buildDir, "generated/java/src/main/java")

licenseFormatMain.dependsOn buildJavaSdk
licenseMain.dependsOn licenseFormatMain

tasks.named('sourcesJar') {
dependsOn tasks.named('buildJavaSdk')
}
Loading

0 comments on commit 0b0f02d

Please sign in to comment.