Analyse de code statique par Checkstyle avec Java + Gradle

Aperçu

Checkstyle est exécuté à partir de Gradle et une analyse de code statique est effectuée lors de la génération et de la vérification. Si le résultat de l'analyse est NG, la génération sera abandonnée.

Checkstyle

GitHub URL

https://github.com/checkstyle/checkstyle

Raison de la sélection

Facile à installer. Google a officiellement fourni un fichier de configuration (XML) pour Google Java Style, qui est souvent utilisé dans les sources ouvertes de nos jours.

table des matières

  1. Ajouter une dépendance Checkstyle à build.gradle
  2. Placez checkstyle.xml

Ajout de la dépendance Checkstyle à build.gradle

Ajoutez ce qui suit.

//plugin checkstyle pour l'analyse de code statique avec checkstyle
apply plugin: 'checkstyle'

//checkstyleMain et checkstyleTest sont automatiquement exécutés par la vérification de gradle
//Puisque la vérification de gradle fonctionne également dans le cadre de la construction de gradle, le style de vérification est également exécuté lorsque la construction de gradle est exécutée sur CI.
def checkstyleVersion = '8.10.1'
checkstyle {
    configFile = file('checkstyle.xml')
    toolVersion = checkstyleVersion
    ignoreFailures = false
}

placement checkstyle.xml

Par défaut, il est placé dans src / main / resources, mais comme `` configFile = file ('checkstyle.xml') '' est spécifié dans le build.gradle ci-dessus, il est placé directement sous la racine du référentiel. .. J'ai fait référence à certaines méthodes de placement open source telles que RxJava.

contenu de checkstyle.xml

Le contenu est basé sur Google Java Style avec quelques modifications.

<?xml version="1.0"?>
<!DOCTYPE module PUBLIC
        "-//Checkstyle//DTD Checkstyle Configuration 1.3//EN"
        "https://checkstyle.org/dtds/configuration_1_3.dtd">

<!--Dessin modifié de Google Java Style
Valeurs d'indentation de 2 à 4,Changement de 4 à 8
Changer la gravité d'avertissement en erreur
-->

<!--
    Checkstyle configuration that checks the Google coding conventions from Google Java Style
    that can be found at https://google.github.io/styleguide/javaguide.html.

    Checkstyle is very configurable. Be sure to read the documentation at
    http://checkstyle.sf.net (or in your downloaded distribution).

    To completely disable a check, just comment it out or delete it from the file.

    Authors: Max Vetrenko, Ruslan Diachenko, Roman Ivanov.
 -->

<module name="Checker">
    <property name="charset" value="UTF-8"/>

    <property name="severity" value="error"/>

    <property name="fileExtensions" value="java, properties, xml"/>
    <!-- Checks for whitespace                               -->
    <!-- See http://checkstyle.sf.net/config_whitespace.html -->
    <module name="FileTabCharacter">
        <property name="eachLine" value="true"/>
    </module>

    <module name="TreeWalker">
        <module name="OuterTypeFilename"/>
        <module name="IllegalTokenText">
            <property name="tokens" value="STRING_LITERAL, CHAR_LITERAL"/>
            <property name="format"
                      value="\\u00(09|0(a|A)|0(c|C)|0(d|D)|22|27|5(C|c))|\\(0(10|11|12|14|15|42|47)|134)"/>
            <property name="message"
                      value="Consider using special escape sequence instead of octal value or Unicode escaped value."/>
        </module>
        <module name="AvoidEscapedUnicodeCharacters">
            <property name="allowEscapesForControlCharacters" value="true"/>
            <property name="allowByTailComment" value="true"/>
            <property name="allowNonPrintableEscapes" value="true"/>
        </module>
        <module name="LineLength">
            <property name="max" value="100"/>
            <property name="ignorePattern" value="^package.*|^import.*|a href|href|http://|https://|ftp://"/>
        </module>
        <module name="AvoidStarImport"/>
        <module name="OneTopLevelClass"/>
        <module name="NoLineWrap"/>
        <module name="EmptyBlock">
            <property name="option" value="TEXT"/>
            <property name="tokens"
                      value="LITERAL_TRY, LITERAL_FINALLY, LITERAL_IF, LITERAL_ELSE, LITERAL_SWITCH"/>
        </module>
        <module name="NeedBraces"/>
        <module name="LeftCurly"/>
        <module name="RightCurly">
            <property name="id" value="RightCurlySame"/>
            <property name="tokens"
                      value="LITERAL_TRY, LITERAL_CATCH, LITERAL_FINALLY, LITERAL_IF, LITERAL_ELSE,
                    LITERAL_DO"/>
        </module>
        <module name="RightCurly">
            <property name="id" value="RightCurlyAlone"/>
            <property name="option" value="alone"/>
            <property name="tokens"
                      value="CLASS_DEF, METHOD_DEF, CTOR_DEF, LITERAL_FOR, LITERAL_WHILE, STATIC_INIT,
                    INSTANCE_INIT"/>
        </module>
        <module name="WhitespaceAround">
            <property name="allowEmptyConstructors" value="true"/>
            <property name="allowEmptyMethods" value="true"/>
            <property name="allowEmptyTypes" value="true"/>
            <property name="allowEmptyLoops" value="true"/>
            <message key="ws.notFollowed"
                     value="WhitespaceAround: ''{0}'' is not followed by whitespace. Empty blocks may only be represented as '{}' when not part of a multi-block statement (4.1.3)"/>
            <message key="ws.notPreceded"
                     value="WhitespaceAround: ''{0}'' is not preceded with whitespace."/>
        </module>
        <module name="OneStatementPerLine"/>
        <module name="MultipleVariableDeclarations"/>
        <module name="ArrayTypeStyle"/>
        <module name="MissingSwitchDefault"/>
        <module name="FallThrough"/>
        <module name="UpperEll"/>
        <module name="ModifierOrder"/>
        <module name="EmptyLineSeparator">
            <property name="allowNoEmptyLineBetweenFields" value="true"/>
        </module>
        <module name="SeparatorWrap">
            <property name="id" value="SeparatorWrapDot"/>
            <property name="tokens" value="DOT"/>
            <property name="option" value="nl"/>
        </module>
        <module name="SeparatorWrap">
            <property name="id" value="SeparatorWrapComma"/>
            <property name="tokens" value="COMMA"/>
            <property name="option" value="EOL"/>
        </module>
        <module name="SeparatorWrap">
            <!-- ELLIPSIS is EOL until https://github.com/google/styleguide/issues/258 -->
            <property name="id" value="SeparatorWrapEllipsis"/>
            <property name="tokens" value="ELLIPSIS"/>
            <property name="option" value="EOL"/>
        </module>
        <module name="SeparatorWrap">
            <!-- ARRAY_DECLARATOR is EOL until https://github.com/google/styleguide/issues/259 -->
            <property name="id" value="SeparatorWrapArrayDeclarator"/>
            <property name="tokens" value="ARRAY_DECLARATOR"/>
            <property name="option" value="EOL"/>
        </module>
        <module name="SeparatorWrap">
            <property name="id" value="SeparatorWrapMethodRef"/>
            <property name="tokens" value="METHOD_REF"/>
            <property name="option" value="nl"/>
        </module>
        <module name="PackageName">
            <property name="format" value="^[a-z]+(\.[a-z][a-z0-9]*)*$"/>
            <message key="name.invalidPattern"
                     value="Package name ''{0}'' must match pattern ''{1}''."/>
        </module>
        <module name="TypeName">
            <message key="name.invalidPattern"
                     value="Type name ''{0}'' must match pattern ''{1}''."/>
        </module>
        <module name="MemberName">
            <property name="format" value="^[a-z][a-z0-9][a-zA-Z0-9]*$"/>
            <message key="name.invalidPattern"
                     value="Member name ''{0}'' must match pattern ''{1}''."/>
        </module>
        <module name="ParameterName">
            <property name="format" value="^[a-z]([a-z0-9][a-zA-Z0-9]*)?$"/>
            <message key="name.invalidPattern"
                     value="Parameter name ''{0}'' must match pattern ''{1}''."/>
        </module>
        <module name="CatchParameterName">
            <property name="format" value="^[a-z]([a-z0-9][a-zA-Z0-9]*)?$"/>
            <message key="name.invalidPattern"
                     value="Catch parameter name ''{0}'' must match pattern ''{1}''."/>
        </module>
        <module name="LocalVariableName">
            <property name="tokens" value="VARIABLE_DEF"/>
            <property name="format" value="^[a-z]([a-z0-9][a-zA-Z0-9]*)?$"/>
            <message key="name.invalidPattern"
                     value="Local variable name ''{0}'' must match pattern ''{1}''."/>
        </module>
        <module name="ClassTypeParameterName">
            <property name="format" value="(^[A-Z][0-9]?)$|([A-Z][a-zA-Z0-9]*[T]$)"/>
            <message key="name.invalidPattern"
                     value="Class type name ''{0}'' must match pattern ''{1}''."/>
        </module>
        <module name="MethodTypeParameterName">
            <property name="format" value="(^[A-Z][0-9]?)$|([A-Z][a-zA-Z0-9]*[T]$)"/>
            <message key="name.invalidPattern"
                     value="Method type name ''{0}'' must match pattern ''{1}''."/>
        </module>
        <module name="InterfaceTypeParameterName">
            <property name="format" value="(^[A-Z][0-9]?)$|([A-Z][a-zA-Z0-9]*[T]$)"/>
            <message key="name.invalidPattern"
                     value="Interface type name ''{0}'' must match pattern ''{1}''."/>
        </module>
        <module name="NoFinalizer"/>
        <module name="GenericWhitespace">
            <message key="ws.followed"
                     value="GenericWhitespace ''{0}'' is followed by whitespace."/>
            <message key="ws.preceded"
                     value="GenericWhitespace ''{0}'' is preceded with whitespace."/>
            <message key="ws.illegalFollow"
                     value="GenericWhitespace ''{0}'' should followed by whitespace."/>
            <message key="ws.notPreceded"
                     value="GenericWhitespace ''{0}'' is not preceded with whitespace."/>
        </module>
        <module name="Indentation">
            <property name="basicOffset" value="4"/>
            <property name="braceAdjustment" value="0"/>
            <property name="caseIndent" value="4"/>
            <property name="throwsIndent" value="8"/>
            <property name="lineWrappingIndentation" value="8"/>
            <property name="arrayInitIndent" value="4"/>
        </module>
        <module name="AbbreviationAsWordInName">
            <property name="ignoreFinal" value="false"/>
            <property name="allowedAbbreviationLength" value="1"/>
        </module>
        <module name="OverloadMethodsDeclarationOrder"/>
        <module name="VariableDeclarationUsageDistance"/>
        <module name="CustomImportOrder">
            <property name="sortImportsInGroupAlphabetically" value="true"/>
            <property name="separateLineBetweenGroups" value="true"/>
            <property name="customImportOrderRules" value="STATIC###THIRD_PARTY_PACKAGE"/>
        </module>
        <module name="MethodParamPad"/>
        <module name="NoWhitespaceBefore">
            <property name="tokens"
                      value="COMMA, SEMI, POST_INC, POST_DEC, DOT, ELLIPSIS, METHOD_REF"/>
            <property name="allowLineBreaks" value="true"/>
        </module>
        <module name="ParenPad"/>
        <module name="OperatorWrap">
            <property name="option" value="NL"/>
            <property name="tokens"
                      value="BAND, BOR, BSR, BXOR, DIV, EQUAL, GE, GT, LAND, LE, LITERAL_INSTANCEOF, LOR,
                    LT, MINUS, MOD, NOT_EQUAL, PLUS, QUESTION, SL, SR, STAR, METHOD_REF "/>
        </module>
        <module name="AnnotationLocation">
            <property name="id" value="AnnotationLocationMostCases"/>
            <property name="tokens"
                      value="CLASS_DEF, INTERFACE_DEF, ENUM_DEF, METHOD_DEF, CTOR_DEF"/>
        </module>
        <module name="AnnotationLocation">
            <property name="id" value="AnnotationLocationVariables"/>
            <property name="tokens" value="VARIABLE_DEF"/>
            <property name="allowSamelineMultipleAnnotations" value="true"/>
        </module>
        <module name="NonEmptyAtclauseDescription"/>
        <module name="JavadocTagContinuationIndentation"/>
        <module name="SummaryJavadoc">
            <property name="forbiddenSummaryFragments"
                      value="^@return the *|^This method returns |^A [{]@code [a-zA-Z0-9]+[}](isa)"/>
        </module>
        <module name="JavadocParagraph"/>
        <module name="AtclauseOrder">
            <property name="tagOrder" value="@param, @return, @throws, @deprecated"/>
            <property name="target"
                      value="CLASS_DEF, INTERFACE_DEF, ENUM_DEF, METHOD_DEF, CTOR_DEF, VARIABLE_DEF"/>
        </module>
        <module name="JavadocMethod">
            <property name="scope" value="public"/>
            <property name="allowMissingParamTags" value="true"/>
            <property name="allowMissingThrowsTags" value="true"/>
            <property name="allowMissingReturnTag" value="true"/>
            <property name="minLineCount" value="2"/>
            <property name="allowedAnnotations" value="Override, Test"/>
            <property name="allowThrowsTagsForSubclasses" value="true"/>
        </module>
        <module name="MethodName">
            <property name="format" value="^[a-z][a-z0-9][a-zA-Z0-9_]*$"/>
            <message key="name.invalidPattern"
                     value="Method name ''{0}'' must match pattern ''{1}''."/>
        </module>
        <module name="SingleLineJavadoc">
            <property name="ignoreInlineTags" value="false"/>
        </module>
        <module name="EmptyCatchBlock">
            <property name="exceptionVariableName" value="expected"/>
        </module>
        <module name="CommentsIndentation"/>
    </module>
</module>

Recommended Posts

Analyse de code statique par Checkstyle avec Java + Gradle
Analyse morphologique en Java avec Kuromoji
Utilisez des outils d'analyse statique dans votre projet Gradle
En utilisant Gradle avec VSCode, compilez Java → exécutez
Inclure l'image dans le fichier jar avec la méthode statique java
Vérifiez la couverture avec Codecov dans la configuration Java + Gradle + Wercker
Créer un multi-projet Java avec Gradle
[Java] JavaConfig avec classe interne statique
Analyse de sujets (LDA) en Java
Java avec Visual Studio Code
Écrire du code de type Java8 en Java8
Agrégation et analyse de journaux (utilisation d'AWS Athena en Java)
Erreur de compilation Java améliorée avec l'outil d'analyse statique ErrorProne
Devinez le code de caractère en Java
Construire un projet Java avec Gradle
Faites HelloWorld avec Java / IntelliJ / Gradle
Coder Java depuis Emacs avec Eclim
Construire Java avec Mac vs Code
Exécuter du code Java packagé avec des commandes
Faire une analyse de phrase en Java 8 (partie 2)
1 Implémentez une analyse de phrase simple en Java
Tweak Markdown avec Java flexmark-java
Création d'une analyse de phrase dans Java 8 (partie 1)
Bonjour tout le monde en Java et Gradle
Revue de code facile pour démarrer avec Jenkins / SonarQube: analyse statique
Préparer l'environnement de développement Java avec VS Code
[Java] Créer un module exécutable avec Gradle
Java statique
Lier le code Java et C ++ avec SWIG
Méthode de concurrence en Java avec exemple de base
Application Java CICS-Run - (3) Gestion de build avec Gradle
[JaCoCo (Java Code Coverage)] Utilisation avec NetBeans
Lire le fichier xlsx en Java avec Selenium
Toutes les mêmes chaînes de code de hachage en Java
Diviser une chaîne avec ". (Dot)" en Java
Gérez d'énormes JSON avec Java Lambda
Configurer un multi-projet avec des sous-répertoires dans Gradle
Présentation du test Java automatisé avec JUnit 5 + Gradle
[Mac] Installer Java dans Visual Studio Code
Exécutez du code Java à partir de cpp sur cocos2dx
Essayez le débogage à distance Java avec des conteneurs distants dans Visual Studio Code Insiders
Exécuter l'analyse statique Infer dans l'environnement Windows
Dans certains cas, j'ai créé du code Java natif avec GraalVM mais je ne l'ai pas accéléré
Lire une chaîne dans un fichier PDF avec Java
Créer un CSR avec des informations étendues en Java
Ajouter l'option --enable-preview dans Java dans Visual Studio Code
Outil GUI refactorisé réalisé avec Java8 + JavaFX en 2016
Techniques de lecture du code source Java dans Eclipse
[Gradle] Opérations de construction souvent effectuées dans les projets Java
Code pour échapper aux chaînes JSON en Java
Créez et testez des applications Java + Gradle avec Wercker
Essayez d'utiliser Sourcetrail (version win) avec du code Java
Extraction de texte en Java à partir de PDF avec pdfbox-2.0.8
Essayez d'utiliser Sourcetrail (version macOS) avec du code Java
Couverture de code Java plus confortable avec Jacoco 0.8.0
Modifier dynamiquement les champs finaux statiques privés en Java
Vérifier le comportement statique et public dans les méthodes Java
Conseils Java - Créez un projet Spring Boot avec Gradle
[AtCoder Problem-ABC001] Observation du vent C-Do en Java [Code]