等价类划分,指的是一种典型的、重要的
黑盒测试方法。其就是解决如何选择适当的数据子集来代表整个
数据集的问题,通过降低测试的数目去实现“合理的”覆盖,以此发现更多的
软件缺陷,统计好数据后由此对软件进行改进升级。
等价类划分法将程序所有可能的输入数据(有效的和无效的)划分成若干个等价类。然后从每个部分中选取具有代表性的数据当做测试用例进行合理的分类,测试用例由有效等价类和
无效等价类的代表组成,从而保证测试用例具有
完整性和代表性。利用这一方法设计测试用例可以不考虑程序的内部结构,以需求规格说明书为依据,选择适当的典型子集,认真分析和推敲说明书的各项需求,特别是功能需求,尽可能多地发现错误。等价类划分法是一种系统性的确定要输入的测试条件的方法。
由于等价类是在需求规格说明书的基础上进行划分的,并且等价类划分不仅可以用来确定测试用例中的数据的输入输出的精确取值范围,也可以用来准备
中间值、状态和与
时间相关的数据以及接口参数等,所以等价类可以用在
系统测试、
集成测试和组件测试中,在有明确的条件和限制的情况下,利用等价类划分技术可以设计出完备的测试用例。这种方法可以减少设计一些不必要的测试用例,因为这种测试用例一般使用相同的等价类数据,从而使测试对象得到同样的反映行为。对于等价类我们从以下几个方面讨论它的
划分方法。等价类划分的方法分为两个主要的步骤,划分等价类型和设计测试用例。
有效等价类指对于程序规格说明来说,是合理的、有意义的输入数据构成的集合。利用有效等价类可以检验程序是否实现了规格说明预先规定的功能和性能。有效等价类可以是一个,也可以是多个,根据系统的输入域划分若干部分,然后从每个部分中选取少数有代表性数据当做
数据测试的测试用例,等价类是输入域的集合。以下是对有效等价类数据集的一些例子。
无效等价类和有效等价类相反,无效等价类是指对于软件
规格说明而言,没有意义的、不合理的输入
数据集合。利用无效等价类,可以找出程序异常说明情况,检查程序的功能和性能的实现是否有不符合规格说明要求的地方。以下是无效等价类数据集的一些例子。
在规定了
输入数据的一组值中(假定有n个值),并且程序要对每个输入值分别处理的情况下,可以确定n个有效等价类和一个无效等价类。
在确定已划分的等价类中各元素在程序处理中的方式不同的情况下,则
应将该等价类进一步地划分为更小的等价类。
(2)将程序可能的输入数据分成若干个子集,从每个子集中选取一个有
代表性的数据作为测试用例。等价类是某个输入域的子集,在该子集中的每个输入数据的作用都是等效的。
(4)设计新的测试用例,使其仅覆盖一个尚未被覆盖的
无效等价类,按照这一步骤重复进行,直到所有的无效等价类都被覆盖为止。