经典的软件测试全过程描述
作者:网络转载 发布时间:[ 2013/11/6 11:37:53 ] 推荐标签:
1.7AdhocTest,ExploratoryTest“探索式”的测试
“AdHoc”原意是指“特定的,一次性的”。
什么叫“特定”测试?或者“探索式”的测试?
是为了某一个特定目的进行的测试,这一次,以后一般也不会重复测试。在软件工程的实践中,“adhoc”大部分是指随机进行的,探索性的测试。
比如:测试人员阿毛拿到了一个新的构建,按计划是进行模块A的功能测试,但是他灵机一动,想看看另一个功能B做得如何,或者想看看模块A在某种边界条件下会出现什么问题,于是他“adhoc”一把,居然在这一功能模块中发现了不少小强。
“adhoc”也意味着测试是尝试性的,“我来试试,在这个对话框中一通乱按,然后随意改变窗口大小,看看会出什么问题…”,如果没问题,那么以后也不会再这么做了。
一般情况下,测试人员不会花很多时间进行特定测试,但是在一些缺乏管理的团队中,很多时候测试人员不知道自己此时应该做什么,只好做一些看似“adhoc”的测试,比如随机测试各个功能的各个方面。这些测试理论上都应该由测试管理人员规划好属于各个功能模块的测试用例中。
在一个团队中,“adhoc”太多是一个管理不好的标志,因为“adhoc”是指那些一时想到要做,但是以后也没有计划经常重复的测试计划。
问:我听说有人是“adhoc”测试的高手,这是什么意思?
答:有很多测试人员会按部班地进行测试,但是还有一些人头脑比较灵活,喜欢另辟蹊径,测试一些一般人不会想到的场景,这些人往往会发现更多的小强。开发人员对这样的“adhoc”高手是又爱又恨。
问:同时看问题要分两方面,有些“adhoc”发现的小强在正常使用软件中几乎不会出现,我们要不要花时间“adhoc”?
答:现在一些成功的通用软件的用户以百万计,按部班的测试计划很难包括很多实际的场景,这时,“adhoc”测试能够发现重要的问题;另外一些风险很大的领域,例如安全性,一旦出了问题,威胁会相当大,这时要多鼓励一些“adhoc”测试,以弥补普通测试的不足。从这个意义上说,“adhoc”测试可以用来衡量当前测试用例的完备性,如果你探索了半天,都没有发现什么在现有测试用例之外的问题,那说明现有的测试用例是比较完备的。
“adhoc”测试的测试流程是不可重复的,因为它的测试都是“特定”测试,没法重复。由于这一原因,“adhoc”测试不能自动化,这一点而言,还达不到CMM的第二级–可重复级。
作为管理人员来说,如果太多小强是在“adhoc”出来的,那我们要看看测试计划是否基于实际的场景,开发人员的代码逻辑是否完善,等等。同时,要善于把看似“adhoc”的测试用例抽象出来,包括到以后的测试计划中。
1.8RegressionTest回归测试
问:我听说不少关于RegressionTest的介绍,但是它到底是怎么“回归”法?回归到哪里去?我还是没搞懂。
答:Regress的英语定义是:returntoaworseorlessdevelopedstate.是倒退,退化,退步的意思。
在软件工程中,如果一个模块或功能以前是正常工作的,但是在一个新的构建中出了问题,那这个模块出现了一个“退步”-regression,从正常工作的稳定状态退化到不正常工作的不稳定状态。
在一个模块的功能逐步完成的同时,和此功能有关的测试用例也同样在完善中。一旦有关的测试用例通过,我们得到此模块的功能基准(baseline).
在某某版本,某某模块的某某测试用例是通过的!
如果测试人员发现了在新的构建版本某个测试用例失败了,这是一个“倒退”,在新版本上运行所有已通过的测试用例以验证没有“退化”情况发生,这个过程是一个“regressiontest”.如果这样的“倒退”是由于模块的功能发生了正常变化(由于设计变更的原因),那么测试用例的基准要修改,以和新的功能保持一致。
针对一个bugfix(拖鞋),我们也要作RegressionTest,
a)验证新的代码的确把缺陷改正了,
b)同时要验证新的代码没有把模块的现有功能破坏,没有regression。
所以我不也知道“回归测试”是如何的“回归”,我们可以理解为“回归到以前不正常的状态”。
回归测试好要自动化,因为对于每一个构建都要运行所有回归测试,以保证尽早发现问题。
1.9Scenario/integration/SystemTest场景/集成/系统测试
在软件开发的一定阶段,我们要对一个软件进行全面和系统的测试,以保证软件的各个模块都能共同工作,在各方面都能满足用户的要求。这时的测试叫系统/集成测试。
问:什么时候做系统测试?是不是越快越好?
答:原则上是当一个模块稳定的时候,可以把它集成到系统中,和整个系统一起进行测试,通常在软件产品需要阶段性发布的时候。
问:有一种叫ScenarioTest,是什么意思?
答:是以场景为驱动的集成测试,关于“场景”,大家可以看专门的介绍。这一方法的核心思想是:当用户使用一个软件的时候,他/她并不会独立使用各个模块,而是把软件做为一个整体来使用的。我们在做场景测试的时候,需要考虑在现实环境中用户使用软件的流程是什么样,然后模拟这个流程,看看软件能不能达到用户的需求。这样,能使软件符合用户使用的实际需求。
用一个数字照片编辑软件为例,这个软件的各个模块都是独立开发的,可是用户有一定的典型流程,如果这个流程走得不好,哪怕某个模块的质量再高,用户也不会满意。
相关推荐
更新发布
功能测试和接口测试的区别
2023/3/23 14:23:39如何写好测试用例文档
2023/3/22 16:17:39常用的选择回归测试的方式有哪些?
2022/6/14 16:14:27测试流程中需要重点把关几个过程?
2021/10/18 15:37:44性能测试的七种方法
2021/9/17 15:19:29全链路压测优化思路
2021/9/14 15:42:25性能测试流程浅谈
2021/5/28 17:25:47常见的APP性能测试指标
2021/5/8 17:01:11