- Docker
- Docker-compose
Here is a preview of project tree :
Ecocode # Root directory
|
+--java-plugin # JAVA
|
+--php-plugin # PHP
|
+--python-plugin # Python
|
\--docker-compose.yml # Docker compose fileYou will find more information about the plugins’ architecture in their folders
- Java >= 11.0.17
- Mvn 3
- SonarQube 9.4 to 9.8
You can build the project code by running the following command in the src directory.
Maven will download the required dependencies.
./tool_build.shEach plugin is generated in its own <plugin>/target directory, but they are also copied to the lib directory.
You must have built the plugins (see the steps above).
Run the SonarQube + PostgreSQL stack:
./tool_docker-init.shCheck if the containers are up:
docker psYou should see two lines (one for sonarqube and one for postgres). If there is only postgres, check the logs:
./tool_docker-logs.shIf you have this error on run:
web_1 | [1]: max virtual memory areas vm.max_map_count [65530] is too low, increase to at least [262144]
you can allocate more virtual memory:
sudo sysctl -w vm.max_map_count=262144For Windows:
wsl -d docker-desktop
sysctl -w vm.max_map_count=262144Go to http://localhost:9000 and use these credentials:
login: admin
password: adminWhen you are connected, generate a new token:
My Account -> Security -> Generate Tokens
Start again your services using the token:
TOKEN=MY_TOKEN docker-compose up --build -d# first clean all containers and resources used
./tool_docker-clean.sh
# then, install from scratch de SonarQube containers and resources
./tool_docker-init.shInstall dependencies from the root directory:
./tool_build.shResult : JAR files (one per plugin) will be copied in lib repository after build.
Once you did the installation a first time (and then you did custom configuration like quality gates, quality profiles, ...), if you only want to start (or stop properly) existing services :
./tool_start.sh
./tool_stop.sh- add release notes in
CHANGELOG.mdfile for next release- create a new section with title like
Release X.Y.Z- ... where
X.Y.Zis the new release - respect Keep a Changelog format
- ... where
- give empty
Unreleasedsection- in majority cases, old content of
Unreleasedsection is now the content of the newRelease X.Y.Zsection
- in majority cases, old content of
- add a new section at the bottom of file with new version
- update docker-compose.yml with new SNAPSHOT version
- commit these modifications
- create a new section with title like
- if all is ok, execute
tool_release_1_prepare.shto prepare locally the next release and next SNAPSHOT (creation of 2 new commits and a tag) - if all is ok, execute
tool_release_2_branch.shto create and push a new branch with that release and SNAPSHOT - if all is ok, on github, create a PR based on this new branch to
mainbranch - wait that automatic check on the new branch are OK, then check modifications and finally merge it
- if PR merge is OK, then delete the branch as mentionned when PR merged
- wait that automatic check on the
mainbranch are OK, and then if all is ok, upgrade your local source code from remote, and go tomainbranch and finally check locally if the new tag is already present on commit starting like[maven-release-plugin] prepare release .... The tag name is the version present in that commit message. The format isX.Y.Z(ex : 1.2.3)- create the new tag locally if not present on that commit
- push new tag with
git push --tags - an automatic workflow started on github and create the new release of plugin
- Add logs like in
java-plugin/src/main/java/fr/cnumr/java/checks/OptimizeReadFileExceptionsclass file - Build plugin JARs with
tool_build.sh - Launch local Sonar with
tool_docker_init.sh - Launch a sonar scanner on an exemple project with
mvn verifycommand (only the first time), followed bymvn org.sonarsource.scanner.maven:sonar-maven-plugin:3.9.1.2184:sonar -Dsonar.login=***** -Dsonar.password=***** -X - logs will appear in console (debug logs will appear if
-Xoption is given like above)
- Java how-to : https://github.com/SonarSource/sonar-java/blob/master/docs/CUSTOM_RULES_101.md
- Python how-to : https://github.com/SonarSource/sonar-custom-rules-examples/tree/master/python-custom-rules
- PHP how-to : https://github.com/SonarSource/sonar-custom-rules-examples/tree/master/php-custom-rules

