tracking code quality with Sonar on Android.
The problematic remains the same: quality is often overlooked for mobile Apps and the cost of setting up a proper quality tracking environment is usually deemed too high. This article will focus on showing that, while the iOS platform is not as tooled as Android, it's now fast and easy to track code quality on iOS projects.
Even though this has been possible in the past mostly using Java tools (see a preceding post on tracking iOS code quality with Jenkins), it has often been limited to big projects where a quality process has to be enforced (and sometimes some metrics were even part of the contract - even if I am not a big fan of this). The main limitation was in that case the time and expertise to set everything up.
This article follows a presentation we held at soft-shake last October.
//www.slideshare.net/slideshow/embed_code/27638272
Make use of Sonar for your mobile developments - It's easy and useful! from cyrilpicat
For the uninitiated, SonarQube is a continuous quality analysis platform running as a web server that tracks metrics regarding your code and its structure. It can be extended through plugins, and usually embeds useful tools and checks. Historically SonarQube only dealt with Java code but it has been extended since, and it handles most common languages as of today (available features may vary).
Our use case being an iOS application, we are wandering far away from the Java world and there is no official support of this language by SonarSource. Romain Felden and I created a dedicated community plugin - Sonar Objective-C plugin - that enables Objective-C project analysis.
Quite a few tools will have to be installed on your computer, this is clearly the most time-consuming part. Hopefully you will have to do that only once on your CI server (or locally on your workstation):
Tip: You may need to go wild and install a development version of OCLint (0.8/0.9) as in my experience, the stable 0.7 version had blockers on my projects
Situation is easier than for Android because there is actually only one build tool: Xcode.
The only things you should do are:
The run-sonar.sh file will stay untouched. You should then describe your project in the sonar-project.properties file, via the following properties:
Tip: Comment sonar.objectivec.testScheme if you have no unit/UI tests in your application
After some research, I stumbled upon the iOctoCat open-source application. Despite its name, it has nothing to do with OCTO. It's an old iOS client for GitHub (by GitHub). This application is interesting because it's non-trivial, it has some tests (you're not misreading) and clean dependencies (with CocoaPods).
To push things even further, here is a fork of the repository cleaned up and fixed for the latest version of Xcode.
Unfortunately, nothing works out-of-the-box like in Android, where you can get first analysis results with no configuration at all! But there is no free lunch, is there?
Anyway you first need to configure the demo project. This is done with the following command lines:
git clone https://github.com/cyrilpicat/ioctocat
./bootstrap.sh
Tip: On a your own project, you don't have to build the project first, the plugin takes care of that. The bootstrap.sh script is a facility provided by iOctocat developers to download and build all the dependencies of iOctocat
You should configure the sonar-project.properties for this project. Here is what mine looks in the end (you can download the file from here):
##########################
##########################
sonar.projectKey=iOctocat sonar.projectName=iOctocat sonar.projectVersion=1.0 sonar.language=objc
sonar.projectDescription=(Old) GitHub client for iOS
sonar.sources=Classes
sonar.objectivec.workspace=iOctocat.xcworkspace sonar.objectivec.projects=iOctocat.xcodeproj sonar.objectivec.appScheme=iOctocat sonar.objectivec.testScheme=iOctocat Unit Tests
##########################
##########################
sonar.sourceEncoding=UTF-8
sonar.junit.reportsPath=sonar-reports/
sonar.objectivec.excludedPathsFromCoverage=.*Tests.*
Then you run the analysis on your project with the following command line (in your Xcode project root folder):
./run-sonar.sh
The dashboard you get is illustrated in the following picture:
If you look at it and compare to its Android counterpart, you will see that quite a few metrics are missing, like:
Your next question should be: fine it looks nice and easy but when are we going to have a full support for the Objective-C in SonarQube?
Well that's not an easy question, as the plugin is done mostly on our free time. But it's faster with real users: star the GitHub project and I am sure it will go faster!
Aside from this twisted answer, here is the plan as of today:
While I expect to have the first two quite soon, the latter is more my 6-12 months plan. Why so long? Because until now, the plugin was more about getting existing tools work smoothly and with no configuration. Now the hardest work begins: have SonarQube understand the Objective-C language.
Afterwards the plugin should be really useful, but still not as complete and integrated as a supported SonarQube plugin. I must say that on my side I have no plan to get it further the useful stage. But who knows, plans change!
Even if the analysis is still limited, it's nice you can get this analysis with no modification of the project at all. Personally I find it more easy to setup than its Android counterpart.
Either way, now you know how to get relevant metrics out of your neat iOS application in no time using Sonar. No more excuse for not using it on your own project, even if it is a indie iOS App.