Jenkins——静态检查checkstyle自定义代码检查

  1. pom的配置
    a) 在<build>里增加checkstyle配置,代码如下:
<plugin>  
    <groupId>org.apache.maven.plugins</groupId>  
    <artifactId>maven-checkstyle-plugin</artifactId>  
    <version>2.17</version>
    <configuration>
        <consoleOutput>ture</consoleOutput>
        <outputFileFormat>xml</outputFileFormat>
        <configLocation>eidlink_checks.xml</configLocation>
        <linkXRef>ture</linkXRef>
    </configuration>
</plugin>

b) 在<reporting>里增加checkstyle的报告生存配置,代码如下:

<plugin>
    <groupId>org.apache.maven.plugins</groupId>
    <artifactId>maven-checkstyle-plugin</artifactId>
    <version>2.17</version>
    <configuration>
        <configLocation>checkstyle.xml</configLocation>
    </configuration>
</plugin>
  1. 定义本公司checkstyle规则
    checkstyle默认使用sun_checks.xml或者google_checks.xml,规则定义比较严格,在实际使用中进行了取舍。
<?xml version="1.0"?>
<!DOCTYPE module PUBLIC
         "-//Puppy Crawl//DTD Check Configuration 1.3//EN"
         "http://www.puppycrawl.com/dtds/configuration_1_3.dtd">

<!--

 Checkstyle configuration that checks the sun coding conventions from:

   - the Java Language Specification at
     http://java.sun.com/docs/books/jls/second_edition/html/index.html

   - the Sun Code Conventions at http://java.sun.com/docs/codeconv/

   - the Javadoc guidelines at
     http://java.sun.com/j2se/javadoc/writingdoccomments/index.html

   - the JDK Api documentation http://java.sun.com/j2se/docs/api/index.html

   - some best practices

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

 Most Checks are configurable, be sure to consult the documentation.

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

 Finally, it is worth reading the documentation.

-->

<module name="Checker">
   <property name="severity" value="warning"/>

   <!-- Checks that a package-info.java file exists for each package.     -->
   <!-- See http://checkstyle.sf.net/config_javadoc.html#JavadocPackage -->
   <!-- <module name="JavadocPackage"/> -->

   <!-- Checks whether files end with a new line.                        -->
   <!-- See http://checkstyle.sf.net/config_misc.html#NewlineAtEndOfFile -->
   <!-- <module name="NewlineAtEndOfFile"> -->
       <!-- <property name="severity" value="ignore"/> -->
   <!-- </module> -->

   <!-- Checks that property files contain the same keys.         -->
   <!-- See http://checkstyle.sf.net/config_misc.html#Translation -->
   <!-- <module name="Translation"/> -->

   <!-- Checks for Size Violations.                    -->
   <!-- See http://checkstyle.sf.net/config_sizes.html -->
   <module name="FileLength"/>

   <!-- Checks for whitespace                               -->
   <!-- See http://checkstyle.sf.net/config_whitespace.html -->
   <!-- <module name="FileTabCharacter"> -->
       <!-- <property name="severity" value="ignore"/> -->
   <!-- </module> -->

   <!-- Miscellaneous other checks.                   -->
   <!-- See http://checkstyle.sf.net/config_misc.html -->
   <!-- <module name="RegexpSingleline"> -->
      <!-- <property name="severity" value="ignore"/> -->
      <!-- <property name="format" value="\s+$"/> -->
      <!-- <property name="minimum" value="0"/> -->
      <!-- <property name="maximum" value="0"/> -->
      <!-- <property name="message" value="Line has trailing spaces."/> -->
   <!-- </module> -->

   <!-- Checks for Headers                                -->
   <!-- See http://checkstyle.sf.net/config_header.html   -->
   <!-- <module name="Header"> -->
   <!--   <property name="headerFile" value="${checkstyle.header.file}"/> -->
   <!--   <property name="fileExtensions" value="java"/> -->
   <!-- </module> -->

   <module name="TreeWalker">
       <property name="tabWidth" value="4"/>

       <!-- Checks for Javadoc comments.                     -->
       <!-- See http://checkstyle.sf.net/config_javadoc.html -->
       <!-- <module name="JavadocMethod"> -->
           <!-- <property name="logLoadErrors" value="true"/> -->
           <!-- <property name="suppressLoadErrors" value="true"/> -->
       <!-- </module> -->
       <!-- <module name="JavadocType"/> -->
       <!-- <module name="JavadocVariable"/> -->
       <!-- <module name="JavadocStyle"/> -->


       <!-- Checks for Naming Conventions.                  -->
       <!-- See http://checkstyle.sf.net/config_naming.html -->
       <module name="ConstantName"/>
       <module name="LocalFinalVariableName"/>
       <module name="LocalVariableName"/>
       <module name="MemberName"/>
       <module name="MethodName"/>
       <module name="PackageName"/>
       <module name="ParameterName"/>
       <module name="StaticVariableName"/>
       <module name="TypeName"/>


       <!-- Checks for imports                              -->
       <!-- See http://checkstyle.sf.net/config_import.html -->
       <module name="AvoidStarImport"/>
       <!-- <module name="IllegalImport"/> --> <!-- defaults to sun.* packages --> 
       <module name="RedundantImport"/>
       <module name="UnusedImports"/>


       <!-- Checks for Size Violations.                    -->
       <!-- See http://checkstyle.sf.net/config_sizes.html -->
       <module name="LineLength">
           <property name="max" value="120"/>
       </module>
       <!-- <module name="MethodLength"/> -->
       <!-- <module name="ParameterNumber"/> -->


       <!-- Checks for whitespace                               -->
       <!-- See http://checkstyle.sf.net/config_whitespace.html -->
       <!-- <module name="EmptyForIteratorPad"/> -->
       <module name="GenericWhitespace"/>
       <module name="MethodParamPad"/>
       <!-- <module name="NoWhitespaceAfter"> -->
           <!-- <property name="tokens" value="BNOT,DEC,DOT,INC,LNOT,UNARY_MINUS,UNARY_PLUS"/> -->
       <!-- </module> -->
       <!-- <module name="NoWhitespaceBefore"/> -->
       <!-- <module name="OperatorWrap"/> -->
       <!-- <module name="ParenPad"/> -->
       <module name="TypecastParenPad"/>
       <!-- <module name="WhitespaceAfter"/> -->
       <!-- <module name="WhitespaceAround"> -->
           <!-- <property name="tokens" value="ASSIGN,BAND,BAND_ASSIGN,BOR,BOR_ASSIGN,BSR,BSR_ASSIGN,BXOR,BXOR_ASSIGN,COLON,DIV,DIV_ASSIGN,EQUAL,GE,GT,LAND,LCURLY,LE,LITERAL_ASSERT,LITERAL_CATCH,LITERAL_DO,LITERAL_ELSE,LITERAL_FINALLY,LITERAL_FOR,LITERAL_IF,LITERAL_RETURN,LITERAL_SYNCHRONIZED,LITERAL_TRY,LITERAL_WHILE,LOR,LT,MINUS,MINUS_ASSIGN,MOD,MOD_ASSIGN,NOT_EQUAL,PLUS,PLUS_ASSIGN,QUESTION,RCURLY,SL,SLIST,SL_ASSIGN,SR,SR_ASSIGN,STAR,STAR_ASSIGN,LITERAL_ASSERT,TYPE_EXTENSION_AND,WILDCARD_TYPE"/> -->
       <!-- </module> -->


       <!-- Modifier Checks                                    -->
       <!-- See http://checkstyle.sf.net/config_modifiers.html -->
       <module name="ModifierOrder"/>
       <module name="RedundantModifier"/>


       <!-- Checks for blocks. You know, those {}'s         -->
       <!-- See http://checkstyle.sf.net/config_blocks.html -->
       <module name="AvoidNestedBlocks"/>
       <module name="EmptyBlock"/>
       <module name="LeftCurly"/>
       <module name="NeedBraces"/>
       <module name="RightCurly"/>


       <!-- Checks for common coding problems               -->
       <!-- See http://checkstyle.sf.net/config_coding.html -->
       <module name="AvoidInlineConditionals"/>
       <module name="EmptyStatement"/>
       <module name="EqualsHashCode"/>
       <module name="HiddenField"/>
       <module name="IllegalInstantiation"/>
       <module name="InnerAssignment"/>
       <!-- <module name="MagicNumber"/> -->
       <module name="MissingSwitchDefault"/>
       <module name="SimplifyBooleanExpression"/>
       <module name="SimplifyBooleanReturn"/>

       <!-- Checks for class design                         -->
       <!-- See http://checkstyle.sf.net/config_design.html -->
       <module name="DesignForExtension"/>
       <module name="FinalClass"/>
       <module name="HideUtilityClassConstructor"/>
       <module name="InterfaceIsType"/>
       <module name="VisibilityModifier"/>


       <!-- Miscellaneous other checks.                   -->
       <!-- See http://checkstyle.sf.net/config_misc.html -->
       <module name="ArrayTypeStyle"/>
       <module name="FinalParameters"/>
       <module name="TodoComment">
           <property name="severity" value="ignore"/>
       </module>
       <module name="UpperEll"/>
   </module>
</module>
  1. jenkins配置
    a) 安装插件Checkstyle Plug-in
    b) 增加构建步骤clean install checkstyle:checkstyle


    Paste_Image.png

    c) 增加构建后步骤,默认设置


    Paste_Image.png
  2. 查看检查报告
    趋势图:
Paste_Image.png

检查报告:

Paste_Image.png

【参考】
1、Jenkins+maven+checkstyle对java代码进行静态代码分析
2、maven配置checkstyle检查的自定义模块

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,012评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,628评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,653评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,485评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,574评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,590评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,596评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,340评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,794评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,102评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,276评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,940评论 5 339
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,583评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,201评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,441评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,173评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,136评论 2 352

推荐阅读更多精彩内容