一、测试的定义
通过人工或自动的手段,对被测对象进行检测的活动。目的在于发现被测对象是否实现用户的需求,或者弄清楚实际结果和预期结果之间的差异。
二、测试的目的
- 发现被测对象与用户需求间的差异,即找bug
- 通过测试活动发现并解决缺陷,增加人们对被测对象的质量信心
- 通过测试活动,获取被测对象的质量信息,为决策提供数据依据
- 通过测试活动,预防缺陷,从而降低项目或产品的风险
三、 测试的七大原则
- 测试证明软件存在缺陷:测试只能证明软件中存在缺陷,但并不能证明软件中不存在缺陷。软件测试是为了降低存在缺陷的可能性,即便是没有找到缺陷,也不能证明软件是完美的。
- 不可能执行穷尽测试:现在软件的规模越来越大,复杂度越来越高,想做到完全性的测试是不可能的。在测试阶段,测试人员可以根据风险和优先级来进行集中和高强度的测试,从而保证软件的质量。
- 测试尽早介入:尽早介入更能保证软件质量,降低风险和成本。测试人员一般在需求阶段就开始介入,使缺陷在需求或设计阶段就被发现,缺陷发现越早,修复的成本就越小。
- 缺陷存在集群现象(2/8原则):缺陷集群性表明小部分模块包含大部分的缺陷。软件测试中存在Pareto原则:80%的缺陷发现在20%的模块中。 一个功能模块发现的缺陷越高,那存在的未被发现的缺陷也越高,故发现的缺陷与未发现的缺陷成正比。
- 杀虫剂悖论:反复使用相同的杀虫剂会导致害虫对杀虫剂产生免疫而无法杀死害虫。软件测试也一样。如果一直使用相同的测试方法或手段,可能无法发现新的bug。为了解决这个问题,测试用例应当定期修订和评审,增