• 0
  • 1
分享
  • 代码质量和安全性测试工具SonarQube——软件测试圈
  • 曼倩诙谐 2023-06-14 14:33:53 字数 1825 阅读 6185 收藏 1

  SonarQube 是一个开源的代码分析平台, 用来持续分析和评测项目源代码的质量。 通过SonarQube我们可以检测出项目中重复代码, 潜在bug, 代码规范,安全性漏洞等问题, 并通过SonarQube web UI展示出来。

  1 Sonar简介

  1.1 sonarQube是什么?

  1、代码质量和安全扫描和分析平台。

  2、多维度分析代码:代码量、安全隐患、编写规范隐患、重复度、复杂度、代码增量、测试覆盖率等。

  3、支持25+编程语言的代码扫描和分析,包含java\python\C#\javascript\go\C++等。

  4、涵盖了编程语言的静态扫描规则: 代码编写规范+安全规范。

  5、能够与代码编辑器、CI/CD平台完美集成。

  6、能够与SCM集成,可以直接在平台上看到代码问题是由哪位开发人员提交。

  7、帮助程序猿写出更干净、更安全的代码。

  静态扫描主要针对开发人员编写的源代码。

  通过定义好的 代码质量和安全规则,对开发人员编写的代码进行扫描和分析。

  将分析的结果多维护的呈现出来,以方便开发人员进行代码的优化和规范编写。

  1.2 sonarQube如何工作?

  sonar静态代码扫描由2部分组成:sonarQube平台,sonar-scanner扫描器。

  sonarQube: web界面管理平台。

  1)展示所有的项目代码的质量数据。

  2)配置质量规则、管理项目、配置通知、配置SCM等。

  sonarScanner: 代码扫描工具。

  专门用来扫描和分析项目代码。支持20+语言。

  代码扫描和分析完成之后,会将扫描结果存储到数据库当中,在sonarQube平台可以看到扫描数据。

  sonarQube和sonarScanner之间的关系:

1-1.png

  2 检测

  Sonar是一个用于代码质量管理的开源平台,用于管理源代码的质量,可以从七个维度检测代码质量。

  通过插件形式,可以支持包括java,C#,C/C++,PL/SQL,Cobol,JavaScrip,Groovy等等二十几种编程语言的代码质量管理与检测。

  2.1 Rules提示

  当然,这对于初学开发者来说是一个很好的教程,搞懂这些规则可以避免bugs的出现,提供自己的开发能力。

  2.1.1 Rule界面

1-2.png

  2.1.2 rule正确实例提示

1-3.png

  2.2 糟糕的复杂度分布

  文件、类、方法等,如果复杂度过高将难以改变,这会使得开发人员难以理解它们, 且如果没有自动化的单元测试,对于程序中的任何组件的改变都将可能导致需要全面的回归测试。

1-4.png

  2.3 重复

  显然程序中包含大量复制粘贴的代码是质量低下的 , sonar可以展示源码中重复严重的地方。

1-5.png

  2.4 缺乏单元测试

  sonar可以很方便地统计并展示单元测试覆盖率。

1-6.png

  2.5 没有代码标准

  sonar可以通过PMD,CheckStyle,Findbugs等等代码规则检测工具规范代码编写。

  2.6 没有足够的或者过多的注释

  没有注释将使代码可读性变差,特别是当不可避免地出现人员变动时,程序的可读性将大幅下降,而过多的注释又会使得开发人员将精力过多地花费在阅读注释上,亦违背初衷。

  2.7 潜在的bug

  sonar可以通过PMD,CheckStyle,Findbugs等等代码规则检测工具检测出潜在的bug。

1-7.png

  2.8 糟糕的设计(原文Spaghetti Design,意大利面式设计)

  通过sonar可以找出循环,展示包与包、类与类之间的相互依赖关系,可以检测自定义的架构规则;

  通过sonar可以管理第三方的jar包可以利用LCOM4检测单个任务规则的应用情况 ,检测耦合。

  3. Sonar 组成

1-8.png

  4. Sonar 集成过程

1-9.png

  开发人员在他们的ide中使用SonarLint运行分析本地代码。

  开发人员将他们的代码提交到代码管理平台中(SVN,GIT等)。

  持续集成工具自动触发构建,调用SonarScanner对项目代码进行扫描分析。

  分析报告发送到SonarQube Server中进行加工。

  SonarQube Server 加工并且保存分析报告到SonarQube Database中,通过UI显示分析报告。


作者:会跑的熊    

来源:http://www.51testing.com/html/14/n-7793014.html

  • 【留下美好印记】
    赞赏支持
登录 后发表评论
+ 关注

热门文章

    最新讲堂

      • 推荐阅读
      • 换一换
          • 1、 强制等待时间 sleep()必须import time包,强制等待生效时间=页面跳转时间+sleep()设置休眠时间强制等待时间使用语法:sleep(s) s表示时间,以秒为单位 例:sleep(2) 休眠3s2、显示等待时间 WebDriverWait()必须导入WebDriverWait包才可以使用,显示等待时间是针对单个元素生效的,当在规定时间内找到了对应元素,则执行下一步操作。显示等待时间使用语法:WebDriverWait(x,y,z).until(lambda x:x.find_element_by_元素定位方法("对应元素方法的值"))x表示网页窗口对象...
            0 0 722
            分享
          •   前言  不管怎样,面试或者被面试和简历有着理不清的关系,面试官要通过简历了解面试者的基本信息、过往经历等。  面试者希望通过简历把自己最好的一面体现给面试官,所以在这场博弈中,作为面试者,需要掌握一定的技巧,写出一个高质量的简历,才能抓住面试官的眼光。  假如你是网上发出简历,你的简历必然会经过 HR 的筛选,一张简历 HR 可能也就花费 10 秒钟看一下,然后 HR 就会决定你这一关是 Fail 还是 Pass。  假如你是内推,如果你的简历没有什么优势的话,就算是内推你的人再用心,也无能为力。  一份好的简历  一份好的简历,可以给人的第一印象大大提升,那么我们如何准备一份高质量的简历...
            0 0 221
            分享
          • 在小程序上线之前,我们是需要先给小程序进行的,小程序只有通过测试之后,才可以上线。小程序要测试的内容有权限测试、功能测试、界面测试、渗透测试、小程序加固以及安全检测等,接下来就先了解下渗透测试、小程序加固以及安全检测。小程序测试在进行小程序渗透测试,通过模拟黑客攻击的形式,对小程序业务系统进行渗透测试,发现可导致业务数据泄露,资产受损、数据被篡改等各类安全风险。在测试阶段发现高风险漏洞,提早进行修复,尽早避免因代码漏洞造成的安全风险及资产损失,针对小程序业务逻辑安全以及WEB框架安全进行深度漏洞挖掘。安全检测安全检测是专门针对小程序前端和后台Web端整体的提供的自动化风险检测工具,覆盖前台代码...
            0 0 844
            分享
          • 虽然现在 Git 已经很普及,但是我相信用 SVN 的公司仍然不少,那么作为 SVN 配置管理员的话,就不可避免的涉及到账号维护的问题,今天我们就说说如何通过 Python 脚本实现用户的快捷维护。 如果手动维护用户,一般需要三个步骤:1.手动添加用户2.手动设置属组3.通知用户设置结果 使用脚本后也是三步,但是效率却大大提升:1.输入用户名2.输入要设置的组名3.按下回车,搞定 这里面设置用户和属组是关键点,也是我们需要自动化起来的操作,下面分别给出实现的代码: def add_user(user_name): """如果用户不存在则调用htpasswd.exe添加用户""" ...
            1 2 2196
            分享
          •   测试用例设计技术和方法,其目的是为了解决测试分析与设计过程中碰到的问题,纯粹的理论只是应用技术和方法的基础,但不是目的。测试用例分析与设计过程,需要我们不断的应用结构化思维、发散性思维和可视化思维,以构建系统化的测试分析与设计框架。  我将我写的《软件测试设计》书中的一些测试用例技术与方法的思维导图分享给大家,希望对大家有所帮助。测试用例分析与设计过程中,大家需要注意的是:  1、解决问题是目的,技术与方法是帮助解决问题的基础,但不要本末倒置;  2、通过分析与设计得到测试用例的过程,必须要在其中构建测试模型,其中的主要输入来自被测对象的领域知识和题主所说的测试技术与方法;  3、每个测试...
            11 11 2231
            分享
      • 51testing软件测试圈微信