From 6394f5b37450c21a5ebafa8e0873ecde3f5db414 Mon Sep 17 00:00:00 2001 From: Peter Trifanov Date: Tue, 17 Dec 2024 17:11:08 +0100 Subject: [PATCH] SONARGO-82 Add "artifactory-configuration" to common Gradle modules (#44) --- .cirrus.yml | 15 +-- build-logic | 2 +- build.gradle | 177 ----------------------------- build.gradle.kts | 50 ++++++++ sonar-go-plugin/build.gradle.kts | 12 +- sonar-go-to-slang/build.gradle.kts | 7 ++ 6 files changed, 73 insertions(+), 190 deletions(-) delete mode 100644 build.gradle create mode 100644 build.gradle.kts diff --git a/.cirrus.yml b/.cirrus.yml index bd717c3..e7a4068 100644 --- a/.cirrus.yml +++ b/.cirrus.yml @@ -70,15 +70,13 @@ on_failure_template: &ON_FAILURE setup_gradle_cache_template: &SETUP_GRADLE_CACHE gradle_cache: folder: .gradle/caches - create_gradle_directory_script: - - mkdir -p "${CIRRUS_WORKING_DIR}/.gradle" + reupload_on_changes: "true" + populate_script: mkdir -p "${GRADLE_USER_HOME}" cleanup_gradle_cache_script_template: &CLEANUP_GRADLE_CACHE_SCRIPT cleanup_gradle_script: - - /usr/bin/find "${CIRRUS_WORKING_DIR}/.gradle/caches/" -name "*.lock" -type f -delete - - rm -rf "${CIRRUS_WORKING_DIR}/.gradle/caches/4.10.2/" - - rm -rf "${CIRRUS_WORKING_DIR}/.gradle/caches/journal-1/" - - rm -rf "${CIRRUS_WORKING_DIR}/.gradle/caches/build-cache-1/" + - rm -rf "${GRADLE_USER_HOME}/caches/journal-1/" + - find ${GRADLE_USER_HOME}/caches/ -name "*.lock" -type f -delete || true build_task: <<: *LINUX_4_CPU_6G @@ -90,9 +88,7 @@ build_task: build_script: - git submodule update --init --depth 1 -- build-logic - source cirrus-env BUILD - - function gradle(){ ./gradlew "$@"; }; export -f gradle - - gradle --version - - source set_gradle_build_version + - source .cirrus/use-gradle-wrapper.sh - regular_gradle_build_deploy_analyze <<: *ON_FAILURE <<: *CLEANUP_GRADLE_CACHE_SCRIPT @@ -116,7 +112,6 @@ gradle_its_template: &GRADLE_ITS_TEMPLATE "-Dsonar.runtimeVersion=${SQ_VERSION}" "-Dorchestrator.artifactory.accessToken=${ARTIFACTORY_ACCESS_TOKEN}" "-DbuildNumber=$BUILD_NUMBER" - -I "${GRADLE_HOME}/init.d/repoxAuth.init.gradle.kts" --info --stacktrace --console plain --no-daemon --build-cache <<: *CLEANUP_GRADLE_CACHE_SCRIPT diff --git a/build-logic b/build-logic index 3a87c25..9243aed 160000 --- a/build-logic +++ b/build-logic @@ -1 +1 @@ -Subproject commit 3a87c2511f6809b708685b09c5170a2fc25a5349 +Subproject commit 9243aeda28e01c2953f58504d6f3c0708a7753ba diff --git a/build.gradle b/build.gradle deleted file mode 100644 index f29ea2e..0000000 --- a/build.gradle +++ /dev/null @@ -1,177 +0,0 @@ -/* - * SonarSource Go - * Copyright (C) 2018-2024 SonarSource SA - * mailto:info AT sonarsource DOT com - * - * This program is free software; you can redistribute it and/or - * modify it under the terms of the Sonar Source-Available License Version 1, as published by SonarSource SA. - * - * This program is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. - * See the Sonar Source-Available License for more details. - * - * You should have received a copy of the Sonar Source-Available License - * along with this program; if not, see https://sonarsource.com/license/ssal/ - */ -import java.util.jar.JarInputStream - -plugins { - id("org.sonarsource.cloud-native.code-style-conventions") - id 'com.jfrog.artifactory' version '4.28.2' - id 'org.sonarqube' version '6.0.1.5171' - id 'de.thetaphi.forbiddenapis' version '3.0' apply false -} - -allprojects { - apply plugin: 'java' - apply plugin: 'com.jfrog.artifactory' - apply plugin: 'maven-publish' - apply plugin: 'signing' - - ext { - sonarLinksCi = 'https://cirrus-ci.com/github/SonarSource/sonar-go' - sonarLinksScm = 'https://github.com/SonarSource/sonar-go' - - artifactsToPublish = '' - artifactsToDownload = '' - } - - repositories { - mavenCentral() - def artifactoryBearerToken = System.getenv("ARTIFACTORY_PRIVATE_PASSWORD") ?: project.findProperty("artifactoryPassword") - if (artifactoryBearerToken) { - maven { - url "https://repox.jfrog.io/repox/sonarsource" - authentication { - header(HttpHeaderAuthentication) - } - credentials(HttpHeaderCredentials) { - name = "Authorization" - value = "Bearer $artifactoryBearerToken" - } - } - } - } -} - -subprojects { - // do not publish to Artifactory by default - artifactoryPublish.skip = true - - configurations { - // include compileOnly dependencies during test - testCompile.extendsFrom compileOnly - } - - tasks.withType(Test).configureEach { - def propKeys = System.properties.findAll { - it.key.startsWith("orchestrator") || it.key.startsWith("sonar") || it.key == "buildNumber" || it.key == "slangVersion" - }.collect { it.key } - systemProperties = System.properties.subMap(propKeys) - if (propKeys.contains("buildNumber") && !propKeys.contains("slangVersion")) { - systemProperties["slangVersion"] = version - } - } - - publishing { - publications { - mavenJava(MavenPublication) { - pom { - name = projectTitle - description = project.description - url = 'http://www.sonarqube.org/' - organization { - name = 'SonarSource' - url = 'http://www.sonarsource.com' - } - licenses { - license { - name = 'SSALv1' - url = 'https://sonarsource.com/license/ssal/' - distribution = 'repo' - } - } - scm { - url = 'https://github.com/SonarSource/sonar-go' - } - developers { - developer { - id = 'sonarsource-team' - name = 'SonarSource Team' - } - } - } - } - } - } - - signing { - def signingKeyId = findProperty("signingKeyId") - def signingKey = findProperty("signingKey") - def signingPassword = findProperty("signingPassword") - useInMemoryPgpKeys(signingKeyId, signingKey, signingPassword) - required { - def branch = System.getenv()["CIRRUS_BRANCH"] - return (branch == 'master' || branch ==~ 'branch-[\\d.]+') && - gradle.taskGraph.hasTask(":artifactoryPublish") - } - sign publishing.publications - } - - tasks.withType(Sign) { - onlyIf { - def branch = System.getenv()["CIRRUS_BRANCH"] - return !artifactoryPublish.skip && - (branch == 'master' || branch ==~ 'branch-[\\d.]+') && - gradle.taskGraph.hasTask(":artifactoryPublish") - } - } -} - -sonar { - properties { - property 'sonar.organization', 'sonarsource' - property 'sonar.projectKey', 'SonarSource_sonar-go' - property 'sonar.projectName', projectTitle - property 'sonar.links.ci', "${sonarLinksCi}" - property 'sonar.links.scm', "${sonarLinksScm}" - property 'sonar.links.issue', 'https://jira.sonarsource.com/browse/SONARGO' - property 'sonar.exclusions', '**/build/**/*' - } -} - -artifactory { - clientConfig.setIncludeEnvVars(true) - clientConfig.setEnvVarsExcludePatterns('*password*,*PASSWORD*,*secret*,*MAVEN_CMD_LINE_ARGS*,sun.java.command,*token*,*TOKEN*,*LOGIN*,*login*,*key*,*KEY*,*PASSPHRASE*,*signing*') - contextUrl = System.getenv('ARTIFACTORY_URL') - publish { - repository { - repoKey = System.getenv('ARTIFACTORY_DEPLOY_REPO') - username = System.getenv('ARTIFACTORY_DEPLOY_USERNAME') - password = System.getenv('ARTIFACTORY_DEPLOY_PASSWORD') - } - defaults { - properties = [ - 'build.name' : 'sonar-go', - 'build.number' : System.getenv('BUILD_NUMBER'), - 'pr.branch.target': System.getenv('PULL_REQUEST_BRANCH_TARGET'), - 'pr.number' : System.getenv('PULL_REQUEST_NUMBER'), - 'vcs.branch' : System.getenv('GIT_BRANCH'), - 'vcs.revision' : System.getenv('GIT_COMMIT'), - 'version' : version - ] - publications('mavenJava') - publishPom = true - publishIvy = false - } - } - - clientConfig.info.setBuildName('sonar-go') - clientConfig.info.setBuildNumber(System.getenv('BUILD_NUMBER')) - // Define the artifacts to be deployed to https://binaries.sonarsource.com on releases - clientConfig.info.addEnvironmentProperty('ARTIFACTS_TO_PUBLISH', artifactsToPublish) - clientConfig.info.addEnvironmentProperty('ARTIFACTS_TO_DOWNLOAD', artifactsToDownload) - // The name of this variable is important because it's used by the delivery process when extracting version from Artifactory build info. - clientConfig.info.addEnvironmentProperty('PROJECT_VERSION', "${version}") -} diff --git a/build.gradle.kts b/build.gradle.kts new file mode 100644 index 0000000..0f43c0a --- /dev/null +++ b/build.gradle.kts @@ -0,0 +1,50 @@ +/* + * SonarSource Go + * Copyright (C) 2018-2024 SonarSource SA + * mailto:info AT sonarsource DOT com + * + * This program is free software; you can redistribute it and/or + * modify it under the terms of the Sonar Source-Available License Version 1, as published by SonarSource SA. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. + * See the Sonar Source-Available License for more details. + * + * You should have received a copy of the Sonar Source-Available License + * along with this program; if not, see https://sonarsource.com/license/ssal/ + */ +plugins { + id("org.sonarsource.cloud-native.code-style-conventions") + id("org.sonarsource.cloud-native.artifactory-configuration") + id("org.sonarqube") version "6.0.1.5171" +} + +artifactoryConfiguration { + buildName = "sonar-go" + artifactsToPublish = "org.sonarsource.slang:sonar-go-plugin:jar" + artifactsToDownload = "" + repoKeyEnv = "ARTIFACTORY_DEPLOY_REPO" + usernameEnv = "ARTIFACTORY_DEPLOY_USERNAME" + passwordEnv = "ARTIFACTORY_DEPLOY_PASSWORD" +} + +spotless { + java { + // no Java sources in the root project + target("") + } +} + +val projectTitle = properties["projectTitle"] as String +sonar { + properties { + property("sonar.organization", "sonarsource") + property("sonar.projectKey", "SonarSource_sonar-go") + property("sonar.projectName", projectTitle) + property("sonar.links.ci", "https://cirrus-ci.com/github/SonarSource/sonar-go") + property("sonar.links.scm", "https://github.com/SonarSource/sonar-go") + property("sonar.links.issue", "https://jira.sonarsource.com/browse/SONARGO") + property("sonar.exclusions", "**/build/**/*") + } +} diff --git a/sonar-go-plugin/build.gradle.kts b/sonar-go-plugin/build.gradle.kts index 1b00ad0..bc2c0fe 100644 --- a/sonar-go-plugin/build.gradle.kts +++ b/sonar-go-plugin/build.gradle.kts @@ -22,6 +22,7 @@ import java.util.jar.JarInputStream plugins { id("org.sonarsource.cloud-native.java-conventions") id("org.sonarsource.cloud-native.code-style-conventions") + id("org.sonarsource.cloud-native.publishing-configuration") id("com.github.johnrengelman.shadow") version "7.1.0" } @@ -117,8 +118,15 @@ artifacts { archives(tasks.shadowJar) } -tasks.artifactoryPublish { - skip = false +publishingConfiguration { + pomName = properties["projectTitle"] as String + scmUrl = "https://github.com/SonarSource/sonar-go" + + license { + name = "SSALv1" + url = "https://sonarsource.com/license/ssal/" + distribution = "repo" + } } publishing { diff --git a/sonar-go-to-slang/build.gradle.kts b/sonar-go-to-slang/build.gradle.kts index 503354b..155feda 100644 --- a/sonar-go-to-slang/build.gradle.kts +++ b/sonar-go-to-slang/build.gradle.kts @@ -68,6 +68,13 @@ tasks.build { dependsOn(generateTestReport) } +spotless { + java { + // No Java sources in this project + target("") + } +} + if (System.getenv("CI") == "true") { // spotless is enabled only for CI, because spotless relies on Go installation being available on the machine spotless {