软件缺陷检测

发表于:2011-3-08 13:31

字体: | 上一篇 | 下一篇 | 我要投稿

 作者:方敏/张胜 等译    来源:51Testing软件测试网采编

  测试人员一般使用两种形式的动态测试:自动化测试(通过编写代码来测试一个应用程序)和手工测试(使用程序的用户界面,手工输入数据进行测试)。

  对自动化测试的评价可以说是毁誉参半。

  说它不好是因为使用代码来进行测试,首先必须编写这些代码,这意味着测试人员也必须是一个开发人员。开发人员能否成为一个优秀的测试人员呢?很多人可以,也有很多人不行,这并没有什么定论。但是自动化的测试代码中也存在缺陷,这是一个反复出现的事实,这就意味着测试人员需要花费大量时间来编写代码、调试代码和再重写代码。一旦测试变成了一个开发项目,问题就无法避免,即测试人员花费在测试软件上的时间多,还是花在维护自动化测试代码上的时间多?不用多想就可以知道,后者的情况居多。

  说它好是因为自动化测试很炫。编写一个简单的程序,就可以执行无数次测试用例,还可以发现很多软件缺陷。在应用程序的代码改变后或需要进行回归测试(regression test)时,自动化测试代码可以被多次重复使用。这太妙了!太神奇了!简直应该对它顶礼膜拜!如果根据运行的测试用例多少来评价测试人员的能力的话,自动化测试铁定排名第一。但如果把评价标准变成根据所运行的测试用例的优劣来排名,结论就完全不同了。

  在软件行业,自动化测试已经行之多年,有些领域甚至已经有几十年历史了,但为什么软件发布到最终用户手里时还会出问题?这是因为自动化测试和开发人员所做的其他测试都有某些共通的问题。首先是运行环境,代码运行的环境是一个测试环境,而不是一个真实的用户环境。因为自动化测试代码并不非常可靠(毕竟,它也属于软件的范畴),所以基本不会使用客户的真实数据库来运行自动化测试代码。如果自动化测试需要在数据库中删除或添加一些数据,想象一下哪个客户愿意在他们的真实数据库中运行这些代码?自动化测试还有一个致命弱点就是“预言家难题”(oracle problem),至今尚无解决方案。

  这里的“预言家难题”(oracle problem)指的是测试中最艰巨的任务之一,就是在运行一个测试用例时,如何才能知道被测试软件确实完成了它应该完成的任务?被测试软件是否输出了正确的结果?在运行过程中,是否带来任何副作用?如何才能确信这一点?如果给定一个用户环境,特定的数据配置和输入顺序,是否存在一个“预言家”可以根据这些情况做出这样的断言:“软件确实做了,也只做了它所应该做的事”?现实情况下,往往由于软件的设计规格说明书(spec)并不完整,或者根本没有,这导致软件的测试人员也没有办法做这个断言。

  缺少这样一个预言家,自动化测试就只能找到那些最极端的问题,比如程序崩溃(crash)、死机(hang)或突发异常(exception)的情况。因为自动化测试本身就是一个软件,所以不仅被测试的软件会崩溃,测试代码也常常会发生崩溃。那些比较微妙或复杂的错误便如此这般被略过了。看看第1章就知道,有多少这样的关键错误躲过了测试,悄悄地溜入正式发布的代码。自动化确实很重要,但光靠它还不够,过度依赖自动化测试会为程序的最终成功带来隐患。

  现在,测试人员该怎么办呢?如果测试人员不能依靠开发人员的缺陷预防工具和自动化手段,他们还能寄希望于什么呢?唯一的答案就是手工测试。

相关链接:

软件缺陷预防

《2023软件测试行业现状调查报告》独家发布~

精彩评论

  • jskongzhi
    2011-8-12 20:03:42

    1.        深圳市精视控制技术有限公司,占据深圳工业资源优势,由专业从事工业自动化系统硬件方案和软件工程师组成的研发客户团队。通过专业知识积累了多年的应用经验,服务广大工业自动化用户,熟练现场实际应用提出最佳解决方案。特别针对机器视觉系统开发的无风扇视觉控制器,更是国内首创自主研发生产的高端视觉控制器。借势国内近几年机器视觉的快速发展和广大机器视觉系统业内的新老朋友的支持公司不断完善发展为机器视觉控制器最佳供应商。

  • windshl
    2011-3-09 16:02:53

    自动化无处不在,但也不能太迷信自动化

关注51Testing

联系我们

快捷面板 站点地图 联系我们 广告服务 关于我们 站长统计 发展历程

法律顾问:上海兰迪律师事务所 项棋律师
版权所有 上海博为峰软件技术股份有限公司 Copyright©51testing.com 2003-2024
投诉及意见反馈:webmaster@51testing.com; 业务联系:service@51testing.com 021-64471599-8017

沪ICP备05003035号

沪公网安备 31010102002173号