Running Sonar on iOS (Objective-C) Projects with Gradle
September 8, 2014After getting the basics out of the way on setting up Sonarqube on Mac OSX, one has to invoke it somehow. We settled on building our iOS project with Gradle, and as such, are using the sonarRunner plugin for Gradle to fire up the Sonar analysis.
Making the Sonar Gradle Plugin Work
Getting the SonarQube plugin for Gradle to work was pretty straightforward.
In your build.gradle file, first insert:
apply plugin: "sonar-runner"
Then, define Sonar properties for Objective-C analysis as follows:
// Sonar Properties for Objective-C sonarRunner { sonarProperties { property "sonar.host.url", "http://sonarbox.mycompanyname.com:9000/" property "sonar.jdbc.url", "jdbc:mysql://sonarbox.mycompanyname.com/sonar" property "sonar.jdbc.driverClassName", "com.mysql.jdbc.Driver" property "sonar.jdbc.username", "sonar" property "sonar.jdbc.password", "sonar" property "sonar.language", "objc" property "sonar.projectKey", "org.codehaus.sonar:superdandymobile-objc-project" property "sonar.projectName", "SuperDandy Mobile" property "sonar.sources", "src" property "sonar.cfamily.gcov.reportsPath", "output" } }
This will then give you a target when invoking the Gradle wrapper of “sonarRunner”, such that you can just execute:
macmini-superdandy04:trunk administrator$ ./gradlew sonarRunner --info
And this will go about downloading the needful dependencies to make the SonarQube plugin work, and will then insert the analysis data into Sonar.
Making GCov Test Coverage Reports Work
Now, the above analysis worked pretty trouble free for me. However, as noted in the docs for the SonarSource Objective-C plugin, the plugin will not, out of the box, give you test coverage / code coverage reports.
You’ll first have to get the xcode project to generate the gcno/gcda code coverage reports as covered here.
Then, execute something like the following to get the gcov files generated from that:
macmini-superdandy04:output administrator$ find . -type f | xargs -I {} xcrun gcov {}
That final line in the sonar properties is meant to then tell it where to look for the gcov reports:
property "sonar.cfamily.gcov.reportsPath", "output"
EDIT: Just found out that despite code coverage and ingest of gcov files being mentioned in their documentation, the C++/Objective-C plugin for SonarQube presently does not do code/test coverage reporting for Objective-C. This is actively under development, meant to release in October 2014.
We are also planning to use gradle to run sonar for objective C, but as per the documentation here
http://www.sonarsource.com/products/plugins/languages/c-cpp-objectivec/installation-and-usage/
we need to run build-wrapper before sonar-runner, can you please share how you guys were able to do it using gradle.
We’re not using the build wrapper on our build. I have a separate Gradle task which makes the GCOV files out of the Obj-C project, and then saves them out to an output directory. Then, I run the sonarRunner as above (using the Gradle Sonar plugin) to run the Sonar analysis. I have to use the older 3.7 LTS version of Sonar, as we’re still on a pre 2.0 version of Gradle, and it’s only (at this point) the 2.2x builds of gradle that support switching out the SonarRunner plugin for one that will support the newer API that’s used in the newest version of SonarQube.
Thanks @Tad Reeves for your response.