You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

.cirrus.yml 5.2KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160
  1. #
  2. # ENV VARIABLES
  3. #
  4. env:
  5. ### Shared variables
  6. CIRRUS_VAULT_AUTH_PATH: jwt-cirrusci
  7. CIRRUS_VAULT_ROLE: cirrusci-${CIRRUS_REPO_OWNER}-${CIRRUS_REPO_NAME}
  8. CIRRUS_VAULT_URL: https://vault.sonar.build:8200
  9. ARTIFACTORY_URL: VAULT[development/kv/data/repox data.url]
  10. ARTIFACTORY_PRIVATE_USERNAME: vault-${CIRRUS_REPO_OWNER}-${CIRRUS_REPO_NAME}-private-reader
  11. ARTIFACTORY_PRIVATE_PASSWORD: VAULT[development/artifactory/token/SonarSource-sonar-scanner-cli-private-reader access_token]
  12. ARTIFACTORY_ACCESS_TOKEN: VAULT[development/artifactory/token/SonarSource-sonar-scanner-cli-private-reader access_token]
  13. ARTIFACTORY_DEPLOY_USERNAME: vault-${CIRRUS_REPO_OWNER}-${CIRRUS_REPO_NAME}-qa-deployer
  14. ARTIFACTORY_DEPLOY_PASSWORD: VAULT[development/artifactory/token/SonarSource-sonar-scanner-cli-qa-deployer access_token]
  15. ARTIFACTORY_DEPLOY_REPO: sonarsource-public-qa
  16. ARTIFACTORY_PROMOTE_ACCESS_TOKEN: VAULT[development/artifactory/token/${CIRRUS_REPO_OWNER}-${CIRRUS_REPO_NAME}-promoter access_token]
  17. BURGR_URL: VAULT[development/kv/data/burgr data.url]
  18. BURGR_USERNAME: VAULT[development/kv/data/burgr data.cirrus_username]
  19. BURGR_PASSWORD: VAULT[development/kv/data/burgr data.cirrus_password]
  20. ### Project variables
  21. DEPLOY_PULL_REQUEST: true
  22. ARTIFACTS: org.sonarsource.scanner.cli:sonar-scanner-cli:jar
  23. NIGHTLY_CRON: 'nightly-cron'
  24. #
  25. # RE-USABLE CONFIGS
  26. #
  27. eks_container: &EKS_CONTAINER
  28. region: eu-central-1
  29. cluster_name: ${CIRRUS_CLUSTER_NAME}
  30. namespace: default
  31. image: ${CIRRUS_AWS_ACCOUNT}.dkr.ecr.eu-central-1.amazonaws.com/base:j17-m3-latest
  32. cpu: 1
  33. memory: 4G
  34. ec2_instance: &EC2_INSTANCE_WINDOWS
  35. experimental: true # see https://github.com/cirruslabs/cirrus-ci-docs/issues/1051
  36. region: eu-central-1
  37. subnet_id: ${CIRRUS_AWS_SUBNET}
  38. type: t2.2xlarge
  39. image: base-windows-jdk17-v*
  40. platform: windows
  41. only_sonarsource_qa: &ONLY_SONARSOURCE_QA
  42. only_if: $CIRRUS_USER_COLLABORATOR == 'true' && $CIRRUS_TAG == "" && ($CIRRUS_PR != "" || $CIRRUS_BRANCH == $CIRRUS_DEFAULT_BRANCH || $CIRRUS_BRANCH =~ "branch-.*" || $CIRRUS_BUILD_SOURCE == 'api' )
  43. except_nightly_cron: &EXCEPT_ON_NIGHTLY_CRON
  44. only_if: $CIRRUS_CRON != $NIGHTLY_CRON
  45. #
  46. # TASKS
  47. #
  48. build_task:
  49. <<: *ONLY_SONARSOURCE_QA
  50. eks_container:
  51. <<: *EKS_CONTAINER
  52. env:
  53. SONAR_TOKEN: VAULT[development/kv/data/next data.token]
  54. SONAR_HOST_URL: VAULT[development/kv/data/next data.url]
  55. SIGN_KEY: VAULT[development/kv/data/sign data.key]
  56. PGP_PASSPHRASE: VAULT[development/kv/data/sign data.passphrase]
  57. maven_cache:
  58. folder: ${CIRRUS_WORKING_DIR}/.m2/repository
  59. script:
  60. - source cirrus-env BUILD
  61. - regular_mvn_build_deploy_analyze -Pdist-linux,dist-windows,dist-macosx
  62. cleanup_before_cache_script:
  63. - cleanup_maven_repository
  64. mend_scan_task:
  65. depends_on:
  66. - build
  67. eks_container:
  68. <<: *EKS_CONTAINER
  69. cpu: 2
  70. memory: 2G
  71. # run only on master and long-term branches
  72. only_if: $CIRRUS_USER_COLLABORATOR == 'true' && $CIRRUS_TAG == "" && ($CIRRUS_BRANCH == $CIRRUS_DEFAULT_BRANCH || $CIRRUS_BRANCH =~ "branch-.*")
  73. env:
  74. WS_APIKEY: VAULT[development/kv/data/mend data.apikey]
  75. maven_cache:
  76. folder: ${CIRRUS_WORKING_DIR}/.m2/repository
  77. whitesource_script:
  78. - source cirrus-env QA
  79. - source set_maven_build_version $BUILD_NUMBER
  80. - mvn clean install -DskipTests --batch-mode
  81. - source ws_scan.sh
  82. cleanup_before_cache_script: cleanup_maven_repository
  83. allow_failures: "true"
  84. always:
  85. ws_artifacts:
  86. path: "whitesource/**/*"
  87. linux_qa_java17_task:
  88. depends_on:
  89. - build
  90. <<: *ONLY_SONARSOURCE_QA
  91. eks_container:
  92. <<: *EKS_CONTAINER
  93. env:
  94. matrix:
  95. - SQ_VERSION: LATEST_RELEASE[9.9]
  96. - SQ_VERSION: LATEST_RELEASE
  97. - SQ_VERSION: DEV
  98. maven_cache:
  99. folder: ${CIRRUS_WORKING_DIR}/.m2/repository
  100. qa_script:
  101. - nodeVersion=18.17.0
  102. - nodeName=node-v${nodeVersion}-linux-x64
  103. - wget https://nodejs.org/download/release/v${nodeVersion}/${nodeName}.tar.gz
  104. - tar xzf ${nodeName}.tar.gz -C /tmp
  105. - export PATH=$PATH:/tmp/${nodeName}/bin
  106. - source cirrus-env QA
  107. - source set_maven_build_version $BUILD_NUMBER
  108. - cd it
  109. - mvn -B -e -Dsonar.runtimeVersion="$SQ_VERSION" -Dmaven.test.redirectTestOutputToFile=false verify
  110. cleanup_before_cache_script:
  111. - cleanup_maven_repository
  112. win_qa_java17_task:
  113. depends_on:
  114. - build
  115. <<: *ONLY_SONARSOURCE_QA
  116. ec2_instance:
  117. <<: *EC2_INSTANCE_WINDOWS
  118. env:
  119. CIRRUS_SHELL: bash
  120. matrix:
  121. - SQ_VERSION: LATEST_RELEASE[9.9]
  122. - SQ_VERSION: LATEST_RELEASE
  123. - SQ_VERSION: DEV
  124. maven_cache:
  125. folder: ${CIRRUS_WORKING_DIR}/.m2/repository
  126. qa_script:
  127. - source cirrus-env QA
  128. - source set_maven_build_version $BUILD_NUMBER
  129. - cd it
  130. - mvn -B -e -Dsonar.runtimeVersion="$SQ_VERSION" -Dmaven.test.redirectTestOutputToFile=false verify
  131. cleanup_before_cache_script:
  132. - cleanup_maven_repository
  133. promote_task:
  134. depends_on:
  135. - linux_qa_java17
  136. - win_qa_java17
  137. <<: *ONLY_SONARSOURCE_QA
  138. <<: *EXCEPT_ON_NIGHTLY_CRON
  139. eks_container:
  140. <<: *EKS_CONTAINER
  141. cpu: 0.5
  142. memory: 500M
  143. env:
  144. GITHUB_TOKEN: VAULT[development/github/token/SonarSource-sonar-scanner-cli-promotion token]
  145. maven_cache:
  146. folder: $CIRRUS_WORKING_DIR/.m2/repository
  147. script:
  148. - cirrus_promote_maven
  149. cleanup_before_cache_script:
  150. - cleanup_maven_repository