测试管理方法之面向对象软件的测试用例的设计方法
白羽 2018-08-06 来源 :网络 阅读 792 评论 0

摘要:本文将带你了解测试管理方法之面向对象软件的测试用例的设计方法,希望对大家学测试管理有所帮助。

        本文将带你了解测试管理方法之面向对象软件的测试用例的设计方法,希望对大家学测试管理有所帮助。


目前,面向对象软件的测试用例的设计方法,还处于研究、发展阶段。与传统软件测试(测试用例的设计由软件的输入?处理?输出视图或单个模块的算法细节驱动)不同,面向对象测试关注于设计适当的操作序列以检查类的状态。

  12.4.1 测试类的方法

  前面已经讲过,软件测试从“小型测试”开始,逐步过渡到“大型测试”。对面向对象的软件来说,小型测试着重测试单个类和类中封装的方法。测试单个类的方法主要有随机测试、划分测试和基于故障的测试等3种。

  1. 随机测试

  下面通过银行应用系统的例子,简要地说明这种测试方法。该系统的account(账户)类有下列操作: open(打开),setup(建立),deposit(存款),withdraw(取款),balance(余额),summarize(清单),creditLimit(透支限额)和close(关闭)。上列每个操作都可以应用于account类的实例,但是,该系统的性质也对操作的应用施加了一些限制,例如,必须在应用其他操作之前先打开账户,在完成了全部操作之后才能关闭账户。即使有这些限制,可做的操作也有许多种排列方法。一个 account类实例的最小行为历史包括下列操作:

open·setup·deposit·withdraw·close
  这就是对account类的最小测试序列。但是,在下面的序列中可能发生许多其他行为:

open·setup·deposit·[deposit|withdraw|balance|summarize|creditLimit]n·withdraw·close
  从上列序列可以随机地产生一系列不同的操作序列,例如:

  测试用例#r1:open·setup·deposit·deposit·balance·summarize·withdraw·close

  测试用例#r2:open·setup·deposit·withdraw·deposit·balance·creditLimit·withdraw·close

  执行上述这些及另外一些随机产生的测试用例,可以测试类实例的不同生存历史。

  2. 划分测试

  与测试传统软件时采用等价划分方法类似,采用划分测试(partition testing)方法可以减少测试类时所需要的测试用例的数量。首先,把输入和输出分类,然后设计测试用例以测试划分出的每个类别。下面介绍划分类别的方法。

  (1) 基于状态的划分

  这种方法根据类操作改变类状态的能力来划分类操作。再一次考虑account类,状态操作包括deposit和withdraw,而非状态操作有balance, summarize和creditLimit。设计测试用例,以分别测试改变状态的操作和不改变状态的操作。例如,用这种方法可以设计出如下的测试用例:

  测试用例#p1:open·setup·deposit·deposit·withdraw·withdraw·close

  测试用例#p2:open·setup·deposit·summarize·creditLimit·withdraw·close

  测试用例#P1改变状态,而测试用例#P2测试不改变状态的操作(在最小测试序列中的操作除外)。

  (2) 基于属性的划分

  这种方法根据类操作使用的属性来划分类操作。对于account类来说,可以使用属性balance来定义划分,从而把操作划分成3个类别:

  . 使用balance的操作;

  . 修改balance的操作;

  . 不使用也不修改balance的操作。

  然后,为每个类别设计测试序列。

  (3) 基于功能的划分

  这种方法根据类操作所完成的功能来划分类操作。例如,可以把account类中的操作分类为初始化操作(open,setup),计算操作(deposit, withdraw),查询操作(balance, summarize,creditLimit)和终止操作(close)。然后为每个类别设计测试序列。

  3. 基于故障的测试

  基于故障的测试(fault based testing)与传统的错误推测法类似,也是首先推测软件中可能有的错误,然后设计出最可能发现这些错误的测试用例。例如,软件工程师经常在问题的边界处犯错误,因此,在测试SQRT(计算平方根)操作(该操作在输入为负数时返回出错信息)时,应该着重检查边界情况: 一个接近零的负数和零本身。其中“零本身”用于检查程序员是否犯了如下错误:
 把语句if(x>=0)calculate_square_root( );

  误写成if(x>0)calculate_square_root( );

  为了推测出软件中可能有的错误,应该仔细研究分析模型和设计模型,而且在很大程度上要依靠测试人员的经验和直觉。如果推测得比较准确,则使用基于故障的测试方法能够用相当低的工作量发现大量错误;反之,如果推测不准,则这种方法的效果并不比随机测试技术的效果好。

  12.4.2 集成测试方法

  开始集成面向对象系统以后,测试用例的设计变得更加复杂。在这个测试阶段,必须对类间协作进行测试。为了举例说明设计类间测试用例的方法,我们扩充 12.4.1小节引入的银行系统的例子,使它包含图12.3所示的类和协作。图中箭头方向代表消息的传递方向,箭头线上的标注给出了作为由消息所蕴含的协作的结果而调用的操作。

  和测试单个类相似,测试类协作可以使用随机测试方法和划分测试方法,以及基于情景的测试和行为测试来完成。

  1. 多类测试

  Kirani和Tsai建议使用下列步骤,以生成多个类的随机测试用例。

  . 对每个客户类,使用类操作符列表来生成一系列随机测试序列。这些操作符向服务器类实例发送消息

  . 对所生成的每个消息,确定协作类和在服务器对象中的对应操作符。

  . 对服务器对象中的每个操作符(已经被来自客户对象的消息调用),确定传递的消息。

  . 对每个消息,确定下一层被调用的操作符,并把这些操作符结合进测试序列中。

  . 为了说明怎样用上述步骤生成多个类的随机测试用例,考虑Bank类相对于ATM类(见图12.3)的操作序列:

verifyAcct·verifyPIN·[(verifyPolicy·withdrawReq)|depositReq|acctInfoREQ]n
  对Bank类的随机测试用例可能是:

  测试用例#r3:verifyAcct·verifyPIN·depositReq

  为了考虑在上述这个测试中涉及的协作者,需要考虑与测试用例#r3中的每个操作相关联的消息。Bank必须和ValidationInfo协作以执行 verifyAcct和verifyPIN,Bank还必须和Account协作以执行depositReq。因此,测试上面提到的协作的新测试用例是:

  测试用例#r4:verifyAcctBank·[validAcctValidationInfo]·verifyPINBank·[validPINvalidationInfo]·depositReq·[depositaccount]

  多个类的划分测试方法类似于单个类的划分测试方法(见12.4.1节)。但是,对于多类测试来说,应该扩充测试序列以包括那些通过发送给协作类的消息而被调用的操作。另一种划分测试方法,根据与特定类的接口来划分类操作。如图12.3所示,Bank类接收来自ATM类和Cashier类的消息,因此,可以通过把Bank类中的方法划分成服务于ATM的和服务于Cashier的两类来测试它们。还可以用基于状态的划分(见12.4.1节),进一步精化划分。


  2. 从动态模型导出测试用例

  在第9章中已经讲过,怎样用状态转换图作为表示类的动态行为的模型。类的状态图可以帮助我们导出测试该类(及与其协作的那些类)的动态行为的测试用例。图12.4给出了前面讨论过的account类的状态图,从图可见,初始转换经过了empty acct和setup acct这两个状态,而类实例的大多数行为发生在working acct状态中,最终的withdraw和close使得account类分别向nonworking acct状态和dead acct状态转换。


  图12.4 account类的状态转换图

  设计出的测试用例应该覆盖所有状态,也就是说,操作序列应该使得account类实例遍历所有允许的状态转换:

  测试用例#s1:open·setupAccnt·deposit(initial)·withdraw(final)·close

  应该注意,上面列出的序列与12.4.1节讨论的最小测试序列相同。向最小序列中加入附加的测试序列,可以得出其他测试用例:

  测试用例#s2:open·setupAccnt·deposit(initial)·deposit·balance·credit·withdraw(final)·close

  测试用例#s3:open·setupAccnt·deposit(initial)·deposit·withdraw·accntInfo·withdraw(final)·close
还可以导出更多测试用例,以保证该类的所有行为都被适当地测试了。在类的行为导致与一个或多个类协作的情况下,应该使用多个状态图去跟踪系统的行为流。    

本文由职坐标整理并发布,希望对同学们有所帮助。了解更多详情请关注职坐标软件测试之测试管理频道!

本文由 @白羽 发布于职坐标。未经许可,禁止转载。
喜欢 | 0 不喜欢 | 0
看完这篇文章有何感觉?已经有0人表态,0%的人喜欢 快给朋友分享吧~
评论(0)
后参与评论

您输入的评论内容中包含违禁敏感词

我知道了

助您圆梦职场 匹配合适岗位
验证码手机号,获得海同独家IT培训资料
选择就业方向:
人工智能物联网
大数据开发/分析
人工智能Python
Java全栈开发
WEB前端+H5

请输入正确的手机号码

请输入正确的验证码

获取验证码

您今天的短信下发次数太多了,明天再试试吧!

提交

我们会在第一时间安排职业规划师联系您!

您也可以联系我们的职业规划师咨询:

小职老师的微信号:z_zhizuobiao
小职老师的微信号:z_zhizuobiao

版权所有 职坐标-一站式IT培训就业服务领导者 沪ICP备13042190号-4
上海海同信息科技有限公司 Copyright ©2015 www.zhizuobiao.com,All Rights Reserved.
 沪公网安备 31011502005948号    

©2015 www.zhizuobiao.com All Rights Reserved

208小时内训课程