《Unit Testing》1.1 -1.2 单元测试的目的

本系列是《Unit Testing》 一书的读书笔记 + 精华提取。

书中的例子 C# 语言编写,但概念是通用的,只要懂得面向对象编程就可以。

 

单元测试当前的状态

  • 目前,在(美国的)大部分公司里,单元测试都是强制性的。

  • 生产代码与测试代码之间的比例大约在 1:1 1:3 之间。

    • 有时候比例会更高,甚至达到 1:10

  • 二十多年来,讨论的话题已经从“是否应该做单元测试”变成了“编写出好的单元测试意味着什么?”

  • 单元测试好与不好不仅仅是个人喜好品味的问题,更是与项目成功失败密切相关

  • 我们的目标不仅是掌握测试工具(很多资料都有这种教程),而是要:“不仅要写单元测试,而且让做单元测试的方式能够为你提供最好的回报”

 

企业应用的特点是什么?

  • 大量高复杂度的业务逻辑

  • 项目的声明周期很长

  • 数据量不算特别大,也不小

  • 对性能的要求不高或中等水平

 

单元测试的目的

单元测试的实践通常会导致更好的设计,但这不是单元测试的主要目的,这仅仅是个副作用。

 

单元测试与代码设计的关系

  • 如果你的代码很难进行单元测试,那这就是你代码需要改进的强烈信号。

  • 代码质量差的通常表现就是紧密的耦合,就是说不同的生产代码段之间没有足够的解耦,所以很难对其进行单独测试。

 

不幸的是:

  • 代码是否能进行单元测试这件事是一个负向指标(只能确定代码质量肯定不好)

  • 如果你的代码能够容易的进行单元测试,并不意味着你的代码质量一定很高。

 

单元测试的目的就是让软件项目可持续的发展,“可持续”这个词是关键。

下图描述了项目有无单元测试与项目发展和消耗工时之间的关系:

这种迅速降低开发速度的现象就是软件的熵。而熵就是体系混乱程度的度量。

在软件中,熵以易于恶化的代码形式表现出来。每次你改变代码库中的某个东西,其中的无序量,或者说熵,都会增加。

 

测试有助于扭转这种趋势。它们充当了一个安全网——一个为绝大多数回归提供保险的工具。测试有助于确保现有功能正常工作,即使在引入新功能或重构代码以更好地适应新的需求之后。

 

  • 回归(regression,是指某个特性在某个事件(通常是代码修改)之后停止按预期工作了。术语回归和软件 bug 是同义词,可以互换使用。

 

可持续性和可扩展性是关键。从长远来看,它们允许您保持开发速度。

 

什么是好和不好的单元测试?

此图描述了较好、较差、没有单元测试与项目发展和消耗工时的关系。

可以看出:不是所有的测试都是被平等创建的。

通过添加更多的测试并不会实现你单元测试的目标,你需要考虑测试的价值和维护成本。而成本取决于各项活动所花费的时间:

  • 重构底层代码时重构测试的时间

  • 针对每次代码修改,运行测试的时间

  • 处理由测试引起的错误警报的时间

  • 当您试图理解底层代码的行为时,阅读测试所花的时间

 

由于维护成本高昂,很容易写出净价值接近于 0 甚至负价值的测试。

 

最后强调一点:代码是一种负债,而不是资产。而测试也是代码。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/309111.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Java Exception

Exception 异常捕获 将代码块选中->ctrlaltt->选中try-catch 01: public class Exception01 {public static void main(String[] args) {int n1 10;int n2 0;try {int res n1/n2;} catch (Exception e) { // e.printStackTrace();System.out.println(e.…

《Unit Testing》1.3 使用覆盖率指标来度量测试套件的好坏

使用覆盖率来度量测试套件(Test Suite)的质量有两种比较流行的测试覆盖率的度量方法:代码覆盖率分支覆盖率覆盖率度量会显示一个测试套件(Test Suite)会执行多少代码,范围从 0 至 100%。除了上述两种方法之…

Linux创始人:v5.8是有史以来最大的发行版之一

导语Linux v5.8已经修改了所有文件的20%,是迄今为止变化最大的一次发行版。正文Linux创始人Linus Torvalds表示:Linux内核5.8版是“我们有史以来最大的发行版之一”。如果一切顺利,Linux v5.8稳定版应该在2020年8月的某个时候出现…

[高等数学]这你不背?

求导及求微分的基本公式: 泰勒中值定理: 麦克劳林公式: 不定积分公式: 凑微分: 第二类换元积分法常用的三种情况: 求高阶导数的几个公式: 二阶常系数非齐次线性微分方程的特解: 排列组合公式: C的计算: 下标的数字乘以上标的数字的个数,且每个数字都要-1.再除以上标…

怎么开会才不浪费时间?

这里是Z哥的个人公众号每周五11:45 按时送达当然了,也会时不时加个餐~我的第「148」篇原创敬上大家好,我是Z哥,先祝大家端午节日快乐。节日期间就发篇比较短的文章吧。人在职场混,开会应该是本职工作之外花…

.NET 5.0预览版6发布:支持Windows ARM64设备

2020年6月25日,微软dotnet团队在博客宣布了第六个 .NET 5.0 的预览版:https://devblogs.microsoft.com/dotnet/announcing-net-5-0-preview-6/,在改进性能的同时增加了一些新的功能。ASP.NET Core和 EF Core也将于今日发布了。注意&#xff1…

利用真值表法求取主析取范式以及主合取范式的实现(C++)

代码如下: #include <iostream> #include <stack> #include <string> #include <vector> using namespace std; const int N 300; stack<char> s; stack<char> v; int seq; bool vis[N]; bool flag[N]; void dfs(int n); vector<int&…

基于 Blazor 开发五子棋小游戏

今天是农历五月初五&#xff0c;端午节。在此&#xff0c;祝大家端午安康&#xff01;端午节是中华民族古老的传统节日之一。端午也称端五&#xff0c;端阳。此外&#xff0c;端午节还有许多别称&#xff0c;如&#xff1a;午日节、重五节、五月节、浴兰节、女儿节、天中节、地…

汇编cmp比较指令详解

刚刚看到了cmp指令&#xff0c;一开始有点晕。后来上网找了些资料&#xff0c;终于看明白了&#xff0c;为了方便初学者&#xff0c;我就简单写下我的思路吧。高手绕过&#xff0c;谢谢&#xff01; cmp(compare)指令进行比较两个操作数的大小例:cmp oprd1,oprd2为第一个操作减…

如何在ASP.NET Core中使用SignalR构建与Angular通信的实时通信应用程序

图片假设我们要创建一个监视Web应用程序&#xff0c;该应用程序为用户提供了一个能够显示一系列信息的仪表板&#xff0c;这些信息会随着时间的推移而更新。第一种方法是在定义的时间间隔&#xff08;轮询&#xff09;定期调用API 以更新仪表板上的数据。无论如何&#xff0c;还…

LED计数电路,5输入按键编码器,7段数码管显示驱动集成为LED计数测试电路

LED计数电路: 5输入按键编码器: 7段数码管显示驱动真值表: 集成:

越卖越涨?腾讯股票3月后大涨45%,超越“阿里”成中国第一,市值相当于14.3个百度!...

01 腾讯股价大涨据股市最新消息&#xff1a;腾讯股价已连续3个交易日上涨, 其中6月22日腾讯股价重返470港元关口&#xff0c;公司市值突破4.5万亿港元&#xff0c;折合4.0万亿人民币&#xff1b;而6月23日上午腾讯股价再度大涨4.05%&#xff0c;刷出493.8港元的新高&#xf…

4位无符号比较器设计

4位比较器原理&#xff1a; 4位比较 a3a2a1a0 : b3b2b1b0&#xff0c;比较顺序从高位到低位&#xff0c;当高位大、小关系确定时则无需看低位&#xff0c;当高位相等时再看相邻低位的关系。 注意&#xff1a;对于三个比较结果&#xff0c;已知其中任意两个&#xff0c;可以用…

关于技术文章“标题党”一事我想说两句

阅读本文大概需要 1.8 分钟。前天发表的一篇文章&#xff0c;标题是&#xff1a;“面试官&#xff1a;你刚说你喜欢研究新技术&#xff0c;那么请说说你对 Blazor 的了解”。确实&#xff0c;这篇文章有标题党的味道&#xff0c;如果因此给部分童鞋带来不适&#xff0c;我在这先…

使用 nuget server 的 API 来实现搜索安装 nuget 包

使用 nuget server 的 API 来实现搜索安装 nuget 包Intronuget 现在几乎是 dotnet 开发不可缺少的一部分了&#xff0c;还没有用过 nuget 的就有点落后时代了&#xff0c;还不快用起来nuget 是 dotnet 里的包管理机制&#xff0c;类似于前端的 npm &#xff0c;php 的 composer…

Kubernetes:通过自动化节省IT预算的4种方法

导语大多数CIO和IT领导者都熟悉反复执行的任务“事半功倍”。在许多组织中&#xff0c;这都是现实&#xff0c;在各种其他因素&#xff08;例如宏观经济状况&#xff09;的影响下&#xff0c;这种趋势往往会起伏不定。正文有时&#xff0c;“用更少的钱做更多的事”可能会更准确…