技术开发 频道

测试用例设计方法

【IT168 技术文章】

    1.
    测试用例设计方法
    1.1.
    白盒测试的测试用例设计(逻辑覆盖法)
    这种方法是从程序内部的逻辑结构出发选取测试用例,因此要求测试用例设计人员对程序的逻辑结构十分清楚,甚至应掌握源程序的所有细节。
    1.1.1.
    语句覆盖
    设计若干测试用例,运行被测试程序,使得每个可执行语句至少执行一次。
    1.1.2.
    判断覆盖
    设计若干测试用例,运行被测试程序,使得程序中每个判断的真值分支和假值分支至少经历一次。对象是每个判断。
    1.1.3.
    条件覆盖
    设计测试用例,运行被测试程序,使得程序中每个判断中的每个条件的可能取值情况至少满足一次。对象是每个条件。
    1.1.4.
    判断—条件覆盖
    设计测试用例,运行被测试程序,使得程序的每个判断中的每个条件的所有可能取值组合至少出现一次,并且使每个判断本身的判定结果也至少出现一次。
    1.1.5.
    路径覆盖
    设计测试用例,覆盖程序中所有的可能路径。
    1.2.
    黑盒测试的测试用例设计
    1.2.1.
    等价类划分
    是把所有可能的输入数据,即程序的输入域划分成若干部分(子集),然后从每一个子集中选取少数具有代表性的数据作为测试用例.
    该方法是一种重要的,常用的黑盒测试用例设计方法.
    该种设计方法分为划分等价类表和选取测试用例两步。
    划分等价类: 等价类是指某个输入域的子集合.在该子集合中,各个输入数据对于揭露程序中的错误都是等效的.并合理地假定:测试某等价类的代表值就等于对这一类其它值的测试.因此,可以把全部输入数据合理划分为若干等价类,在每一个等价类中取一个数据作为测试的输入条件,就可以用少量代表性的测试数据.取得较好的测试结果.等价类划分可有两种不同的情况:有效等价类和无效等价类.
    有效等价类:是指对于程序的规格说明来说是合理的、有意义的输入数据构成的集合.利用有效等价类可检验程序是否实现了规格说明中所规定的功能和性能.
    无效等价类是指对于程序的规格说明书来说不合理的、无意义的输入数据构成的集合.利用无效等价类可检查程序中功能和性能的实现是否有不符合规格说明书的地方。.
    设计测试用例时,要同时考虑这两种等价类.因为,软件不仅要能接收合理的数据,也要能经受意外的考验.这样的测试才能确保软件具有更高的可靠性.
    等价类划分的原则:
    (1)
    如果输入条件规定了取值范围或值得个数,则可以确立一个有效等价类和两个无效等价类。如:1 < x < 99,则1 < x < 99是有效等价类,而x > = 99 和 x < = 1 就是两个无效等价类;
    (2)
    如果输入条件规定了输入值的集合,或者是规定了“必须如何”的条件,这是可以确立一个有效等价类和一个无效等价类。如:必须为正整数,则取正整数是有效等价类,而非正整数的是无效等价类;
    (3)
    如果输入条件是一个布尔值,则可以确定一个有效等价类和一个无效等价类,则满足条件的为有效等价类,而不满足条件的为无效等价类;
    (4)
    如果规定了输入数据的一组值(假定n个),并且程序要对每个输入值分别进行处理。这样可以为每一个输入值确立一个有效等价类,此外可以确立针对这组值确立一个无效等价类,如:{1、5、10、20},则取1、5、10、20分别建立有效等价类,而非1、5、10、20的值是无效等价类;
    (5)
    如果规定了输入数据必须遵守的规则,则可以确立一个有效等价类(符合规则)和若干个无效等价类(从不同角度违反规则)。如:则满足规则的为有效等价类,则不满足规则的分别建立无效等价类;
    (6)
    如果在确知已划分的等价类中各元素在程序中的处理方式不同,则应将此等价类进一步分成更小的等价类。
    测试用例设计与选择:
    (1)
    为每一个等价类规定一个唯一的编号。
    (2)
    设计一个新的测试用例,使其尽可能多地覆盖尚未被覆盖的有效等价类,重复这一步,直到所有的有效等价类都被覆盖为止。
    (3)
    设计一个新的测试用例,使其近覆盖一个尚未被覆盖的无效等价类,重复这一步,直到所有的无效等价类都被覆盖为止。
    1.2.2.
    边界值分析
    是对等价划分方法的补充。
    (1)
    边界值分析方法的考虑:
    长期的测试工作经验告诉我们,大量的错误是发生在输入或输出范围的边界上,而不是发生在输入输出范围的内部.因此针对各种边界情况设计测试用例,可以查出更多的错误.
    使用边界值分析方法设计测试用例,首先应确定边界情况。通常输入等价类与输出等价类的边界,就是应着重测试的边界情况,应当选取正好等于、刚刚大于、或刚刚小于边界的值作为测试数据。
    (2)
    边界值分析方法选择测试用例的原则在很多方面与等价划分方法类似。
    A.如果输入条件规定了值的范围,则应取刚达到这个范围的边界值,及刚刚超越这个范围边界的值作为测试输入数据。
    B.如果输入条件规定了值的个数,则用最大个数、最小个数、比最大个数多1,比最小个数少1的数做为测试数据。
    C.根据规格说明书的每个输出条件,使用前面的原则A。
    D.根据规格说明书的每个输出条件,使用前面的原则B。
    E.如果程序的规格说明书给出的输入域或输出域是有序集合,则应选取集合的第一个元素和最后一个元素作为测试用例。
    F.如果程序中使用了一个内部数据结构,则应当选择这个内部数据结构的边界值作为测试用例。
    1.2.3.

    错误推测法
    错误推测法: 基于经验和直觉推测程序中所有可能存在的各种错误, 从而有针对性的设计测试用例的方法.
    错误推测方法的基本思想: 列举出程序中所有可能有的错误和容易发生错误的特殊情况,根据他们选择测试用例. 例如, 在单元测试时曾列出的许多在模块中常见的错误. 以前产品测试中曾经发现的错误等, 这些就是经验的总结. 还有, 输入数据和输出数据为0的情况. 输入表格为空格或输入表格只有一行. 这些都是容易发生错误的情况. 可选择这些情况下的例子作为测试用例.

0
相关文章