SonarQube配置自定义的CheckStyle代码规则

对于自定义的CheckStyle代码规则如何配置到SonarQube?网上找了很久,也没找到多少有用的信息,没办法,自己撸吧。一通撸下来发现,其实挺简单 (⊙▽⊙)

惯例第一步肯定是SonarQube的安装与运行配置了,但这部分不在本文主题内,网上一搜一大把,这里就不讲了,大家可以先看这篇文章:SonarQube的安装、配置与使用
。我们直接讲自定义CheckStyle代码规则的配置方法。
(:不同的SonarQube版本可能略有不同,大家按线索来)

1、CheckStyle插件安装(熟悉的可跳过)

CheckStyle插件安装操作步骤

如图所示,在应用市场中搜索CheckStyle即可,搜索出来后,点击安装按钮(我这里已经安装了,未安装的情况再卸载按钮的地方会有安装按钮),即可下载安装,安装过程中会有一次重启操作,大家按提示操作即可。
:有些版本的SonarQube插件安装是在配置-系统-更新中心

2、配置自定义的CheckStyle代码规则

配置自定义的CheckStyle代码规则,有两种方法,使用CheckStyle代码规则配置文件启用SonarQube中的CheckStyle相关代码规则,下面一一介绍:

  • 使用CheckStyle代码规则配置文件
    注意:这种方法只有新建一个质量配置时才能用,质量配置创建好后,就不能利用配置文件来配置代码规则了。


    按照上面两个图,填写好相关信息后,点击创建按钮。这里有几个问题需要注意下:
    • 问题一 配置文件不能以<?xml version="1.0" encoding="UTF-8"?>开头,否则点击创建按钮时会有如下错误提示:

      配置文件中有<?xml?>标签

      因此要把此标签去掉,直接以<module>标签开头,如下图所示:
      配置文件去掉xml文件头标签

    • 问题二 配置文件中不能有重复的规则,否则点击创建按钮时,会有报错提示,比如:

      重复规则错误提示
      上图中提示ReturnCountCheck进行了重复配置,看一下配置文件
      这里我们需要对构造函数和lambda表达式的返回语句个数进行不同的配置,但是SonarQube认为是重复的配置。┑( ̄Д  ̄)┍

    • 问题三 配置文件中不能有规则模板(规则模板后面介绍),当配置文件中有规则模板,点击创建按钮时,会有报错提示,比如:

      `规则模板`错误提示
      上图错误提示的意思是:规则模板checkstyle:com.puppycrawl.tools.checkstyle.checks.coding.FinalLocalVariableCheck不能被激活。这条规则是检测从未改变的局部变量是否添加final修饰词,那么如果我们需要添加这条规则,怎么处理呢?留到启用SonarQube中CheckStyle相关代码规则方法去说。

通过使用配置文件的方法配置自定义的CheckStyle代码规则,或多或少还会有其它问题,要根据提示处理配置文件。所以,一般情况下,不建议使用这种方法,事倍功半的说。╥﹏╥

  • 启用SonarQube中CheckStyle相关代码规则

    如图所示,在质量配置中会显示SonarQube中所有已安装编程语言中创建好的规则配置(每个语言都有内置Sonar way的默认配置),可见,刚刚创建的CheckStyle配置中,通过文件已配置了18条规则,接下来我们再进行添加。点击配置名称,进入配置详情页:
    质量配置详情
    点击更多激活规则
    可激活规则列表
    上图中左边栏的用于筛选的,可从语言、规则类型、标签、资源库等等进行筛选,这里我们要用到资源库的筛选,选中资源库后,会列举出已安装的插件列表,选中CheckStyle,页面中会筛选出CheckStyle的可配置规则(上图已经筛选好了,显示有136条可配置的规则)。

    接下来就可以对这136条规则进行配置了,细心的同学可能已经发现了,规则列表中的规则有两类:非模板规则(有活动按钮,无规则模板的标签)和模板规则(无活动按钮,有规则模板的标签)。所以,我们也分两类讲:

    • 非模板规则
      对于非模板规则,我们直接在规则列表中点击列表项的活动按钮即可,在弹出的对话框中填写属性值,如下图所示:
      激活非模板规则
      如果想先了解下规则的内容,也可以先点击规则名称进入详情页,详情页也有激活的入口。
    • 规则模板
      对于规则模板,是没有直接的激活按钮的。那么规则模板怎么激活呢?且听下回分解……O(∩_∩)O哈哈~(玩笑脸)
      规则模板,需要我们先根据模板创建一条规则,之后再激活创建的规则。接下来说步骤(以上文说的规则模板Final Local Variable为例)
      • 在规则列表中找到这表规则,点击规则名称进入详情页
        规则详情页
      • 点击创建按钮,弹出自定义规则创建框
        创建自定义规则
        根据提示填写相关信息后(子属性根据需要进行填写,不填则使用默认值),点击创建按钮。
        创建成功的规则如下图所示:
        在自定义规则下面会有一个创建的规则列表。此时回到之前的规则列表后,会在列表中找到刚刚创建的规则,点击列表项的活动即可激活。其次,也可以在此页面点击自定义的规则名称,进入详情页
        自定义规则详情页
        在此页面中,可以进行二次编辑删除激活等操作。

配置好后,可在配置详情页中点击CheckStyle的链接,以XML的格式查看已配置好的规则,如下图所示:


配置好的CheckStyle规则

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

推荐阅读更多精彩内容