- 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的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
我只想从客户端向服务器发送数组 adc_array=[w, x, y, z]。下面是客户端代码,而我的服务器是在只接受 json 的 python 中。编译代码时我没有收到任何错误,但收到 2 条警告
我是 lua 和 Node js 的新手,我正在尝试将我正在开发的移动应用程序连接到服务器。问题是它连接到服务器,但我尝试传递的数据丢失或无法到达服务器。对我正在做的事情有什么问题有什么想法吗? th
我在这个页面上工作 http://www.haskell.org/haskellwiki/99_questions/Solutions/4 我理解每个函数的含义,看到一个函数可以像这样以多种方式定义,
我目前正在尝试将数据写入 excel 以生成报告。我可以将数据写入 csv 文件,但它不会按照我想要的顺序出现在 excel 中。我需要数据在每列的最佳和最差适应性下打印,而不是全部打印在平均值下。这
所以,我正在做一个项目,现在我有一个问题,所以我想得到你的帮助:) 首先,我已经知道如何编写和读取 .txt 文件,但我想要的不仅仅是 x.hasNext()。 我想知道如何像 .ini 那样编写、读
我正在尝试编写一个函数,该函数将返回作为输入给出的任何数字的阶乘。现在,我的代码绝对是一团糟。请帮忙。 function factorialize(num) { for (var i=num, i
这个问题已经有答案了: Check variable equality against a list of values (16 个回答) 已关闭 4 年前。 有没有一种简洁或更好的方法来编写这个条件
我对 VR 完全陌生,正在 AFrame 中为一个类(class)项目开发 VR 太空射击游戏,并且想知道 AFrame 中是否有 TDD 的任何文档/标准。有人能指出我正确的方向吗? 最佳答案 几乎
我正在尝试创建一个 for 循环,它将重现以下功能代码块,但以一种更具吸引力的方式。这是与 Soundcould 小部件 API 实现一起使用的 here on stackoverflow $(doc
我有一个非常令人困惑的问题。我正在尝试更改属性文件中的属性,但它只是没有更改... 这是代码: package config; import java.io.FileNotFoundException
我对 VR 完全陌生,正在 AFrame 中为一个类(class)项目开发 VR 太空射击游戏,并且想知道 AFrame 中是否有 TDD 的任何文档/标准。有人能指出我正确的方向吗? 最佳答案 几乎
我正在开发一个用户模式(Ring3)代码级调试器。它还应支持.NET可执行文件的本机(x86)调试。基本上,我需要执行以下操作: 1).NET在隐身模式下加载某些模块,而没有LOAD_DLL_DEBU
我有一个列表,我知道有些项目是不必要打印的,我正在尝试通过 if 语句来做到这一点...但是它变得非常复杂,所以有没有什么方法可以在 if 语句中包含多个索引而无需打印重写整个声明。 看起来像这样的东
我很好奇以不同方式编写 if 语句是否会影响程序的速度和效率。所以,例如写一个这样的: bool isActive = true; bool isResponding = false; if (isA
我在搜索网站的源代码时找到了一种以另一种方式(我认为)编写 if 语句的方法。 代替: if(a)b; 或: a?b:''; 我读了: !a||b; 第三种方式和前两种方式一样吗?如果是,为什么我们要
我的数据采用以下格式(HashMap的列表) {TeamName=India, Name=Sachin, Score=170} {TeamName=India, Name=Sehwag, Score=
我目前正在完成 More JOIN operations sqlzoo 的教程,遇到了下面的代码作为#12 的答案: SELECT yr,COUNT(title) FROM movie JOIN ca
我正试图找到一种更好的方法来编写这段代码: def down_up(array, player) 7.downto(3).each do |row| 8.times do |col
出于某种原因,我的缓冲区中充满了乱码,我不确定为什么。我什至用十六进制编辑器检查了我的文件,以验证我的字符是否以 2 字节的 unicode 格式保存。我不确定出了什么问题。 [打开文件] fseek
阅读编码恐怖片时,我刚刚又遇到了 FizzBuzz。 原帖在这里:Coding Horror: Why Can't Programmers.. Program? 对于那些不知道的人:FizzBu
我是一名优秀的程序员,十分优秀!