Um die Qualität unseres Codes (.Net C#) weiter zu verbessern haben wir eine Testinstallation von SonarQube vorgenommen. Ziel ist es zuerst mal aus dem VNext Build den Code in Sonar analysieren zu lassen und darzustellen. Ob wir später SonarQube als Quality Gate benutzen wird sich noch zeigen.
Die Installation von SonarQube ist recht einfach und auch sehr gut beschrieben. Wer nicht so viel lesen will kann sich den Quickstart Guide anschauen.
Unser Installationsumgebung ist Win Server 2012 R2 mit SQL Server 2014. Die Installation lief wie folgt ab:
Sql Server :
- Datenbank (sonar) anlegen
- Benutzer für Datenbank anlegen und entsprechend mit Rechten verstehen
- Benutzer in die Konfigdatei eintragen
SonarQube Server einrichten:
- Zip nach c:sonar entpakt
- Scanner für MSBuild hinzufügen
- C# Plugin hinzufügen -> Runterladen und unter C:\sonar\extensions\plugins legen.
- Starten oder als Service installieren (C\:sonar\bin\windows-x86-64)
– Starten „StartSonar.bat“ oder
– Service installieren (InstallNTService.bat) -> Service User noch ggf. anpassen
Vnext Build anpassen: Detaillierte Anleitung ist auf CodeWrecks zu finden
- Buildschritt „SonarQube for MSBuild – Begin Analysis“ direkt als ersten Schritt hinzufügen
– Project Key und Project Name eingeben -> werden automatisch in Sonar angelegt
– Wer eine History und Vergleichsmöglichkeit in Sonar haben möchte muss die Project Version dynamisch setzen. z.B. 1.$(Build.BuildNumber)
– Die anderen Felder können leer gelassen werden - Buildschritt „SonarQube for MSBuild – End Analysis“ am Ende hinzufügen
Der Build Agent muss auch noch die entsprechenden Anforderungen erfüllen Ein Blick in die Builddefinition -> Allgemein -> Anforderungen genügt.
Bei uns fehlte Java.
Falls nicht alle Anforderungen erfüllt sind kommt eine aussagekräftige Fehlermeldung.