From 00e0dc6ac85048c9cc33cb3423bd0b2b6d811bc0 Mon Sep 17 00:00:00 2001 From: olewandowski1 Date: Fri, 3 Nov 2023 10:45:52 +0100 Subject: [PATCH] CQI-10: use sonarcloud instead of sonarqube --- .github/workflows/sonar-analysis.yml | 20 ++++++++++ .gitignore | 1 - Jenkinsfile | 58 ---------------------------- sonar-project.properties | 5 +++ sonar.sh | 9 ----- 5 files changed, 25 insertions(+), 68 deletions(-) create mode 100644 .github/workflows/sonar-analysis.yml create mode 100644 sonar-project.properties delete mode 100755 sonar.sh diff --git a/.github/workflows/sonar-analysis.yml b/.github/workflows/sonar-analysis.yml new file mode 100644 index 00000000..1cc250c8 --- /dev/null +++ b/.github/workflows/sonar-analysis.yml @@ -0,0 +1,20 @@ +name: SonarCloud OpenLMIS-stockmanagement-ui Pipeline +on: + push: + branches: + - master + pull_request: + types: [opened, synchronize, reopened] +jobs: + sonarcloud: + name: SonarCloud Analyze + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v3 + with: + fetch-depth: 0 + - name: SonarCloud Scan + uses: SonarSource/sonarcloud-github-action@master + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + SONAR_TOKEN: ${{ secrets.SONAR_TOKEN }} diff --git a/.gitignore b/.gitignore index 43999e78..e3fc7485 100644 --- a/.gitignore +++ b/.gitignore @@ -14,4 +14,3 @@ bower_components .tmp /local-web-test/.local-web-test-env /local-web-test/.local-web-test-env-home -.sonar diff --git a/Jenkinsfile b/Jenkinsfile index 505fde15..61189695 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -109,64 +109,6 @@ pipeline { } } } - stage('Sonar analysis') { - when { - expression { - return VERSION.endsWith("SNAPSHOT") - } - } - steps { - withSonarQubeEnv('Sonar OpenLMIS') { - withCredentials([string(credentialsId: 'SONAR_LOGIN', variable: 'SONAR_LOGIN'), string(credentialsId: 'SONAR_PASSWORD', variable: 'SONAR_PASSWORD')]) { - script { - sh ''' - set +x - - sudo rm -f .env - touch .env - - SONAR_LOGIN_TEMP=$(echo $SONAR_LOGIN | cut -f2 -d=) - SONAR_PASSWORD_TEMP=$(echo $SONAR_PASSWORD | cut -f2 -d=) - echo "SONAR_LOGIN=$SONAR_LOGIN_TEMP" >> .env - echo "SONAR_PASSWORD=$SONAR_PASSWORD_TEMP" >> .env - echo "SONAR_BRANCH=$GIT_BRANCH" >> .env - - docker-compose run --entrypoint ./sonar.sh stockmanagement-ui - docker-compose down --volumes - ''' - // workaround because sonar plugin retrieve the path directly from the output - sh 'echo "Working dir: ${WORKSPACE}/.sonar"' - } - } - } - timeout(time: 1, unit: 'HOURS') { - script { - def gate = waitForQualityGate() - if (gate.status != 'OK') { - echo 'Quality Gate FAILED' - currentBuild.result = 'UNSTABLE' - } - } - } - } - post { - unstable { - script { - notifyAfterFailure() - } - } - failure { - script { - notifyAfterFailure() - } - } - cleanup { - script { - sh "sudo rm -rf ${WORKSPACE}/{*,.*} || true" - } - } - } - } stage('Push image') { when { expression { diff --git a/sonar-project.properties b/sonar-project.properties new file mode 100644 index 00000000..11aa281d --- /dev/null +++ b/sonar-project.properties @@ -0,0 +1,5 @@ +sonar.projectKey=OpenLMIS_openlmis-stockmanagement-ui +sonar.organization=openlmis +sonar.projectName=openlmis-stockmanagement-ui +sonar.sources=src +sonar.sourceEncoding=UTF-8 diff --git a/sonar.sh b/sonar.sh deleted file mode 100755 index 593418fc..00000000 --- a/sonar.sh +++ /dev/null @@ -1,9 +0,0 @@ -#!/bin/sh - -# Update everything (just in case) -npm rebuild -npm install --no-optional - -# Built and test -grunt -grunt sonar --sonarLogin=$SONAR_LOGIN --sonarPassword=$SONAR_PASSWORD --sonarBranch=$SONAR_BRANCH