Skip to content

Latest commit

 

History

History
261 lines (178 loc) · 12.9 KB

README.MD

File metadata and controls

261 lines (178 loc) · 12.9 KB

This project provides Docker images to tests some features of the SonarQube scanner for Jenkins related to

  • Jenkins 2
  • Jenkins pipeline (available in later version of Jenkins 1 and in Jenkins 2)

It provides the different Docker images:

Preparing the environment

Build test-sonarqube-jenkins-pipeline:jenkins1 Docker image

cd jenkins1
docker build -t test-sonarqube-jenkins-pipeline:jenkins1 .

Build test-sonarqube-jenkins-pipeline:jenkins2-base Docker image

cd jenkins2/base
docker build -t test-sonarqube-jenkins-pipeline:jenkins2-base .

Testing

Validating with test-sonarqube-jenkins-pipeline:jenkins2-base Docker image:

SonarQube Scanner for MSBuild and SonarQube Scanner installations must be configured at http://localhost:8080/configureTools

Tools configuration

To run Jenkins:

docker run --rm -p 2222:2222 -p 8080:8080 -p 8081:8081 -p 9418:9418 -ti test-sonarqube-jenkins-pipeline:jenkins2-base

Scanner on Freestyle

  • with a SonarQube Scanner for MSBuild -Begin Analysis Build Step:

MSBuild Scanner on Freestyle

Scanner General Build Step on Pipeline

  • with a SonarQube Scanner for MSBuild - Begin Analysis General Build Step:

MSBuild Scanner General Build Step on Pipeline

  • with a sonarScanner: Execute SonarQube Scanner Step:

Scanner on Pipeline

  • with a sonarScannerMSBuildBegin: SonarQube Scanner for MSBuild - Begin Analysis Step:

MSBuild Scanner on Pipeline

Testing non regression on Jenkins 1 with test-sonarqube-jenkins-pipeline:jenkins1 Docker image:

SonarQube Scanner for MSBuild and SonarQube Scanner installations must be configured at http://localhost:8080/configure

Tools configuration

To run Jenkins:

docker run --rm -p 2222:2222 -p 8080:8080 -p 8081:8081 -p 9418:9418 -ti test-sonarqube-jenkins-pipeline:jenkins1

Scanner on Freestyle

  • with a SonarQube Scanner for MSBuild - Begin Analysis Build Step:

MSBuild Scanner on Freestyle

Scanner General Build Step on Pipeline

  • with a sonarScannerMSBuildBegin: SonarQube Scanner for MSBuild - Begin Analysis Step:

MSBuild Scanner General Build Step on Pipeline

Please note that sonarScanner: Execute SonarQube Scanner and sonarScannerMSBuildBegin: SonarQube Scanner for MSBuild - Begin Analysis steps are not available on Jenkins 1 because it is a Jenkins 2 feature.

Validating with test-sonarqube-jenkins-pipeline:jenkins2-base Docker image:

As there is no SonarQube instance configured an error must be displayed in the Pipeline syntax editor

To run Jenkins:

docker run --rm -p 2222:2222 -p 8080:8080 -p 8081:8081 -p 9418:9418 -ti test-sonarqube-jenkins-pipeline:jenkins2-base

Validated using Pipeline syntax (Go to http://localhost:8080/job/pipeline-job/pipeline-syntax/)

SonarBuildWrapper without SQ

Validating with 1 Jenkins and 2 SonarQube:

Environment variable must be available and protected variable should not be seen By default the 1st instance of SonarQube must be used if not specified The SonarBuildWrapper must take a SonarQube installation when more than 1 are configured

To run Jenkins and SonarQube instances:

cd jenkins2/withSQ
docker-compose up
  • Validated running the SONARJNKNS-253 Jenkins job
    • the Check environment stage checks that we can access to environment variable (except protected ones)
    • the Analyse with default stage checks that the 1st instance of SonarQube is used when not defined
    • the Analyse with Localhost stage checks that the Localhost instance of SonarQube is used (result of analyse is available at http://localhost:9000/)
    • the Analyse with Other stage checks that the Other instance of SonarQube is used (result of analyse is available at http://localhost:9001/)

SonarBuildWrapper run with 2 SQ

SonarBuildWrapper Pipeline Syntax

Validating with test-sonarqube-jenkins-pipeline:jenkins2-base Docker image:

As there is no SonarQube Scanner instance configured an error must be displayed in the Pipeline syntax editor

To run Jenkins:

docker run --rm -p 2222:2222 -p 8080:8080 -p 8081:8081 -p 9418:9418 -ti test-sonarqube-jenkins-pipeline:jenkins2-base

Validated using Pipeline syntax (Go to http://localhost:8080/job/pipeline-job/pipeline-syntax/)

SonarScanner Pipeline Syntax

Validating with 1 Jenkins and 2 SonarQube and 2 SonarQube Scanner:

The arguments that are not set must be ignore from the step arguments, arguments set must be available in the parameters of the step By default the 1st instance of SonarQube must be used if not specified By default the 1st instance of SonarQube Scanner must be used if not specified By default the 1st instance of JDK tool must be used if not specified

To run Jenkins and SonarQube instances:

cd jenkins2/withSQ
docker-compose up

SonarScanner Pipeline Syntax

  • Validated running the SONARJNKNS-252 Jenkins job
    • the Analyse with default stage checks that the 1st instance of SonarQube is used when not defined, 1 instance of SonarQube Scanner is used when not specified, default JDK is used when not specified
    • the Analyse with Localhost and Scanner 2.8 stage checks that the Localhost instance of SonarQube is used (result of analyse is available at http://localhost:9000/) and SonarQube Scanner 2.8 is used
    • the Analyse with Other and Scanner 2.7 stage checks that the Other instance of SonarQube is used (result of analyse is available at http://localhost:9001/) and SonarQube Scanner 2.7 is used

SonarScanner run with 2 SQ

The project name and version fields no longer raise validation errors.

Validated with test-sonarqube-jenkins-pipeline:jenkins2-base Docker image using Pipeline syntax (Go to http://localhost:8080/job/pipeline-job/pipeline-syntax/)

To run Jenkins:

docker run --rm -p 2222:2222 -p 8080:8080 -p 8081:8081 -p 9418:9418 -ti test-sonarqube-jenkins-pipeline:jenkins2-base

Scanner for MSBuild project name and version

Validating with test-sonarqube-jenkins-pipeline:jenkins2-base Docker image:

As there is no SonarQube Scanner instance configured an error must be displayed in the Pipeline syntax editor

To run Jenkins:

docker run --rm -p 2222:2222 -p 8080:8080 -p 8081:8081 -p 9418:9418 -ti test-sonarqube-jenkins-pipeline:jenkins2-base

Validated using Pipeline syntax (Go to http://localhost:8080/job/pipeline-job/pipeline-syntax/)

SonarScanner for MSBuild Pipeline Syntax

Validating with 1 Jenkins and 2 SonarQube and 2 SonarQube Scanner:

The arguments that are not set must be ignore from the step arguments, arguments set must be available in the parameters of the step By default the 1st instance of SonarQube must be used if not specified By default the 1st instance of SonarQube Scanner for MSBuild must be used if not specified

To run Jenkins and SonarQube instances:

cd jenkins2/withSQ
docker-compose up

You need a windows slave with MSBuild and git configured to be able to run the next tests!

Not validated running the SONARJNKNS-254 Jenkins job: The sonarScannerMSBuildEnd() does not inherit from the envrionment.

  • the Before build with default and Analyse with default stages check that the 1st instance of SonarQube is used when not defined, 1 instance of SonarQube Scanner for MSBuild is used when not specified
  • the Before build with Localhost and SonarQube Scanner for MSBuild 2.1 and Analyse with Localhost and SonarQube Scanner for MSBuild 2.1 stages check that the Localhost instance of SonarQube is used (result of analyse is available at http://localhost:9000/) and SonarQube Scanner for MSBuild 2.1 is used
  • the Before build with Other and SonarQube Scanner for MSBuild 2.0 and Analyse with Other and SonarQube Scanner for MSBuild 2.0 stages check that the Other instance of SonarQube is used (result of analyse is available at http://localhost:9000/) and SonarQube Scanner for MSBuild 2.0 is used

SonarScanner for MSBuild run with 2 SQ

The sonar-scanner executable must be called JVM options should be passed using SONAR_SCANNER_OPTS No more deprecation messages in the logs

To run Jenkins and SonarQube instances:

cd jenkins2/withSQ
docker-compose up

Validated running the SONARJNKNS-264 Jenkins job

SonarScanner executable

The environment variable SONARQUBE_SCANNER_PARAMS must be populated

To run Jenkins and SonarQube instances:

cd jenkins2/withSQ
docker-compose up

Validated running the SONARJNKNS-263 Jenkins job

SONARQUBE_SCANNER_PARAMS enviornment variable

Validated with test-sonarqube-jenkins-pipeline:jenkins2-base Docker image using Pipeline syntax (Go to http://localhost:8080/job/pipeline-job/pipeline-syntax/)

To run Jenkins:

docker run --rm -p 2222:2222 -p 8080:8080 -p 8081:8081 -p 9418:9418 -ti test-sonarqube-jenkins-pipeline:jenkins2-base

Scanner for MSBuild Additional command line arguments

Also validated for any other Scanner

TODO

Thoughts

Would be cool to automatically add the property -Dsonar.links.ci=${env.JOB_URL} which create the links from the SonarQube project to the Jenkins job.