Common Gradle modules for multiple projects
This repository is supposed to be used as a submodule in a project. The Gradle build should then be configured as an include build.
To include this repository as a submodule in a project, run the following command in the project's root directory:
git submodule add https://github.com/SonarSource/cloud-native-gradle-modules gradle/build-logicThen, in the project's settings.gradle.kts file, add includeBuild to the pluginManagement block:
pluginManagement {
includeBuild("gradle/build-logic")
}Here we used gradle/build-logic as a directory, but the choice is arbitrary.
An example usage can be seen in the Sonar-Go analyzer
When a newer version of the submodule is integrated into a remote branch, running git pull will not automatically update the submodule. Instead, Git will display it as changed, and git status will show a message like:
modified: gradle/build-logic (new commits)
To configure Git to automatically checkout changes in the submodule, run the following command:
git config submodule.recurse trueOptionally, run this command with --global to apply this configuration globally.
- Apply
artifactory-configurationto the root project to set some defaults - Apply
sonar-pluginto the subproject that contains the plugin - If necessary, re-apply
artifactory-configurationto the subproject to override the defaults
- Apply
go-binary-builderscript to the subproject that contains the Go code- It expects
make.shandmake.batscripts to be present in the same directory asbuild.gradle[.kts]
- It expects
- Configure the
goBuildextension - Go-related tasks are automatically linked to
test,assemble,check, andbuildtasks - A configuration
goBinariesis created, and it can be used to depend on the Go binaries likeimplementation(projects(":go-subprojcet", "goBinaries"))
The license-file-generator plugin generates license files for third-party runtime dependencies and bundles them into the plugin's resources folder.
Apply the plugin to the subproject that packages the plugin (usually sonar-<language>-plugin):
plugins {
id("org.sonarsource.cloud-native.license-file-generator")
}The plugin exposes a licenseGenerationConfig extension with the following options:
| Property | Type | Default | Description |
|---|---|---|---|
projectLicenseFile |
File |
../LICENSE.txt (one level above the plugin project directory) |
The project's own license file. |
dependencyLicenseOverrides |
Map<String, File> |
empty | Per-dependency license file overrides. Keys use the group:name format. |
Example configuration (Groovy DSL):
licenseGenerationConfig {
projectLicenseFile.set(file("../LICENSE.txt"))
dependencyLicenseOverrides.put("com.salesforce:apex-jorje-lsp-minimized", file("../build-logic/common/gradle-modules/src/main/resources/licenses/BSD-3.txt"))
}Example configuration (Kotlin DSL):
licenseGenerationConfig {
projectLicenseFile.set(file("../LICENSE.txt"))
dependencyLicenseOverrides.put("com.salesforce:apex-jorje-lsp-minimized", file("../build-logic/common/gradle-modules/src/main/resources/licenses/BSD-3.txt"))
}Use dependencyLicenseOverrides when the plugin cannot automatically resolve the correct license for a dependency (e.g., the dependency jar does not include a license file and its POM license title is not recognized).
The following license files are bundled in this module and can be referenced in overrides:
0BSD.txt, Apache-2.0.txt, BSD-2.txt, BSD-3.txt, GNU-LGPL-3.txt, Go.txt, lgpl-2.1.txt, MIT.txt
| Task | Description |
|---|---|
generateLicenseReport |
Generates license files into the build directory. |
generateLicenseResources |
Copies generated license files to src/main/resources/licenses/. Run this to update committed license files. |
validateLicenseFiles |
Validates that committed license files match the generated ones. Runs as part of check. |
- Apply the plugin and configure
licenseGenerationConfigif needed - Run
./gradlew generateLicenseResourcesto generate and copy license files intosrc/main/resources/licenses/ - Commit the generated files
- The
checktask will automatically validate that committed license files are up-to-date viavalidateLicenseFiles