- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章为什么开发人员不编写更多测试?由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
我经常在会议上谈论 测试微服务,我问与会者的第一个问题是他们是否编写测试。房间通常在为他们的代码编写测试的开发人员和不为他们的代码编写测试的开发人员之间分配 50-50。当我在编码训练营做客座讲座时,这种差异变得更加明显,我发现只有不到十分之一的毕业生真正知道如何编写单元测试.
我的轶事观察也得到了调查的支持。Diffblue 发现 42% 的开发人员跳过编写测试,而 Stack Overflow 发现 37% 的开发人员不为他们的工作代码编写测试.
为了理解为什么开发人员没有更好地编写测试,我决定向几个运行软件团队的朋友提出这个问题。在这篇文章中,我收集了他们的一些观察(与我自己的混合),关于为什么开发人员没有像您认为的那样经常编写测试。他们的一些回答让我感到惊讶,尤其是当我们谈到今天测试的局限性时.
最后,我请他们每个人给我一些提示,给那些可能不熟悉自动化测试的工程领导者和开发人员。如果你是今天跳过测试的大约 40% 的开发人员之一,我希望他们的建议能鼓励你开始.
从广义上讲,自动化测试倾向于提高软件的可靠性、质量和可维护性.
“如果你对某个功能进行了测试,那么你就会知道未来的一些变化是否会破坏某些东西,” Earthly 的Adam Gordon Bell 告诉我。他补充说,测试是一种动态的文档形式:“很多时候,阅读测试比阅读实际实现更容易理解某些东西的作用。” 。
也就是说,编写测试需要时间,许多开发人员没有(或不能)抽出时间来编写它们。随着代码库的增长和测试覆盖率的不断下降,这个问题变得更加明显.
管理经常推出大量功能,而测试总是从优先级列表中下滑……一旦您拥有足够大的代码库,您就可以花费无限量的时间来编写测试,因此可能会令人生畏且难以知道从哪里开始.
如果截止日期很紧或者团队领导者不是特别致力于测试,这通常是软件开发人员被迫跳过的第一件事.
另一方面,一些开发人员只是认为测试不值得他们花时间。“他们可能会想,‘这是一个非常小的功能,任何人都可以为此创建一个测试,我的时间应该在更重要的东西利用。’”的Mudit辛格 LambdaTest告诉我的.
我已经看到这种测试态度在企业环境中“低于”开发人员,在这些环境中,专门的 QA 团队可能负责大部分测试,但它可能发生在任何地方。我曾经在一家初创公司管理过一位高级开发人员,他鼓励我雇佣初级开发人员来为他编写测试.
所以,你可能认为答案很简单。给开发人员更多时间来编写测试并使其成为他们工作的一部分,对吗?
事实上,自动化测试存在一些合理的限制。像软件开发中的许多复杂问题一样,选择测试与否是关于了解权衡.
“写自动化测试可以提供信心,您的应用程序工作的某些部分如预期,”首席执行官艾丹Cunniff, 光纤告诉我,“但代价是你已经投入了大量的时间‘稳定’,使‘可靠’你系统的那部分。” 。
我在创业公司的经历中也看到了这一点。我曾经花了三个星期来构建一个新功能、编写测试和解决代码审查,结果却被告知业务团队改变了主意,该功能将在下一个 sprint 中删除.
虽然测试可能使我的新功能更好、更易于维护,但从技术上讲,它们对业务来说是浪费时间,因为该功能并不是我们真正需要的。在开始编写代码之前,我们没有投入足够的时间来理解问题并制定计划.
“想象一下,一群建筑工人和建筑师在一块空地上与客户和一大堆木材会面。然后以自发的方式建造房屋。当客户怀疑地看着完工的房子并抱怨屋顶看起来不太安全时,承包商回答说“别担心,我们会等到下雨然后修补漏水的地方。”......没有其他专业建造质量不受控制的产品然后依靠测试(和缺陷修复)来提高产品质量.
最后,某些形式的测试特别难以实现,因为它们要求您的代码以特定方式编写。这是对单元测试的常见抱怨.
一方面,单元测试迫使开发人员以一种“可测试”的方式构建他们的代码,但另一方面,这些单元测试很少告诉你最终的应用程序是否为用户提供了价值.
在大多数企业中,唯一具有业务价值的测试是源自业务需求的测试。大多数单元测试源自程序员对函数应该如何工作的幻想……那些没有可证明的价值.
如果您在开始之前没有单元测试覆盖率的遗留代码库中工作,则几乎不可能追溯添加它们。因此,大多数开发人员转向集成或端到端测试.
这些功能测试可能会有所帮助,但它们也存在问题。任何重要的应用程序都会有几十个功能和逻辑分支,因此几乎不可能跟上所有预期的行为。正如 JB Rainsberger 在他的文章Integrated Tests Are A Scam 中指出的那样 ,一个有 20 个页面的中型 Web 应用程序可能需要 10,000 到 1,000,000 次测试才能涵盖所有用户故事.
我认为单元测试和特别是测试驱动的开发被其支持者过度宣传为解决所有问题的方法……但是测试,如果做得好,是非常有价值的。为未来的编写测试,他们将试图了解这个方法在未来的作用。让自己有信心做出需要做出的改变.
虽然测试不是灵丹妙药,但当它适当地应用于手头的软件时,它是合法有用的。几乎在所有情况下,测试对开发人员来说都是积极的,即使它有局限性。开发团队要做的重要事情是有意识地了解他们测试的方式和内容.
Aidan Cunniffe 告诉我:“仔细考虑将测试工作投入到哪里是平衡投资与其提供的价值的最佳方式。” 跳过对新功能的第一个 alpha 版本的测试可能是合理的,但是“当该功能成为其他 3 个功能的支柱时,就该开始测试了。” 。
就我个人而言,我认为混合方法是最好的。单元测试对于快速覆盖大量微小案例很有用,集成测试确保各个部分按预期进行交互,端到端测试提供用户界面是否正常工作的最终检查.
还出现了新的测试品种,试图减轻我们许多人采用的分层测试方法的一些缺点。例如,我 去年调查了一些低代码测试工具,而且还有更多。RelicX首席执行官 Sushil Kumar 指出,“使用基于 AI/ML 的测试自动生成测试脚本可以大大减轻开发人员的负担。” 。
如果您对辩论如此深入,并且您只是因为不确定从哪里开始而没有进行测试,那么让我们谈谈您可以从哪里开始.
最容易开始的地方通常是单元测试。Speedscale 的 Ken Ahrens 告诉我:“当你刚开始测试时,弄清楚你的团队使用什么单元测试框架,并为你的第一次代码签入包含一个单元测试用例。” 继续解释从小做起,但让测试成为一种习惯是坚持下去的关键.
接下来,您需要获得团队其他成员和领导层的支持。需要给开发人员时间来编写测试,并了解这项投资从长远来看会得到回报.
团队中的每个人都在编写测试,或者没有人在编写测试,这确实是一种文化实践,一种技术僵局。没有人想成为唯一这样做的人.
证明测试价值的一种方法是使用它们来防止回归。“如果某些东西不起作用,”Adam Gordon Bell 告诉我,“在修复它之前,先编写一个功能正确的测试。” 这将降低未来回归的可能性,并让您的团队在将来更新该部分代码时充满信心.
测试有局限性,它们不能替代出色的系统设计,但测试在软件开发中也占有一席之地。给工程师时间进行测试并将测试的价值传授给您的团队是工程领导力的一个重要角色,而且随着软件变得越来越复杂,它只会变得越来越重要.
原文链接:https://www.toutiao.com/a7025101305534284325/ 。
最后此篇关于为什么开发人员不编写更多测试?的文章就讲到这里了,如果你想了解更多关于为什么开发人员不编写更多测试?的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
我获得了一些源代码示例,我想测试一些功能。不幸的是,我在执行程序时遇到问题: 11:41:31 [linqus@ottsrvafq1 example]$ javac -g test/test.jav
我想测试ggplot生成的两个图是否相同。一种选择是在绘图对象上使用all.equal,但我宁愿进行更艰巨的测试以确保它们相同,这似乎是identical()为我提供的东西。 但是,当我测试使用相同d
我确实使用 JUnit5 执行我的 Maven 测试,其中所有测试类都有 @ExtendWith({ProcessExtension.class}) 注释。如果是这种情况,此扩展必须根据特殊逻辑使测试
在开始使用 Node.js 开发有用的东西之前,您的流程是什么?您是否在 VowJS、Expresso 上创建测试?你使用 Selenium 测试吗?什么时候? 我有兴趣获得一个很好的工作流程来开发我
这个问题已经有答案了: What is a NullPointerException, and how do I fix it? (12 个回答) 已关闭 3 年前。 基于示例here ,我尝试为我的
我正在考虑测试一些 Vue.js 组件,作为 Laravel 应用程序的一部分。所以,我有一个在 Blade 模板中使用并生成 GET 的组件。在 mounted 期间请求生命周期钩子(Hook)。假
考虑以下程序: #include struct Test { int a; }; int main() { Test t=Test(); std::cout<
我目前的立场是:如果我使用 web 测试(在我的例子中可能是通过 VS.NET'08 测试工具和 WatiN)以及代码覆盖率和广泛的数据来彻底测试我的 ASP.NET 应用程序,我应该不需要编写单独的
我正在使用 C#、.NET 4.7 我有 3 个字符串,即。 [test.1, test.10, test.2] 我需要对它们进行排序以获得: test.1 test.2 test.10 我可能会得到
我有一个 ID 为“rv_list”的 RecyclerView。单击任何 RecyclerView 项目时,每个项目内都有一个可见的 id 为“star”的 View 。 我想用 expresso
我正在使用 Jest 和模拟器测试 Firebase 函数,尽管这些测试可能来自竞争条件。所谓 flakey,我的意思是有时它们会通过,有时不会,即使在同一台机器上也是如此。 测试和函数是用 Type
我在测试我与 typeahead.js ( https://github.com/angular-ui/bootstrap/blob/master/src/typeahead/typeahead.js
我正在尝试使用 Teamcity 自动运行测试,但似乎当代理编译项目时,它没有正确完成,因为当我运行运行测试之类的命令时,我收到以下错误: fatal error: 'Pushwoosh/PushNo
这是我第一次玩 cucumber ,还创建了一个测试和 API 的套件。我的问题是在测试 API 时是否需要运行它? 例如我脑子里有这个, 启动 express 服务器作为后台任务 然后当它启动时(我
我有我的主要应用程序项目,然后是我的测试的第二个项目。将所有类型的测试存储在该测试项目中是一种好的做法,还是应该将一些测试驻留在主应用程序项目中? 我应该在我的主项目中保留 POJO JUnit(测试
我正在努力弄清楚如何实现这个计数。模型是用户、测试、等级 用户 has_many 测试,测试 has_many 成绩。 每个等级都有一个计算分数(strong_pass、pass、fail、stron
我正在尝试测试一些涉及 OkHttp3 的下载代码,但不幸失败了。目标:测试 下载图像文件并验证其是否有效。平台:安卓。此代码可在生产环境中运行,但测试代码没有任何意义。 产品代码 class Fil
当我想为 iOS 运行 UI 测试时,我收到以下消息: SetUp : System.Exception : Unable to determine simulator version for X 堆
我正在使用 Firebase Remote Config 在 iOS 上设置 A/B 测试。 一切都已设置完毕,我正在 iOS 应用程序中读取服务器端默认值。 但是在多个模拟器上尝试,它们都读取了默认
[已编辑]:我已经用 promise 方式更改了我的代码。 我正在写 React with this starter 由 facebook 创建,我是测试方面的新手。 现在我有一个关于图像的组件,它有
我是一名优秀的程序员,十分优秀!