android-check-2
android-check-2 copied to clipboard
Static code analysis plugin for next-generation Android projects.
Android Check 2
Static code analysis plugin for Android projects. This is a fork of the original android-check plugin, which implements a really useful concept, but unfortunately seems abandoned. Works for application, library and feature modules.
Current version tested with Android plugin for Gradle 3.1.3.
Who uses this?
Build status
master data:image/s3,"s3://crabby-images/06232/06232dbd1a65d3487d93002652e4d7626627d1e1" alt="master"
dev data:image/s3,"s3://crabby-images/dbb9c/dbb9ca7a96725918f5e561080de752907d21934f" alt="dev"
Usage
This plugin is available in the Gradle Plugin Portal. It attaches itself to the check
task, but you can also execute the corresponding tasks manually when desired: androidCheckstyle
for CheckStyle, and androidPmd
for PMD.
In order to add it to your project, you can use this snippet for Gradle 2.1 and later:
Kotlin
plugins {
id("org.stoyicker.android-check") version "+"
}
Groovy
plugins {
id "org.stoyicker.android-check" version "+"
}
Or this one for older Gradle versions or where dynamic configuration is required:
Kotlin
buildscript {
repositories {
gradlePluginPortal()
}
dependencies {
classpath("org.stoyicker.android-check:plugin:+")
}
}
apply(plugin = "org.stoyicker.android-check")
Groovy
buildscript {
repositories {
gradlePluginPortal()
}
dependencies {
classpath("org.stoyicker.android-check:plugin:+") {
// These are to avoid some conflicts with the Android plugin due to how classloading is performed by Gradle
// Only required before Gradle 4.8: https://github.com/gradle/gradle/issues/5092
exclude module: "asm"
exclude module: "gson"
exclude module: "guava"
exclude module: "commons-logging"
// This one is required because Checkstyle and PMD use different Saxon artifacts that have overlapping packages
// Also only required before Gradle < 4.8
exclude module: "Saxon-HE"
}
}
}
apply plugin: "org.stoyicker.android-check"
Configuration
Recommended
The default one.
Customized
Kotlin
// Configuration is completely optional, defaults will be used if not present
check {
// Do absolutely nothing, default: false
skip(true/false)
// Fails build if a violation is found, default: true. Ignored if all per-tool confs are set to abortOnError false (see below)
abortOnError(true/false)
// Checkstyle configuration
checkstyle {
// Completely skip Checkstyle, default: false
skip(true/false)
// Fails build if Checkstyle rule violations are found, default: false
abortOnError(true/false)
// Configuration file for Checkstyle, default: <project_path>/config/checkstyle.xml, if non-existent then <project_path>/<module_path>/config/checkstyle.xml, if non-existent then plugin/src/main/resources/checkstyle/conf-default.xml
config("path/to/config.xml")
// Output file for XML reports, default: File(project.buildDir, "outputs/checkstyle/checkstyle.xml")
reportXML(File(project.buildDir, "path/where/you/want/checkstyle.xml"))
// Output file for HTML reports, default: File(project.buildDir, "outputs/checkstyle/checkstyle.html")
reportHTML(File(project.buildDir, "path/where/you/want/checkstyle.html"))
}
// PMD configuration
pmd {
// Completely skip PMD, default: false
skip(true/false)
// Fails build if PMD rule violations are found, default: false
abortOnError(true/false)
// Configuration file for PMD, default: <project_path>/config/pmd.xml, if non-existent then <project_path>/<module_path>/config/pmd.xml, if non-existent then plugin/src/main/resources/pmd/conf-default.xml
config("path/to/config.xml")
// Output file for XML reports, default: File(project.buildDir, "outputs/pmd/pmd.xml")
reportXML(File(project.buildDir, "path/where/you/want/pmd.xml"))
// Output file for HTML reports, default: File(project.buildDir, "outputs/pmd/pmd.html")
reportHTML(File(project.buildDir, "path/where/you/want/pmd.html"))
}
}
Groovy
// Configuration is completely optional, defaults will be used if not present
check {
// Do absolutely nothing, default: false
skip(true/false)
// Fails build if a violation is found, default: true. Ignored if all per-tool confs are set to abortOnError false (see below)
abortOnError(true/false)
// Checkstyle configuration
checkstyle {
// Completely skip Checkstyle, default: false
skip(true/false)
// Fails build if Checkstyle rule violations are found, default: false
abortOnError(true/false)
// Configuration file for Checkstyle, default: <project_path>/config/checkstyle.xml, if non-existent then <project_path>/<module_path>/config/checkstyle.xml, if non-existent then plugin/src/main/resources/checkstyle/conf-default.xml
config("path/to/config.xml")
// Output file for XML reports, default: new File(project.buildDir, "outputs/checkstyle/checkstyle.xml")
reportXML(new File(project.buildDir, "path/where/you/want/checkstyle.xml"))
// Output file for HTML reports, default: new File(project.buildDir, "outputs/checkstyle/checkstyle.html")
reportHTML(new File(project.buildDir, "path/where/you/want/checkstyle.html"))
}
// PMD configuration
pmd {
// Completely skip PMD, default: false
skip(true/false)
// Fails build if PMD rule violations are found, default: false
abortOnError(true/false)
// Configuration file for PMD, default: <project_path>/config/pmd.xml, if non-existent then <project_path>/<module_path>/config/pmd.xml, if non-existent then plugin/src/main/resources/pmd/conf-default.xml
config("path/to/config.xml")
// Output file for XML reports, default: new File(project.buildDir, "outputs/pmd/pmd.xml")
reportXML(new File(project.buildDir, "path/where/you/want/pmd.xml"))
// Output file for HTML reports, default: new File(project.buildDir, "outputs/pmd/pmd.html")
reportHTML(new File(project.buildDir, "path/where/you/want/pmd.html"))
}
}
Also, if abortOnError
is true
, the browser will open the report for the tool that caused the failure (if your system supports it).
Developed By
The original version of this plugin was developed by:
This fork is owned and maintained by Jorge Antonio Diaz-Benito Soriano.
License
See LICENSE.txt.
Original work licensed under MIT license.