找错―面向对象软件的测试技术与方法[3]

发表于:2010-05-31来源:作者:点击数: 标签:面向对象软件技术
找错― 面向对象 软件的测试技术与方法[3] 软件测试 例如一个 银行 信用卡的应用,其中有一个类:计算(account)。该account的操作有:open、setup、deposit、withdraw、balance、summarize、creditlimit和close。 这些操作中的每一项都可用于计算,但open、c

  找错―面向对象软件的测试技术与方法[3]   软件测试

  例如一个银行信用卡的应用,其中有一个类:计算(aclearcase/" target="_blank" >ccount)。该account的操作有:open、setup、deposit、withdraw、balance、summarize、creditlimit和close。

  这些操作中的每一项都可用于计算,但open、close必须在其他计算的任何一个操作前后执行,即使open和close有这种限制,这些操作仍有多种排列。所以一个不同变化的操作序列可由于应用不同而随机产生,如一个Account实例的最小行为生存史可包括以下操作:

  open+setup+deposit+[deposit|withdraw |balance|summarize|creditlimit]+withdraw+close

  从此可见,尽管这个操作序列是最小测试序列,但在这个序列内仍可以发生许多其他的行为。

  4.类层次的分割测试

  这种测试可以减少用完全相同的方式检查类测试用例的数目。这很像传统软件测试中的等价类划分测试。分割测试又可分三种。

  (1)基于状态的分割 按类操作是否改变类的状态来分割(归类)。这里仍用account类为例,改变状态的操作有deposit、withdraw,不改变状态的操作有balance、 summarize、creditlimit。如果测试按检查类操作是否改变类状态来设计,则结果如下:

  用例1:执行操作改变状态

  open+setup+deposit+deposit+withdraw+withdraw+close。

  用例2:执行操作不改变状态

  open+setup+deposit+summarize+creditlimit+withdraw+close。

  (2)基于属性的分割 按类操作所用到的属性来分割(归类),如果仍以一个account类为例,其属性creditlimit能被分割为三种操作:用creditlimit的操作,修改creditlimit的操作,不用也不修改creditlimit的操作。

  这样,测试序列就可按每种分割来设计。

  (3)基于类型的分割 按完成的功能分割(归类)。例如,在account类的操作中,可以分割为:初始操作open、setup;计算操作deposit、withdraw;查询操作balance、summarize、creditlimit;终止操作close。

  5.由行为模型(状态、活动、顺序和合作图)导出的测试

  状态转换图(STD)可以用来帮助导出类的动态行为的测试序列,以及这些类与之合作的类的动态行为测试序列。

  为了说明问题,仍用前面讨论过的account类。开始由empty acct状态转换为setup acct状态。类实例的大多数行为发生在working acct状态中。而最后,取款和关闭分别使account类转换到non-working acct和dead acct状态。

  这样,设计的测试用例应当是完成所有的状态转换。换句话说,操作序列应当能导致account类所有允许的状态进行转换。

  测试用例:

  open+setupAcct+deposit(initial)+withdraw(final)+close

  还可导出更多的测试用例,以保证该类所有行为被充分检查。

  小资料

  OO软件测试的主要目标与传统软件测试一样,即用最小量的投入来最大限度地发现软件存在的错误。但由于OO软件具有的特殊性质,OO软件测试在内容、策略和方法上与传统软件测试不完全相同。

  (1)OOA(Object-Oriented Analysis)和OOD(Object-Oriented Design)的评审与传统软件的分析和设计相同,应给出相应的评审检查表。

  (2)OOP(Object-Oriented Programming)后,单元和组装测试策略必须做相应的改变。

  (3)测试用例设计必须说明OO软件特有的性质。

原文转自:http://www.ltesting.net