金字塔测试原理:写好单元测试的8个小技巧,一文总结
off999 2025-05-22 12:46 115 浏览 0 评论
想必金字塔测试原理大家已经很熟悉了,近年来的测试驱动开放在各个公司开始盛行,测试代码先写的倡议被反复提及。
鉴于此,许多中大型软件公司对单元测试的要求也逐渐提高。那么,编写单元测试有哪些小技巧可以借鉴和学习的呢?
测试代码文件路径与开发代码文件路径“相同”
这里的“相同”并不是完全意义的一摸一样,测试代码和开发代码处于同一目录,而是指的测试代码文件路径你与开发代码文件路径“大体相同”。
如下图1、2所示,开发代码路径和测试代码路径都包括/java/ru/yandex/clickhouse/。
图1 开发代码路径
图2 测试代码路径
测试代码文件名清晰
清晰的测试代码文件名可以帮助阅读测试代码的其他人员对该文件的测试内容有很好的初步认识。
例如上图2所示:测试代码文件ClickHouseConnectionTest.java,从命名上就可以帮助阅读人员获悉该测试代码文件是针对ClickHouseConnection.java的测试。
清楚地命名单元测试名称
不要担心名字过长,一个长而完整的名称可以让您立即知道哪个测试失败了,以及该测试到底想做什么。
长时间命名的测试也可以记录你的测试。如下图3所示:从testMaxMemoryUsage()名称就可以看出该测试代码是针对最大内存使用量地测试。显而易见,该名称远远好于test1()、test()2……
图3 单元测试名称样例
一次测试一项
同集成测试、系统测试原则一致,测试用例应该保持“专有性”原则,即每次测试只针对一个功能进行测试。
如下图4所示:都是针对clickhouse进行配置,然后发起查询的功能,但图上方主要是针对最大执行事件设置的测试,图下方是针对最大内存使用量设置的测试。
图4 单元测试“专有性”样例
测试保持独立性
测试保持独立性指的是不同测试用例/代码块之间不应该存在依赖(如:test2()的代码依赖test1()中的参数设置),每一个测试用例/代码块应该能独立运行。
鉴于此,我们可以把一些通用性配置(如数据库初始化)提取到测试套件/代码文件初始化环节。
清晰地抛出测试失败地异常
测试用例/代码并不能保证每次运行都能成功(如开发代码进行重构或功能变动引起地测试代码失败),因此在编写测试代码时需要捕获失败时的异常,并清晰地返回。
例如:若使用Integer aa=1;Integer bb=2;Assert.assertTrue(aa==bb);代码判断变量aa和bb是否相等,若不相等时只会判定失败而不会有详细错误信息。
若改为Assert.assertEquals(aa, bb);则会在失败时返回类似的Expected 1, but the actual result was 2的信息,这样的错误信息更有价值。
不要执着于测试覆盖率
谈到单元测试,就会想到测试覆盖率。测试覆盖率主要指的是代码路径覆盖率和分支覆盖率。
在编写单元测试时难免会陷入一味追求100%测试覆盖率的陷阱。100%测试覆盖率是一个很难实现的愿景,100% 的覆盖率并不意味着你已经覆盖了所有的边缘情况,它只是意味着所有的代码路径都被执行了。
在实际测试过程中,我们应该关注的是测试功能是否覆盖而不是单元代码路径是否被全部覆盖。例如:对于具有相同代码的文件(同一代码块复制粘贴),追求100%的测试覆盖率会导致测试冗余。
因此,我们应该从保障功能正常的角度出发编写单元测试用例,而不是针对每个单元函数编写单元测试用例。
那么,如何从功能的角度出发编写单元测试用例呢?最简单的一点就是查看被调用的函数模块。
若某个模块被上层功能函数调用,那么这个模块就需要我们编写单元测试用例进行守护。
最好有注释
注释可以帮助其他阅读代码的人员更快地理解代码,单元测试也是代码,因此养成注释地习惯可以提高你编写代码的素养。
适当地给单元测试用例分类,提高运行效率
单元测试用例和集成测试用例、系统测试用例一样,当测试用例数量变得很大时,每次修改部分代码运行所有的单元测试用例显得累赘。
这个时候如果你的单元测试用例有明确的分类,那么就能提高运行效率。
如下图5所示:该单元测试标签为”unit”,在运行时可以根据“unit”标签选中该单元测试用例。
图5 单元测试标签样例
上述单元测试小技巧,希望能帮助各位单元测试初学者。
最后:
1)关注+私信回复:“测试”,可以免费领取一份10G软件测试工程师面试宝典文档资料。以及相对应的视频学习教程免费分享!,其中包括了有基础知识、Linux必备、Mysql数据库、抓包工具、接口测试工具、测试进阶-Python编程、Web自动化测试、APP自动化测试、接口自动化测试、测试高级持续集成、测试架构开发测试框架、性能测试等。
2)关注+私信回复:"入群" 就可以邀请你进入软件测试群学习交流~~
相关推荐
- 路由器静态ip填什么(路由器的静态ip)
-
手机登入路由器web界面,输入用户名和密码,第一次弹出设置向导,选择静态ip上网方式,填写可以上网的ip地址,如ip192.168.1.188子网掩码255.255.255.0网关192.168....
- 电脑频繁断电关机(电脑经常断电是不是电源的问题)
-
电脑自动关机主要有以下几种原因造成:1.散热不好。由于天气温度的影响或CPU风扇的转数不够所引起的系统过热,从而会导致电脑的自动关机,建议可以检查一下系统温度是否正常。2.内存原因。当内存与主板插...
- 华为手机双密码双界面(华为手机双密码双界面忘记密码了怎么办)
-
华为手机锁屏怎么有两个锁屏?通常情况下是你多设置了一个锁屏,第一个就是你手势。锁屏二个是密码锁屏,通常这两个同时使用会出现有两个锁屏的现象。你可以在设置里面重新设置一个锁屏就可以了。华为手机锁屏有两个...
- 无线路由器密码在哪看(无线路由器密码在哪里看)
-
笔记本已连接wifi密码查看:1.同时按住按键上面的Win和R这2个按键,打开运行程序。2.在运行程序中输入“ncpa.cpl”,并点击“确定”。3.找到WLAN或者无线网络连接图标,...
- office2003的主要功能(word2003的主要功能)
-
是一套Office2003专业版的精简版,包含常用的Word、Excel、PowerPoint三个应用,使用者甚多。楼主如果有需要,请上电脑在本帖下载我的附件。
- 怎样准备一个带pe的u盘的(带pe系统的u盘)
-
一、U盘安装系统前期准备: 1、首先需要预备一个空的4G或以上U盘,用来存储启动程序跟系统文件。 2、接着我们需要安装的ghost系统。 3、U盘启动盘制作工具:U盘启动工具 二、U盘启动盘制...
- 怎样拷贝文件到u盘里(怎么文件拷贝到u盘)
-
方法/步骤分步阅读1点击安全打开等电脑的桌面中弹出U盘插入成功的提示框之后,点击安全打开,将U盘打开。2点击文件将U盘打开之后,在电脑的桌面中找到需要拷贝的文件,点击鼠标右键等弹出序列。3点击复制弹出...
-
- 固态硬盘怎么安装win7(固态硬盘怎么安装在电脑上)
-
1.首选需要找一个4GB以上的U盘2.用来存放Win7的ISO镜像文件。带有光盘标识的即为“光盘映像文件”3.在点击写入之前,一定要确保U盘里面没有任何数据,如果有数据应该及时备份,否则里面的数据将被删除,不过在做完启动盘后,仍然可以向里面...
-
2025-12-27 13:03 off999
- 苹果手机忘记密码怎么办(很久没用的苹果手机忘记密码怎么办)
-
在苹果官网中搜索忘记iphone密码,点击置于恢复模式的链接,根据步骤完成解锁即可,以下是详细的操作步骤:方法/步骤1点击搜索图标网页上搜索进入apple官网,进入官网主页面之后,点击页面上方的放大镜...
- win10系统防火墙在哪里设置(windows10的防火墙怎么设置)
-
Windows10的防火墙设置非常简单。首先,您可以点击“开始”菜单,然后在搜索框中输入“防火墙”来打开防火墙设置。接下来,您可以根据需要为不同的网络(包括公用网络、专用网络和域网络)设置不同的防火...
- 软件市场下载(软件市场下载安装)
-
是的,因为酷安已经被下架了,目前在所有手机自带的应用市场下载的酷安都是阉割版本。不仅是酷安,其它应用市场比如腾讯的应用宝目前在手机自带的应用商店全都已经下架了。并且申请上架也会被拒绝,拒绝理由是:“暂...
- u盘有东西但是显示文件夹为空
-
u盘里面有文件,却显示文件夹为空是因为文件被隐藏了,开启方法如下:需要用到的工具有:电脑、U盘。1、打开我的电脑,找到并点击进入U盘,2、在U盘目录里面,点击上方的属性功能。3、在属性页面,把隐藏对勾...
欢迎 你 发表评论:
- 一周热门
-
-
抖音上好看的小姐姐,Python给你都下载了
-
全网最简单易懂!495页Python漫画教程,高清PDF版免费下载
-
Python 3.14 的 UUIDv6/v7/v8 上新,别再用 uuid4 () 啦!
-
飞牛NAS部署TVGate Docker项目,实现内网一键转发、代理、jx
-
python入门到脱坑 输入与输出—str()函数
-
宝塔面板如何添加免费waf防火墙?(宝塔面板开启https)
-
Python三目运算基础与进阶_python三目运算符判断三个变量
-
(新版)Python 分布式爬虫与 JS 逆向进阶实战吾爱分享
-
失业程序员复习python笔记——条件与循环
-
系统u盘安装(win11系统u盘安装)
-
- 最近发表
- 标签列表
-
- python计时 (73)
- python安装路径 (56)
- python类型转换 (93)
- python进度条 (67)
- python吧 (67)
- python的for循环 (65)
- python格式化字符串 (61)
- python静态方法 (57)
- python列表切片 (59)
- python面向对象编程 (60)
- python 代码加密 (65)
- python串口编程 (77)
- python封装 (57)
- python写入txt (66)
- python读取文件夹下所有文件 (59)
- python操作mysql数据库 (66)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python多态 (60)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)
