自动化软件测试的推动力
更新时间:2021-12-22 09:36:55 作者:多测师 浏览:247
做过一个单元测试自动化,我们开发了近百行的测试代码去测试一个代码行为10行的函数;在UI测试自动化,则调用了IE的COM接口去驱动IE application,以模拟在界面上的两个动作,输入“测所”和点击“搜索”按钮,总共9行代码(如果考虑自动化健壮性的话,还要增加错误处理代码)。
观察到这些,我们暂且不考虑自动化测试开发之后的维护,至少可以有一个直观的认识:从手工测试向自动化测试的转变是要付出的成本的,而且这个投入要远比做一次手工测试的代价要高,比如,一个有经验的自动化测试开发人员完成一段健壮的100行左右的测试脚本大概需要一天左右的时间,而手工完成这个功能点的测试则只需要10分钟。一天 VS十分钟,按理说,这是一个赔本的买卖,但为什么还有这么多的软件企业对测试自动化情有独钟呢?排除一些盲目跟风,试图提高测试技术含金量的情感因素,至少有以下几个理性的现实驱动力。
1. 测试自动化主要是做长线投资,而非一时之计
显而易见地,开发一个程序,只为了运行一次自动化测试是非常不划算的。那么要想能收回开发自动化测试的投资,就要尽可能多地运行测试程序,每多运行一次,就会多节省一份手工测试工作量。这个简单的道理可以说明为什么如今测试自动化应用最多的就是回归测试阶段。由于回归测试往往是验证软件bug的fix或者软件补丁的有效性,理论上,每一次bug的修复,都需要进行一次全面回归测试。
2. 测试自动化可以随时触发运行
测试自动化一旦开发完成,就可以在任何时间被触发运行,而没有下班或周末的概念,测试人员完全可以在下班之前触发某个自动化开关,把测试任务移交给自动化脚本,然后经过一夜的运行,第二天早上上班来查看自动化测试报告,这是自动化的独特优势所在。从这个意义上讲,测试自动化延伸了手工测试的工作时间和范围。
3. 测试自动化有助于知识的存储和移交
这是一个潜在的事实,在以前的手工测试一统天下的时候,测试人员的知识主要是靠文档存储,比如测试计划,测试案例说明书,bug数据库等等。因此,我们看到,当一个测试工程师离职的时候,他会把他的知识以文档的方式留给原来的团队。而随着自动化测试的发展,这种测试知识的形式也在发生变化,测试人员的技术可以通过测试程序保留下来。对整个测试团队来说,能够量化共享的知识越多,团队就越稳定,受到个体测试人员的影响就越少。这是老板愿意看到的场面,因此,从这个角度来说,测试经理比测试工程师更有动力去推动软件测试自动化。
4. 第三方自动化测试工具的使用提高了自动化测试开发的效率
如果说前三点已经讲清了自动化测试的合理性动机,那么自动化测试工具的应用则为自动化测试实施提供了保障,使得做自动化测试不在那么困难和复杂,而变得简单和有效率。
以上内容为大家介绍了自动化软件测试的推动力,希望对大家有所帮助,如果想要了解更多接口自动化测试相关知识,请关注多测师。https://www.aichudan.com/xwzx/
上一篇:软件自动化测试陷阱
下一篇:软件测试自动化是变革而非革命