2024年软件测试最新【软件测试】牢记这7点,掌握写好自动化测试用例的法宝,软件测试高频面试题+解析

img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上软件测试知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

需要这份系统化的资料的朋友,可以戳这里获取

当然,编写用例的过程与其他开发人员的编码工作没有什么本质上的区别,也别指望用例脚本可以一次性的编写到位,脚本大多数都是需要一次又一次的优化,起初写的效率低一点也没关系,我们先确保可以跑通,复用性和健壮性可以稍微差点。

但是跑通之后,我们就应该着眼于性能方面,如果你用的python,跑几条用例是完全没有问题的,因为python是动态语言,变量指向对象的时候编译器无法做任何预测,另外加上他本身是解释执行,所以是在跑大量测试用例的情况下,一定会出现运行周期时间长与意外报错的情况出现,此时提高代码的性能就成为了重中之重,算法时间复杂度的优化、内置方法的合理使用、避免全局变量、减少循环等等都可以为我们的代码提供相应的性能提升。

02 业务强关联
与黑盒测试用例不同,自动化测试用例内的业务关联性会很强。其实我们从其本质形态来考虑的话也就能探究一二,它需要解决的本来就是一些功能稳定、业务路径明确的正向测试场景,测试用例脚本不可能只操作某个业务界面中的某一个功能,这样就太浪费了。

一般来说测试脚本都需要覆盖某一个正常业务的整条流程,这样我们才可以在其运行的过程中,加入自己所需的各类断言,来验证多条用例中的测试预期结果。另外由于和黑盒测试用例的本质不同,也就更好的印证了自动化测试用例可以快速进行业务验证与归回、冒烟。

03 正向场景
对于自动化测试来说,最恐怖的情形就是将所有的正向、逆向测试场景一股脑的塞进自动化测试框架。有些人会本能的认为既然是自动化执行,为什么不可以执行逆向测试用例呢?只要设计好合适的参数、编写进测试用例真的就万无一失了吗?

其实逆向测试场景与测试用例被适合放入自动化测试的原因就在于它本身的不确定性,这种不确定性会影响自动化测试的最终运行结果。

做过自动化测试的同学都知道,对于执行自动化测试来说真正可怕的不是逆向测试用例,而是那种不知道什么时候就会报错的测试场景和用例,而这种测试用例的所在场景,绝大多数会出现在逆向测试场景中。

我们要知道自动化测试不是帮测试人员把什么事情都干了。所以针对功能稳定、需求变动不多的正向测试场景,我们可以放心的将自动化测试投入其中,但逆向的测试场景就不建议如此操作了。

如果真的要放,也只建议放入比较不重要的功能模块,一些业务复杂和重要的功能模块的逆向场景还是需要经验丰富的测试人员去进行手工确认来的更为的稳妥。

一般来说自动化测试主要覆盖产品的主体happy path即可,无需设计过多的逆向场景在其中,影响自动化测试活动的稳定性。不要忘记了,自动化测试的主要作用还是让我们的测试人员从繁杂重复的测试工作中脱离出来,把精力投入更重要、更复杂的模块和业务测试中去。

04 多场景构建
这里的多场景构建理念是希望可以充分的利用自动化测试的优势,以更少的运行次数来尽可能的覆盖更多的测试场景。

举个例子,一个自动化测试脚本中存在多条测试用例,那么我们在设计用例的过程中需要充分的利用脚本中的业务界面,来进行多个场景的组合构建。

诸如CRM,我们都会在客户信息界面中验证客户的各类信息、增删改查操作,而这些操作如果可能尽量放在页面的一次性操作中,除非和后面的业务有强关联(后续操作的必要数据),否则基本都是按照这个原则。

这也就是上面说的尽量在一遍中将可以验证的业务场景组合在一起,而非跑多轮同样的业务线却只是验证的测试点不同。

05 强针对性
一般来说,我们设计自动化测试用例,来源的基础都是我们之前设计的黑盒测试用例,普遍的做法是将P0与P1级别的正向测试用例加入到自动化测试用例中。

这样做是完全没有问题的,不过我们还需要注意的是,针对不同的测试类型,我们的自动化测试用例不是一成不变的。例如自动化测试中最常配到的冒烟和回归测试,这两类的自动化测试用例就不应该相同。

冒烟测试的测试用例应该更倾向于快速的将主流程进行验证,确保当前版本的提测质量值得开展接下去的测试活动,也更注重于老用例的套用。

回归测试则是针对部分功能修复后对于整体功能与延展部分模块的正常运行是否会有影响,这块需要在已修复的功能模块和测试认为有必要开展的相关模块间开展自动化测试,所以自动化测试用例会有和冒烟部分重叠的情况出现,同时也会新增用于确认相关延展部分的功能正常运行的用例。

06 独立测试功能点
这个也很好理解,和黑盒测试用例没有区别,虽然脚本里会设计某个页面当前整体的线性业务操作,但是我们仍旧要确保好每条自动化测试用例中只验证一个功能点,切不可图方便把一条用例中放入多个功能点进行确认。

这时一定有人会问,我多放几个断言不就可以进行多功能确认了吗?其实这个观点是违背了测试用例设计的初衷的,多个断言自然可以判断多个功能点,但大家试想一下,一条测试用例中有多个验证点是否会让用例本身的步骤变多,且无法拆解,这个和写黑盒测试用例不一样的地方就在于你的代码是无法独立拆解出来的。

那么接下来的问题就是同样是测试用例,是一堆组合后的测试用例复用度高?还是独立测试功能点的用例复用度高?大家都不用细想,答案就已经很明显了。就好比是乐高积木,如果需要你设计一座城堡,是一整块不规则形状的大积木好还是一小块一小块规整的小积木好?

07 完整设计
我们除了设计基本的测试用例之外,同样也可以利用自动化的优势来进行一些额外的用例扩展设计。

在日常工作中,我们的自动化测试也不是只要设计相关的功能测试点即可的,这里还包括了相关的一些测试数据操作。那么测试数据的前后置操作也就理所当然的变成了设计测试用例中必须的步骤之一了。

在黑盒测试中,我们的测试数据都会在我们执行前定义或创建好,在执行的过程中就会比较的顺畅。而自动化测试中,这个操作我们就无需再手动提前进行操作了,一般来说我们会把需要生成的测试数据提前的放入某个独立的测试用例内进行预先创建,这个称为前置操作,其实也就是我们所说的前提条件。

而同样的,我们在执行完某些操作或业务流之后,也可以将这些测试数据进行回收、删除,这被称为后置操作。这样我们就可以时刻保证我们的测试环境可以重复的进行同样的测试用例而不会担心环境或数据等因素发生改变。

另外,因为我们的测试过程是“过不留痕”,所以在重要的用例与断言处可以使用截图函数、打印日志等方式留下测试证据,以便在出现Bug时方便排查与定位。

好了,以上就是关于自动化测试用例的一些设计因素与心得,希望可以帮助到大家更好的总结出各自的心得体验。

下面是一些配套的学习资源,希望能帮到大家,朋友们如果需要可以自行免费领取 【保证100%免费】
在这里插入图片描述

软件测试面试文档

我们进阶学习自动化测试—测试开发必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有字节大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。图片

img
img

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

opics/618608311)**

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值