sonarsource
成功的组织在过程---分析向前移动, 并将其作为整个软件开发生命周期的一部分进行迭代。---开发和测试和业务方法以及正在向敏捷模型演进-持续的价值生成/持续改进/连续检查是提高的基本战略。idc 观察到, 传统的代码方法通常在开发过程结束时成为检查表项目时失败。此 idc 技术---讨论了改进软件分析、缺陷管理、安全性和度量的方法的---性, 以通过主动可见性来获得业务和 it 好处。idc 建议评估和采用自动化的软件分析方法, 如 sonarqube 和 sonarsource 提供的, 以改进软件策略。





如何在软件开发工作流中构建
远见卓识视图, 显示每个测试在运行时的执行时间
假设你是一个希望成长为一家中型科技公司的初创企业--介于30到100---之间。招聘是快速发生的, 而且你的代码数量也在快速增长。在较早的阶段, 贵公司---于证明产品。一切都是规模较小, 你可以循环快速。现在, 随着你的成长, 你有更多的在编写代码和更多的变量的组合。
这是当你注意到产品开始恶化, 你不能像你希望的那样快速发布代码。在扩展业务时, 有越来越多的变量需要进行调整, 您可能会忽略更多测试的需要, 并在测试上花费更多的时间。
如果你决定聘请一个 qa 经理, 而后者又带来了一批自动化---, 你就可以走出困境。硒测试的覆盖率---。但随着时间的推移, 事情又开始放慢了。所有的自动化和善意, 你建立了硒覆盖开始---和失败, 它反复暂停软件工厂。
我们开始的地方
当我加入 shutterstock 时, 我对公司的自动化测试覆盖率印象深刻。几乎每一个功能的网站上都有测试覆盖率的形式, 硒端对点测试。shutterstock 有一个开发工作流程的地方通过詹金斯, 将阻止部署到生产, 如果硒测试失败。我喜欢这样;这意味着除非所有的测试都通过了, 否则任何人都不能将任何东西放到生产中。
但不久之后,sonarqube修改检测规则, 我意识到, 我们的公司, 这是每天发布多次, 已经变成了一个公司, 现在被禁止发布多天一次, 主要是因为失败的硒测试。常见的情况是, 测试失败不是因为产品损坏, 而是因为它们很脆弱。
一些事情导致了这一点:
终端端 selenium-based 验收测试成为了每个人都依赖于测试的唯yi形式的自动化测试。许多团队甚至停止编写单元测试。
测试框架是片状的, 是由 qa 团队建立和拥有的。当某件事情失败, 整个软件工厂停止运转时, qa 团队中一小部分三到五人的错误就落在了我们身上, 他们经常被指责为放慢了组织的速度。
工程组织花了很多时间来研究如何构建一个可以扩展的产品, 但是没有足够的注意力去构建一个支持这种产品开发的开发工作流程。
完全由 qa 团队拥有。
在我们的, 我们有一个 qa 组织, 它没有与组织的其他部分进行扩展。虽然他们拥有自动化所有内容的技能, 但是他们缺乏构建可伸缩的测试框架所需的技能。由于这种差距, 他们无法影响组织的其他人认为是---拥有的东西, 而不仅仅是 qa 团队。为了弥合这一差距, 我们不得不重新考虑我们对 qa 整体的态度。
迈向新的开始
我想完成两个目标: 首先, 重建 shutterstock 的测试基础架构/框架, 使其稳定, 其次, 改变 shutterstock 的工程文化, 使之成为一个不是由测试工程团队拥有的, 而是由每个人来拥有。
我们改变了招聘测试---时所期待的能力。我们希望我们的测试---成为---的开发人员, 他们知道如何构建 object-oriented 的解决方案, 从而帮助他们创建一个稳定且可扩展的测试框架。我们也希望他们成为有影响力的人, 他们可以推动他们的团队做正确的事情, 而不采取跳过单元测试这样的捷径。一旦我们建立了一个 world-class 测试工程团队, 我们就开始了解如何快速发布, 同时保持一个的产品。
我们知道我们da的问题是脆弱的测试, 所以我们建立了一个叫做 睿智 的工具来记录每个测试的通过/失败数据。我们所有的测试都把数据推入睿智, 每次他们作为我们的詹金斯工作流程的一部分运行。然后, 我们在这个数据库之上建立了一个网站, 使数据的挖掘变得容易。我们现在能够监控工作的合格率、个别测试的及格率、常见的失败消息、的运行测试, 等等。有了这些数据, 我们就可以保持自己和其他人的责任感。我们的一个团队受影响的失败的测试认识到, 他们通常的传球率只有20%。(试想一下, 由于这一路障, 软件工厂经常停下来。通过使用远见卓识,sonarqube修改检测规则, 他们能够快速隔离测试的di合格率, 并在这些测试中看到常见的失败消息。团队对测试---进行了简单的修复, 以提高其---性。
sonarqube和jacoco的个人测试代码覆盖率
本文介绍了如何使sonarqube收集单个测试的测试代码覆盖率指标。代码覆盖工具通常产生一个报告,显示在给定测试会话期间执行的所有测试的组合效果的代码覆盖率(按行,分支等)。例如,当您在持续集成中运行单元测试时就是这种情况。在sonarqube和jacoco的帮助下,可以在单个测---例级别(junit或testng中的测试方法)中收集覆盖度量。为了实现这一点,我们在这篇文章中显示了一些特殊的配置。
环境
以下过程已经使用sonarqube 4.1.2和4.3.2版本进行了验证,sonarqube修改检测规则,但它也适用于sonarqube 3.7.x(xin的lts版本)。我们用于验证设置的应用程序代码是熟悉的spring pet clinic应用程序,sonarqube修改检测规则,增强功能可支持tomcat 7和spring 3(请参阅此篇文章,以了解有关宠物诊suo需要更新的信息:https://deors.wordpress.com/ 2012/09/06 / petclinic-tomcat-7 /)该代码可以从存储库中的github:https://github.com/deors/deors.demos.petclinic
说明
一旦你知道如何连接所有的点,这些说明很简单。所有这些都是为maven surefire插件添加一些特定的配置(surefire是插件,它是单元测试执行的任务,它支持junit和testng)。由于此具体配置不应影响常规单元测试执行,因此建议将所需配置包含在单独的配置文件中,仅在执行sonarqube分析时执行。我们一起来描述pom.xml文件中所需的更改。
sonarqube修改检测规则-华克斯由苏州华克斯信息科技有限公司提供。苏州华克斯信息科技有限公司坚持“以人为本”的企业理念,拥有一支高素质的员工队伍,力求提供---的产品和服务回馈社会,并欢迎广大新老客户光临惠顾,真诚合作、共创美好未来。华克斯——您可---的朋友,公司地址:苏州工业园区新平街388号,联系人:华克斯。
联系我们时请一定说明是在100招商网上看到的此信息,谢谢!
本文链接:https://tztz192713a2.zhaoshang100.com/zhaoshang/275545832.html
关键词: