热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

自动化测试项目失败的原因及调查结果

本文介绍了自动化测试专家ElfriedeDustin在2008年的文章中讨论了自动化测试项目失败的原因。同时,引用了IDT在2007年进行的一次软件自动化测试的研究调查结果,调查显示很多公司认为自动化测试很有用,但很少有公司成功实施。调查结果表明,缺乏资源是导致自动化测试失败的主要原因,其中37%的人认为缺乏时间。

自动化测试专家

Elfriede Dustin



2008



10

月的《

Software Testing and Performance

》杂志上发表文章,深入探讨了为什么如此多的自动化测试项目会最终失败。

 



1





IDT


的自动化测试调查


        

IDT



Innovative Defense Technologies

)在

2007

年进行了一次软件自动化测试的研究调查。调查研究表明:虽然很多公司都认为自动化测试是非常有用的,但是很少有公司真正成功地实施了自动化测试。在问及没有很好地开展自动化测试的原因时,大部分人回答是由于缺乏资源,例如:时间、预算、技术等,其中:


   

 

37%

认为缺乏时间。


   

 

17%

认为缺乏足够的预算。


   

 

11%

认为缺乏合适的工具。


   

 

20%

认为缺乏专家的技术指导。

        研发领域的技术在过去

20



30

年间得到了高速的发展。然而我们对这些技术的测试能力并没有跟上发展的速度。现实告诉我们,测试变得越来越重要。

IDT

研究测试技术多年,发现一些有趣的东西:





1


)软件测试开始和软件开发一起驱动着业务。

        以前,业务驱动着软件和测试的技术发展。现在,软件和测试技术逐渐对业务起着驱动作用。业务部门可以有很好的业务

idea

,但是如果软件开发和测试部门不能很好地交付产品,或者测试能力有所欠缺的话,业务的竞争力会很快地消失。抢占市场的先机很重要,但是应该给予产品开发和质量保证更多的关注。





2


)应该给予“感知质量”更多的测试

        质量过程和标准往往过于关注数据,例如出现了多少个

Bug

、缺陷的密度等数据,而忽略了顾客的“感知质量”。例如,对于一个产品,频繁出现的

10

个缺陷,并且会影响到关键的功能运行,这往往会被顾客认为是一个低质量的产品,即使相对于整个项目而言,缺陷密度是非常低的。

        相反地,如果发布的产品中有

100

个缺陷,但是不经常出现,而且几乎不影响正常的功能操作,顾客则会认为这是个高质量的产品,即便从数据看来,其缺陷率非常高。

        到目前为止,并没有太多“基于使用的测试”的研究。“基于使用的测试”探索感知质量的内涵,追求高的感知质量,从而获得更高的顾客满意度。在 

Elfriede Dustin

看来,

amazon.com

相比起其他在线书店网站,拥有更高的顾客感知质量,因为

amazon.com

的用户体验非常友好。

        我们的目标是提高产品的感知质量。提高的途径是:让测试专注在那些最常使用的功能上(确保正常工作,没有任何缺陷),专注于测试那些最常用功能的可用性、可靠性。





3


)测试人员总是会受到责备

        

Deadline

临近,而在多种环境下的测试周期看起来是无止境的。测试人员通常会因为

Deadline

而受到责备,还会因为项目超出预算、没有覆盖产品的所有

Bug

、缺乏创新等,受到责备。

        但是,通常造成这种结果的真正原因是因为缺乏系统工程的过程。例如,对于一个上百万行代码、包含大量功能模块的产品,仅仅依靠测试组的黑盒测试,费尽九牛二虎之力才找到一些

Bug


        从另外一个角度来看,测试对项目进度拖延的真正原因是:不良的开发习惯导致充满

Bug

的代码,需要很长的、重复的修改周期。

        还有一个原因是:缺乏单元测试。调查分析表明:单元测试越充分、越有效,则系统测试会开展得越顺利,系统测试的周期也会越短。

        不能忽略的一个问题是产品构建。构建(

Build

)和发布(

Release

)的过程应该自动化。如果没有实现构建的自动化,那么软件构建的过程将会是非常浪费时间、并且容易出错的一件事情。

        另外,如果

Deadline

本身设置得就不合理,那么导致失败的可能性就非常大。有些

Deadline

的设置没有考虑清楚究竟需要多长的时间来开发和测试软件。





4


)开发人员不做测试

        虽然已经有不少的开发人员采用单元测试、测试驱动的开发方式,他们确实做得不错。但是开发人员仍然缺少集成和系统方面的测试。开发人员往往倾向于关注自己编写的功能模块的问题,缺乏对整个系统的全局观。

        为什么开发人员不做一下系统测试呢?他们没有时间,他们不是专业的测试人员,他们缺少测试的技巧,他们忙着开发新的代码和功能,并且测试系统整合部分的代码不是他们的职责。

        开发人员疲于应付新功能的开发,以便满足那些不合理的

Deadline

。毕竟,大部分人认为抢占市场是很关键的。然而,事实证明,我们不仅仅要关注 

R&D

,还要关注

R&D&T


 



2


、自动化测试的最佳实践


        很自然地,大家希望借助于自动化测试来缩短系统测试的周期,缓解测试的压力。但是,如果在设计和代码开发的过程中缺乏对自动化测试的考虑,例如提高应用程序的可测试性,我们可能会掉入自动化测试的陷阱中去。

        为了避免掉入自动化测试的陷阱,

Elfriede Dustin

总结了几个最佳实践,其中包括:





1


)提高应用程序的可测试性。

        软件开发人员可以通过在程序中构建更多的可测试特性,来帮助测试人员开展自动化测试。可以有多种方式来提高可测试性,其中一种比较常见的方式是提供日志或 跟踪机制,从而提供关于程序正在做什么的信息,包括正在操作的数据,以及关于应用程序状态、运行中的错误等方面的信息。测试工程师可以利用这些信息来判断 错误是否发生,跟踪测试执行过程中的各种处理流程。

        在应用程序执行过程中,所有模块都会写入关于方法、函数、当前处理对象等详细的日志信息。通常日志会写到文件或数据库中,并且按一定的格式写入,以便后期地分析和调试。

        在某些复杂的

C/S

结构系统或

Web

系统中,日志文件可能会写到多个机器上,因此日志中应该包含足够的信息用于判断在机器之间执行的顺序和路径。但是也不能包含太多的信息,否则将影响后期的分析过程。这些日志信息对于开发人员定位问题的本质有重要的作用,可以减少问题分析和定位、调试的时间。





2





GUI


和接口测试的建议

        录制回放型的测试工具通过脚本语言记录测试工程师在程序界面上的操作,然后通过回放来做一些基本的验证。由于需要与

GUI

打交道,任何

GUI

的细微变化都可能引起脚本回放的失败。因此,如果是基于位图的录制,则要注意下面几个方面:


   

 控件的字体不要随便改动。


   

 界面的颜色不要随便改动。


   

 显示的设置需要保持不变。


   

 如果可能,应该保持操作系统的标准设置。

        开发人员在做界面层的修改之前,需要考虑到界面的修改对自动化测试脚本的影响,尤其是在界面基线已经建立起来之后,需要慎重考虑

GUI

的修改。

        

GUI

测试工具通常是基于对象的属性来识别对象的,因此开发人员最好能知道

GUI

测试工具的工作原理,这样可以在修改

GUI

时尽量避免对自动化测试脚本造成的影响。

 



3


、小结


        为了避免掉入那些主要的自动化测试陷阱,

R&D

应该在开发过程中把测试这个“

T”

也考虑进去,而不仅仅考虑那些最新最酷的开发技术。如果发明并使用了最新最好的技术,但是不能被充分测试或者很难被测试到,那么我们如何知道它们的质量水平呢?!


 


 


 


 测试自动化是个很关键的技术,在开发软件的过程中,程序员需要把测试效果和可测试性等因素考虑进去。并且,还应该明白修改


GUI


的内容对于自动化测试脚本的影响。


自动化测试:为什么受伤的总是我?




推荐阅读
  • Flowable 6.6.0 表单引擎在Web应用中的集成与使用
    本文档提供了Flowable 6.6.0版本中表单引擎在Web应用程序中的配置和使用指南,包括表单引擎的初始化、配置以及在Web环境下的具体实现方法。 ... [详细]
  • HTML基础入门指南
    本文将深入浅出地介绍HTML的基础知识,包括其定义、开发工具、制定机构、特性、基本标签及更多实用内容。 ... [详细]
  • docker镜像重启_docker怎么启动镜像dock ... [详细]
  • EasyMock实战指南
    本文介绍了如何使用EasyMock进行单元测试,特别是当测试对象的合作者依赖于外部资源或尚未实现时。通过具体的示例,展示了EasyMock在模拟对象行为方面的强大功能。 ... [详细]
  • 智慧城市建设现状及未来趋势
    随着新基建政策的推进及‘十四五’规划的实施,我国正步入以5G、人工智能等先进技术引领的智慧经济新时代。规划强调加速数字化转型,促进数字政府建设,新基建政策亦倡导城市基础设施的全面数字化。本文探讨了智慧城市的发展背景、全球及国内进展、市场规模、架构设计,以及百度、阿里、腾讯、华为等领军企业在该领域的布局策略。 ... [详细]
  • 深入解析SpringMVC核心组件:DispatcherServlet的工作原理
    本文详细探讨了SpringMVC的核心组件——DispatcherServlet的运作机制,旨在帮助有一定Java和Spring基础的开发人员理解HTTP请求是如何被映射到Controller并执行的。文章将解答以下问题:1. HTTP请求如何映射到Controller;2. Controller是如何被执行的。 ... [详细]
  • 并发编程 12—— 任务取消与关闭 之 shutdownNow 的局限性
    Java并发编程实践目录并发编程01——ThreadLocal并发编程02——ConcurrentHashMap并发编程03——阻塞队列和生产者-消费者模式并发编程04——闭锁Co ... [详细]
  • Vue 开发与调试工具指南
    本文介绍了如何使用 Vue 调试工具,包括克隆仓库、安装依赖包、构建项目以及在 Chrome 浏览器中加载扩展的详细步骤。 ... [详细]
  • 本文深入探讨了 Delphi 中类对象成员的核心概念,包括 System 单元的基础知识、TObject 类的定义及其方法、TClass 的作用以及对象的消息处理机制。文章不仅解释了这些概念的基本原理,还提供了丰富的补充和专业解答,帮助读者全面理解 Delphi 的面向对象编程。 ... [详细]
  • 深入分析十大PHP开发框架
    随着PHP技术的发展,各类开发框架层出不穷,成为了开发者们热议的话题。本文将详细介绍并对比十款主流的PHP开发框架,旨在帮助开发者根据自身需求选择最合适的工具。 ... [详细]
  • 本文详细介绍了 Java 中 com.amazonaws.auth.SystemPropertiesCredentialsProvider 初始化方法的使用方式,并提供了多个实际的代码示例,帮助开发者更好地理解和应用这一方法。 ... [详细]
  • 本文探讨了亚马逊Go如何通过技术创新推动零售业的发展,以及面临的市场和隐私挑战。同时,介绍了亚马逊最新的‘刷手支付’技术及其潜在影响。 ... [详细]
  • Flask框架下MySQL数据库的集成与应用
    本文详细探讨了如何在Flask框架中集成和使用MySQL数据库,通过具体的实例和代码演示,帮助开发者更好地理解和掌握Flask与MySQL的结合使用。 ... [详细]
  • 我们正在使用GNU Make来构建我们的系统,在makefile文件的末尾,我们通过一个名为Makedepends的包含来生成一系列的.d文件。然而,当文件被删除或移动时,依赖关系会中断,我们需要寻找一种方法来优雅地处理这种情况。 ... [详细]
  • 本文探讨了在当前开发环境中使用Django 1.5和Python 3.3的情况下,如何解决AWS和GAE仅支持Python 2.7的问题,并提供了相应的解决方案。 ... [详细]
author-avatar
zjy135781012
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有