测试用例设计(全面,转自51)

上一篇 / 下一篇  2008-12-09 14:10:28 / 个人分类:QTP及功能测试

测试用例(Test Case)是为某个特殊目标而编制的一组测试输入、执行条件以及预期结果,以便测试某个程序路径或核实是否满足某个特定需求。51Testing软件测试网.q}y3{/?M8QVP

$jcre }5p @154414测试用例(Test Case)目前没有经典的定义。比较通常的说法是:指对一项特定的软件产品进行测试任务的描述,体现测试方案、方法、技术和策略。内容包括测试目标、测试环境、输入数据、测试步骤、预期结果、测试
脚本等,并形成文档。51Testing软件测试网.i([)khe E'ZNF
51Testing软件测试网 x+R8p8T(a(NBd
不同类别的软件,测试用例是不同的。不同于诸如系统、工具、控制、游戏软件,管理软件的用户需求更加不统一,变化更大、更快。笔者主要从事企业管理软件的测试。因此我们的做法是把测试数据和测试脚本从测试用例中划分出来。测试用例更趋于是针对软件产品的功能、业务规则和业务处理所设计的测试方案。对软件的每个特定功能或运行操作路径的测试构成了一个个测试用例。
Y/vM)MCEexy|Z15441451Testing软件测试网s2m-g2PDl%cXi%@zN
随着中国软件业的日益壮大和逐步走向成熟,软件测试也在不断发展。从最初的由软件编程人员兼职测试到软件公司组建独立专职测试部门。测试工作也从简单测试演变为包括:编制测试计划、编写测试用例、准备测试数据、编写测试脚本、实施测试、测试评估等多项内容的正规测试。测试方式则由单纯手工测试发展为手工、自动兼之,并有向第三方专业测试公司发展的趋势。51Testing软件测试网!J xiA/Of
51Testing软件测试网0[%tM^9~L|7q.i6g
要使最终用户对软件感到满意,最有力的举措就是对最终用户的期望加以明确阐述,以便对这些期望进行核实并确认其有效性。测试用例反映了要核实的需求。然而,核实这些需求可能通过不同的方式并由不同的测试员来实施。例如,执行软件以便验证它的功能和性能,这项操作可能由某个测试员采用自动测试技术来实现;计算机系统的关机步骤可通过手工测试和观察来完成;不过,市场占有率和销售数据(以及产品需求),只能通过评测产品和竞争销售数据来完成。51Testing软件测试网gk?"o(M U5A-x'k
51Testing软件测试网Xod(tY
既然可能无法(或不必负责)核实所有的需求,那么是否能为测试挑选最适合或最关键的需求则关系到项目的成败。选中要核实的需求将是对成本、风险和对该需求进行核实的必要性这三者权衡考虑的结果。
)zqm;h B;O0R.?pX/|15441451Testing软件测试网1mF.\pl6Fk`;J
确定测试用例之所以很重要,原因有以下几方面。51Testing软件测试网l.hNEy"S#H*g

O].t4@ |*M;Vl%r t154414测试用例构成了设计和制定测试过程的基础。51Testing软件测试网EQfO n
测试的“深度”与测试用例的数量成比例。由于每个测试用例反映不同的场景、条件或经由产品的事件流,因而,随着测试用例数量的增加,您对产品质量和测试流程也就越有信心。
"[GSb$HseE154414判断测试是否完全的一个主要评测方法是基于需求的覆盖,而这又是以确定、实施和/或执行的测试用例的数量为依据的。类似下面这样的说明:“95 % 的关键测试用例已得以执行和验证”,远比“我们已完成 95 % 的测试”更有意义。51Testing软件测试网b!sCeA9xE
测试工作量与测试用例的数量成比例。根据全面且细化的测试用例,可以更准确地估计测试周期各连续阶段的时间安排。51Testing软件测试网5@ `_F(c:Fj2?"F%@f
测试设计和开发的类型以及所需的资源主要都受控于测试用例。
QlGXQq4s A$ip154414测试用例通常根据它们所关联关系的测试类型或测试需求来分类,而且将随类型和需求进行相应地改变。最佳方案是为每个测试需求至少编制两个测试用例:51Testing软件测试网R~4]3Kr7Z'MW

:D,pC(J_ ra }/}(D154414·一个测试用例用于证明该需求已经满足,通常称作正面测试用例;51Testing软件测试网m@S4{.I!g
·另一个测试用例反映某个无法接受、反常或意外的条件或数据,用于论证只有在所需条件下才能够满足该需求,这个测试用例称作负面测试用例。51Testing软件测试网 i_ua ZHa3yJjN i
51Testing软件测试网@p:Ee5ka4~
51Testing软件测试网9m-Z'] ?zd2\Y+d {8m X
一、测试用例是软件测试的核心51Testing软件测试网V:Myq#h ^

5`/``9Vm ju6MXE154414软件测试的重要性是毋庸置疑的。但如何以最少的人力、资源投入,在最短的时间内完成测试,发现软件系统的缺陷,保证软件的优良品质,则是软件公司探索和追求的目标。每个软件产品或软件开发项目都需要有一套优秀的测试方案和测试方法。
.j&g%|.j[Z#D$O\o154414
Bo VE-MN5T Tw E`154414影响软件测试的因素很多,例如软件本身的复杂程度、开发人员(包括分析、设计、编程和测试的人员)的素质、测试方法和技术的运用等等。因为有些因素是客观存在的,无法避免。有些因素则是波动的、不稳定的,例如开发队伍是流动的,有经验的走了,新人不断补充进来;一个具体的人工作也受情绪等影响,等等。如何保障软件测试质量的稳定?有了测试用例,无论是谁来测试,参照测试用例实施,都能保障测试的质量。可以把人为因素的影响减少到最小。即便最初的测试用例考虑不周全,随着测试的进行和软件版本更新,也将日趋完善。51Testing软件测试网8v*PG ~ | ~7x+P?"s-eN

LN,tZC4}ZrU154414因此测试用例的设计和编制是软件测试活动中最重要的。测试用例是测试工作的指导,是软件测试的必须遵守的准则。更是软件测试质量稳定的根本保障。51Testing软件测试网B"Xz&X]LW A _4uT

U%xCw(t'[154414二、编制测试用例
Ul*Sdn(I15441451Testing软件测试网qTIG6[:SBIpn$}
着重介绍一些编制测试用例的具体做法。
pq)E,z,K4M t15441451Testing软件测试网S2@N)D,d FjM
1、测试用例文档51Testing软件测试网8Uv1f0Koh~} {d*r

2wH7R5K3d} o154414编写测试用例文档应有文档模板,须符合内部的规范要求。测试用例文档将受制于测试用例管理软件的约束。
:{6wLzRQ r-qqX154414软件产品或软件开发项目的测试用例一般以该产品的软件模块或子系统为单位,形成一个测试用例文档,但并不是绝对的。
7d0k8} Zacg15441451Testing软件测试网pIP,M\Rvc[
测试用例文档由简介和测试用例两部分组成。简介部分编制了测试目的、测试范围、定义术语、参考文档、概述等。测试用例部分逐一列示各测试用例。每个具体测试用例都将包括下列详细信息:用例编号、用例名称、测试等级、入口准则、验证步骤、期望结果(含判断标准)、出口准则、注释等。以上内容涵盖了测试用例的基本元素:测试索引,测试环境,测试输入,测试操作,预期结果,评价标准。51Testing软件测试网j~zs6T

$i4F v9a)A[F1544142、测试用例的设置
(]G~!vf;i9nQs154414
zm(]:h$S[hjUQg154414我们早期的测试用例是按功能设置用例。后来引进了路径分析法,按路径设置用例。目前演变为按功能、路径混合模式设置用例。
*@c Y:``u3t y15441451Testing软件测试网"q/T)taL6X
功能测试是最简捷的,按用例规约遍历测试每一功能。
e*fNJ I4XUli%L154414
8a"@NfB F.k:^154414对于复杂操作的程序模块,其各功能的实施是相互影响、紧密相关、环环相扣的,可以演变出数量繁多的变化。没有严密的逻辑分析,产生遗漏是在所难免。路径分析是一个很好的方法,其最大的优点是在于可以避免漏测试。51Testing软件测试网rDO ew#G"k$f
51Testing软件测试网G+}/i&G3x*Bs f
但路径分析法也有局限性。在一个非常简单字典维护模块就存在十余条路径。一个复杂的模块会有几十到上百条路径是不足为奇的。笔者以为这是路径分析比较合适的使用规模。若一个子系统有十余个或更多的模块,这些模块相互有关联。再采用路径分析法,其路径数量成几何级增长,达5位数或更多,就无法使用了。那么子系统模块间的测试路径或测试用例还是要靠传统方法来解决。这是按功能、路径混合模式设置用例的由来。
6Bs Q r(H154414
{qO.p&hO&a&I1544143、设计测试用例
_1_*DD V(e6rJ;h154414
f1Xk(GyMxPQ?154414测试用例可以分为基本事件、备选事件和异常事件。设计基本事件的用例,应该参照用例规约(或设计规格说明书),根据关联的功能、操作按路径分析法设计测试用例。而对孤立的功能则直接按功能设计测试用例。基本事件的测试用例应包含所有需要实现的需求功能,覆盖率达100%。51Testing软件测试网\(o7mwm?

p] ~2`*l4z:Q_154414设计备选事件和异常事件的用例,则要复杂和困难得多。例如,字典的代码是唯一的,不允许重复。测试需要验证:字典新增程序中已存在有关字典代码的约束,若出现代码重复必须报错,并且报错文字正确。往往在设计编码阶段形成的文档对备选事件和异常事件分析描述不够详尽。而测试本身则要求验证全部非基本事件,并同时尽量发现其中的软件缺陷。
,q7i9s u KQ/z154414
RJ8A8R$^ `154414可以采用软件测试常用的基本方法:等价类划分法、边界值分析法、错误推测法、因果图法、逻辑覆盖法等设计测试用例。视软件的不同性质采用不同的方法。如何灵活运用各种基本方法来设计完整的测试用例,并最终实现暴露隐藏的缺陷,全凭测试设计人员的丰富经验和精心设计。51Testing软件测试网 d'D B[f,sw,G2h

$b F t}5Do)_154414三、测试用例在软件测试中的作用51Testing软件测试网D0Zw%y#nkh

b"[ OvWv"O1544141、指导测试的实施
l}4T[1ce@:D15441451Testing软件测试网wk,IA2q,]
测试用例主要适用于集成测试、系统测试和回归测试。在实施测试时测试用例作为测试的标准,测试人员一定要按照测试用例严格按用例项目和测试步骤逐一实施测试。并对测试情况记录在测试用例管理软件中,以便自动生成测试结果文档。
~d5HAcJGg*M15441451Testing软件测试网:ND9bmg1S |tMQ
根据测试用例的测试等级,集成测试应测试那些用例,系统测试和回归测试又该测试那些用例,在设计测试用例时都已作明确规定,实施测试时测试人员不能随意作变动。
yJ5o(NH3iv154414
#yN-a%H V2D*s _\H1544142、规划测试数据的准备51Testing软件测试网oXJR$N)_#J

/bo"Ea&m*{7y0KY154414在我们的实践中测试数据是与测试用例分离的。按照测试用例配套准备一组或若干组测试原始数据,以及标准测试结果。尤其象测试报表之类数据集的正确性,按照测试用例规划准备测试数据是十分必须的。
i!V(F ]y[QDF154414除正常数据之外,还必须根据测试用例设计大量边缘数据和错误数据。51Testing软件测试网*I@ u&nkn-H Z&y

uqDus#P+F{3a T1544143、编写测试脚本的"设计规格说明书"51Testing软件测试网Q[4Ai ~
51Testing软件测试网j&D m$}b6WX
为提高测试效率,软件测试已大力发展自动测试。自动测试的中心任务是编写测试脚本。如果说软件工程中软件编程必须有设计规格说明书,那么测试脚本的设计规格说明书就是测试用例。
3x)N]H&k}lm15441451Testing软件测试网u/v-JI!O!A r V
4、评估测试结果的度量基准51Testing软件测试网co(K2]n6y g*{ y$^p"u
51Testing软件测试网%q u8y1b t]
完成测试实施后需要对测试结果进行评估,并且编制测试报告。判断软件测试是否完成、衡量测试质量需要一些量化的结果。例:测试覆盖率是多少、测试合格率是多少、重要测试合格率是多少,等等。以前统计基准是软件模块或功能点,显得过于粗糙。采用测试用例作度量基准更加准确、有效。51Testing软件测试网!p4uxUj2rv

?jD d3vsF!_]oj1544145、分析缺陷的标准51Testing软件测试网@Z W q]3}

5ID9f;c2fv'D154414通过收集缺陷,对比测试用例和缺陷数据库,分析确证是漏测还是缺陷复现。漏测反映了测试用例的不完善,应立即补充相应测试用例,最终达到逐步完善软件质量。而已有相应测试用例,则反映实施测试或变更处理存在问题。51Testing软件测试网 j/I ha._b"f3YG

~7Zi,OUt!iv154414四、相关问题
|T USGz@154414
D-ylK`s:xF1544141、测试用例的评审
3t xzOk-_bL15441451Testing软件测试网t.f%q j:f)R$VO2M
测试用例是软件测试的准则,但它并不是一经编制完成就成为准则。测试用例在设计编制过程中要组织同级互查。完成编制后应组织专家评审,需获得通过才可以使用。评审委员会可由项目负责人、测试、编程、分析设计等有关人员组成,也可邀请客户代表参加。51Testing软件测试网%Xc*EhP agvI

\7n4W|3giM_0L1544142、测试用例的修改更新
#q WMl;H!cu o154414
F\ K|~154414测试用例在形成文档后也还需要不断完善。主要来自三方面的缘故:第一、在测试过程中发现设计测试用例时考虑不周,需要完善;第二、在软件交付使用后反馈的软件缺陷,而缺陷又是因测试用例存在漏洞造成;第三、软件自身的新增功能以及软件版本的更新,测试用例也必须配套修改更新。
)_ aoXh^D^15441451Testing软件测试网y o+u'A5S K @2x!i
一般小的修改完善可在原测试用例文档上修改,但文档要有更改记录。软件的版本升级更新,测试用例一般也应随之编制升级更新版本。51Testing软件测试网@0EC8EyF)|i
51Testing软件测试网7AXw Eta:i,Ylb
3、测试用例的管理软件51Testing软件测试网,O-p/hMO|!U
51Testing软件测试网 _+w/A @&oA
运用测试用例还需配备测试用例管理软件。它的主要功能有三个:第一、能将测试用例文档的关键内容,如编号、名称等等自动导入管理数据库,形成与测试用例文档完全对应的记录;第二、可供测试实施时及时输入测试情况;第三、最终实现自动生成测试结果文档,包含各测试度量值,测试覆盖表和测试通过或不通过的测试用例清单列表。51Testing软件测试网#gR4W8rF1@ C
51Testing软件测试网;f5w#m2X&h0w1X4mY
有了管理软件,测试人员无论是编写每日的测试工作日志、还是出软件测试报告,都会变得轻而易举。51Testing软件测试网 } Q&a u mR[
51Testing软件测试网$u A2Nh._B%i;ZKu
五、测试用例的设计51Testing软件测试网[)`+z!w9I

$fxB w"b%d)J154414(一)白盒技术51Testing软件测试网@\u6l)Nj"z
51Testing软件测试网u*{ vo4t K [
白盒测试是结构测试,所以被测对象基本上是源程序,以程序的内部逻辑为基础设计测试用例。
m2J`(fm q"?j1544141、逻辑覆盖
uZ4V9gu`E154414程序内部的逻辑覆盖程度,当程序中有循环时,覆盖每条路径是不可能的,要设计使覆盖程度较高的或覆盖最有代表性的路径的测试用例。下面根据图7-1所示的程序,分别讨论几种常用的覆盖技术。51Testing软件测试网`*l9wT+@
(1)语句覆盖。51Testing软件测试网 tV%P.C:l(j2Rwl
为了个提高发现错误的可能性,在测试时应该执行到程序中的每一个语句。语句覆盖是指设计足够的测试用例,使被测试程序中每个语句至少执行一次。51Testing软件测试网#B9EM~1c
如图7-1是一个被测试程序流程图:
FmW$JEh!f.w!s`n15441451Testing软件测试网;LPGUj3p9U @Dl H!u&R

:E,d"Z!xf Z9_154414(2)判定覆盖。
P@3K? m3^Wzx154414判定覆盖指设计足够的测试用例,使得被测程序中每个判定表达式至少获得一次“真”值和“假”值,从而使程序的每一个分支至少都通过一次,因此判定覆盖也称分支覆盖。51Testing软件测试网%k9Ukh0al7G
(3)条件覆盖。
f8?VR1V q154414条件覆盖是指设计足够的测试用例,使得判定表达式中每个条件的各种可能的值至少出现一次。51Testing软件测试网+y&DEFg9iz
(4)判定/条件测试。
P)|M$?HDb bj154414该覆盖标准指设计足够的测试用例,使得判定表达式的每个条件的所有可能取值至少出现一次,并使每个判定表达式所有可能的结果也至少出现一次。
r8_X*GB:}3Y%U154414(5)条件组合覆盖。51Testing软件测试网 K,~d6I]i^9~5Y E"s
条件组合覆盖是比较强的覆盖标准,它是指设计足够的测试用例,使得每个判定表达式中条件的各种可能的值的组合都至少出现一次。51Testing软件测试网T[HD#p5ID,P5ko
(6)路径覆盖。
3jD k[E154414路径覆盖是指设计足够的测试用例,覆盖被测程序中所有可能的路径。
8J!v&MmL@k154414在实际的逻辑覆盖测试中,一般以条件组合覆盖为主设计测试用例,然后再补充部分用例,以达到路径覆盖测试标准。51Testing软件测试网/pa4CiU1e
2.循环覆盖
LKNl/w(o3e\%M1544143.基本路径测试51Testing软件测试网"buIF} p F/IK6J
51Testing软件测试网a(|D d5G s"Ny'l
51Testing软件测试网 r2V3DNw(E
(二)黑盒技术51Testing软件测试网e @{Bt
51Testing软件测试网-[ Y-Wc5r7|+\r`Sg
1.等价类划分
nz3V6U_154414(1)划分等价类。
4p%p$aLbvp\154414①如果某个输入条件规定了取值范围或值的个数。则可确定一个合理的等价类(输入值或数在此范围内)和两个不合理等价类(输入值或个数小于这个范围的最小值或大于这个范围的最大值)。
lz`h$k7L^154414②如果规定了输入数据的一组值,而且程序对不同的输入值做不同的处理,则每个允许输入值是一个合理等价类,此处还有一个不合理等价类(任何一个不允许的输入值)。51Testing软件测试网i"h2|5|z"V'|+| g}
③如果规定了输入数据必须遵循的规则,可确定一个合理等价类(符合规则)和若干个不合理等价类(从各种不同角度违反规则)。
b%`X(V4a Ms q154414④如果已划分的等价类中各元素在程序中的处理方式不同,则应将此等价类进一步划分为更小的等价类。51Testing软件测试网|5js8^6}
(2)确定测试用例。
/U&Ixz_7g"S8}154414①为每一个等价类编号。51Testing软件测试网 aK QI-w5ZcI
②设计一个测试用例,使其尽可能多地覆盖尚未被覆盖过的合理等价类。重复这步,直到所有合理等价类被测试用例覆盖。
q&IU$znE$P1HZ154414③设计一个测试用例,使其只覆盖一个不合理等价类。51Testing软件测试网LDN s7NLe
2.边界值分析
Ck:D S }4C| w%U V7V154414使用边界值分析方法设计测试用例时一般与等价类划分结合起来。但它不是从一个等价类中任选一个例子作为代表,而是将测试边界情况作为重点目标,选取正好等于、刚刚大于或刚刚小于边界值的测试数据。51Testing软件测试网p'y,_7pr Q+ye
(1)如果输入条件规定了值的范围,可以选择正好等于边界值的数据作为合理的测试用例,同时还要选择刚好越过边界值的数据作为不合理的测试用例。如输入值的范围是[1,100],可取0,1,100,101等值作为测试数据。51Testing软件测试网J!iN r*HZep
(2)如果输入条件指出了输入数据的个数,则按最大个数、最小个数、比最小个数少1、比最大个数多1等情况分别设计测试用例。如,一个输入文件可包括1--255个记录,则分别设计有1个记录、255个记录,以及0个记录的输入文件的测试用例。51Testing软件测试网o{6z3Zb0Vz$h
(3) 对每个输出条件分别按照以上原则(1)或(2)确定输出值的边界情况。如,一个学生成绩管理系统规定,只能查询95--98级大学生的各科成绩,可以设计测试用例,使得查询范围内的某一届或四届学生的学生成绩,还需设计查询94级、99级学生成绩的测试用例(不合理输出等价类)。
#e*k~kfvp154414由于输出值的边界不与输入值的边界相对应,所以要检查输出值的边界不一定可能,要产生超出输出值之外的结果也不一定能做到,但必要时还需试一试。
8OO#qJI%IG qkC154414(4)如果程序的规格说明给出的输入或输出域是个有序集合(如顺序文件、线形表、链表等),则应选取集合的第一个元素和最后一个元素作为测试用例。
@y c?/t"P)A1544143.错误推测51Testing软件测试网 {;c0Rc*o PT
在测试程序时,人们可能根据经验或直觉推测程序中可能存在的各种错误,从而有针对性地编写检查这些错误的测试用例,这就是错误推测法。51Testing软件测试网)e3f:enPcL7o
4.因果图51Testing软件测试网o.dp4H&y,`z*J
等价类划分和边界值方法分析方法都只是孤立地考虑各个输入数据的测试功能,而没有考虑多个输入数据的组合引起的错误。51Testing软件测试网WV(rns$S'Z+[Z
5.综合策略
K/uu*{-?cT/K154414每种方法都能设计出一组有用例子,用这组例子容易发现某种类型的错误,但可能不易发现另一类型的错误。因此在实际测试中,联合使用各种测试方法,形成综合策略,通常先用黑盒法设计基本的测试用例,再用白盒法补充一些必要的测试用例。51Testing软件测试网q5@2[Ui3XnN

i%I q wl{.B154414六、测试用例设计的误区51Testing软件测试网!Q;~/i7d PMN4vC0b
(来源:关河测试网)51Testing软件测试网bT TRA+{jhb0|(I

'JSP_;`:^i154414·能发现到目前为止没有发现的缺陷的用例是好的用例;51Testing软件测试网;P;W U-IQ$O
51Testing软件测试网| UP u|a
首先要申明,其实这句话是十分有道理的,但我发现很多人都曲解了这句话的原意,一心要设计出发现“难于发现的缺陷”而陷入盲目的片面中去,忘记了测试的目的所在,这是十分可怕的。我倾向于将测试用例当作一个集合来认识,对它的评价也只能对测试用例的集合来进行,测试本身是一种“V&V”的活动,测试 需要保证以下两点:51Testing软件测试网9J0Ai_hP_

D Y t*?Z*o W154414程序做了它应该做的事情51Testing软件测试网 {/h/h4[!D J
程序没有做它不该做的事情51Testing软件测试网J([|v'yF&L
因此,作为测试实施依据的测试用例,必须要能完整覆盖测试需求,而不应该针对单个的测试用例去评判好坏。
}4o+p+~ K(Pg?15441451Testing软件测试网0HO*GZn F9q0x7b
·测试用例应该详细记录所有的操作信息,使一个没有接触过系统的人员也能进行测试;
1{0xv6ZM.R154414
3jb.Enj \ h154414不知道国内有没有公司真正做到这点,或者说,不知道有国内没有公司能够将每个测试用例都写得如此详细。在我的测试经历中,对测试用例描述的详细和复杂程度也曾有过很多的彷徨。写得太简单吧,除了自己没人能够执行,写得太详细吧,消耗在测试用例维护(别忘了,测试用例是动态的,一旦测试环境、需求、设计、实现发生了变化,测试用例都需要相应发生变化)上的时间实在是太惊人,在目前国内大部分软件公司的测试资源都不足的情况下,恐怕很难实现。但我偏偏就能遇到一些这样的老总或者是项目负责人,甚至是测试工程师本身,全然不顾实际的资源情况,一定要写出“没有接触过系统的人员也能进行测试”的用例。
fL~x!h0O*B154414
r7mFQ&x8aS154414在讨论这个问题之前,我们可以先考虑一下测试的目的。测试的目的是尽可能发现程序中存在的缺陷,测试活动本身也可以被看作是一个Project,也需要在给定的资源条件下尽可能达成目标,根据我个人的经验,大部分的国内软件公司在测试方面配备的资源都是不足够的,因此我们必须在测试计划阶段明确测试的目标,一切围绕测试的目标进行。
(^:N%KT~U'F15441451Testing软件测试网q%J;k_6Nq \q
除了资源上的约束外,测试用例的详细程度也需要根据需要确定。如果测试用例的执行者、测试用例设计者、测试活动相关人对系统了解都很深刻,那测试用例就没有必要太详细了,文档的作用本来就在于沟通,只要能达到沟通的目的就OK。在我担任测试经理的项目中,在测试计划阶段,一般给予测试设计30% - 40%左右的时间,测试设计工程师能够根据项目的需要自行确定用例的详细程度,在测试用例的评审阶段由参与评审的相关人对其把关。
"xDg(Y2~;F0SN15441451Testing软件测试网.W^\1h:nU-N'z(E(l
·测试用例设计是一劳永逸的事情;51Testing软件测试网C#npHLP

a6|$XPa E154414这句话摆在这里,我想没有一个人会认可,但在实际情况中,却经常能发现这种想法的影子。我曾经参与过一个项目,软件需求和设计已经变更了多次,但测试用例 却没有任何修改。导致的直接结果是新加入的测试工程师在执行测试用例时不知所措,间接的后果是测试用例成了废纸一堆,开发人员在多次被无效的缺陷报告打扰 后,对测试人员不屑一顾。51Testing软件测试网W)y-b|o6L
51Testing软件测试网Yw%NTn$]~5T
这个例子可能有些极端,但测试用例与需求和设计不同步的情况在实际开发过程中确是屡见不鲜的,测试用例文档是“活的”文档,这一点应该被测试工程师牢记。51Testing软件测试网)C,f Nb3i7`-A:d
51Testing软件测试网#j%["v q5O-wXJ"cb
·测试用例不应该包含实际的数据;51Testing软件测试网6AR\R&F$DO{
51Testing软件测试网8t-k ` K{s
测试用例是“一组输入、执行条件、预期结果”、毫无疑问地应该包括清晰的输入数据和预期输出,没有测试数据的用例最多只具有指导性的意义,不具有可执行性。当然,测试用例中包含输入数据会带来维护、与测试环境同步之类的问题,关于这一点,《Effective Software Test》一书中提供了详细的测试用例、测试数据的维护方法,可以参考。51Testing软件测试网#C7Z[VT6s

+xT/f?F:[,K m f"A3r^154414·测试用例中不需要明显的验证手段;51Testing软件测试网$J5_!j @'BV^
51Testing软件测试网de/@7RCq+n;NA
我见过很多测试工程师编写的测试用例中,“预期输出”仅描述为程序的可见行为,其实,“预期结果”的含义并不只是程序的可见行为。例如,对一个订货系统,输入订货数据,点击“确定”按钮后,系统提示“订货成功”,这样是不是一个完整的用例呢?是不是系统输出的“订货成功”就应该作为我们唯一的验证手段呢?显然不是。订货是否成功还需要查看相应的数据记录是否更新,因此,在这样的一个用例中,还应该包含对测试结果的显式的验证手段:在数据库中执行查询语句进行查询,看查询结果是否与预期的一致。51Testing软件测试网$O6I N(qv
51Testing软件测试网7\4LYv8H(qU
七、从用例中生成测试用例
^v j-vw y15441451Testing软件测试网3~]u-Cw_

%w.ZiV$]#\p9ks154414用于功能性测试的测试用例来源于测试目标的用例。应该为每个用例场景编制测试用例。用例场景要通过描述流经用例的路径来确定,这个流经过程要从用例开始到结束遍历其中所有基本流和备选流。
s&|/C @l qKH154414
7l/^0VZ:og154414例如,下图中经过用例的每条不同路径都反映了基本流和备选流,都用箭头来表示。基本流用直黑线来表示,是经过用例的最简单的路径。每个备选流自基本流开始,之后,备选流会在某个特定条件下执行。备选流可能会重新加入基本流中(备选流 1 和 3),还可能起源于另一个备选流(备选流 2),或者终止用例而不再重新加入某个流(备选流 2 和 4)。
)oG(\3VIm154414
7a6` [-vo`4`%d_15441451Testing软件测试网%M p4@s^_1C[
用例的事件流示例51Testing软件测试网 h u L l q(XV

;S+f^_6Mr154414遵循上图中每个经过用例的可能路径,可以确定不同的用例场景。从基本流开始,再将基本流和备选流结合起来,可以确定以下用例场景:51Testing软件测试网:X2Dy cge3}-TQ|
51Testing软件测试网&G"l:?7_XZ
场景 1     基本流             51Testing软件测试网*w!|W A1dz
场景 2     基本流     备选流 1         
&_O ~fJ|.~ p#@~154414场景 3     基本流     备选流 1     备选流 2     
H2O v2o*g9~!_:M154414场景 4     基本流     备选流 3         51Testing软件测试网/N Ni(m0ic-Ugn%g0M
场景 5     基本流     备选流 3     备选流 1     51Testing软件测试网V&^&c6z2@~
场景 6     基本流     备选流 3     备选流 1     备选流 2
4A:aNE;C154414场景 7     基本流     备选流 4         51Testing软件测试网O7sf Z?+|&S
场景 8     基本流     备选流 3     备选流 4
O5JOM S/NA154414
!c7F)x5C)My"c J"G154414注:为方便起见,场景 5、6 和 8 只描述了备选流 3 指示的循环执行一次的情况。51Testing软件测试网Y5?!@$^Zj*H
51Testing软件测试网@xV[UWU
生成每个场景的测试用例是通过确定某个特定条件来完成的,这个特定条件将导致特定用例场景的执行。51Testing软件测试网2Hj:P+_ClH

F!t1\0gYd0@W FhZ#p154414例如,假定上图描述的用例对备选流 3 规定如下:51Testing软件测试网%Y'IkN8L!q7d*i
51Testing软件测试网x Y.Q \o!@4Mvp/\i6u
“如果在上述步骤 2‘输入提款金额’中输入的美元量超出当前帐户余额,则出现此事件流。系统将显示一则警告消息,之后重新加入基本流,再次执行上述步骤 2‘输入提款金额’,此时银行客户可以输入新的提款金额。”51Testing软件测试网ZO2`Bv)R Z v

e \`9D x,H154414据此,可以开始确定需要用来执行备选流 3 的测试用例:51Testing软件测试网DG PnqQ5|
51Testing软件测试网/L8{ I,s5{!U
测试用例 ID     场景     条件     预期结果
5_]4HxMP6i a b154414TC x     场景 4     步骤 2 - 提款金额 > 帐户余额     在步骤 2 处重新加入基本流
P${v w0T{6X'z154414TC y     场景 4     步骤 2 - 提款金额 < 帐户余额     不执行备选流 3,执行基本流51Testing软件测试网M){;@8Jq [V+KG$R
TC z     场景 4     步骤 2 - 提款金额 = 帐户余额     不执行备选流 3,执行基本流51Testing软件测试网;?E{q"@!^@9W

SQkzo4{154414注:由于没有提供其他信息,以上显示的测试用例都非常简单。测试用例很少如此简单。
;JH5x?TF@:stz7W154414
3dH x1f#Ou}n1\|"r154414下面是一个由用例生成测试用例的更符合实际情况的示例。
-n QI/z+}h d15441451Testing软件测试网r;Lgn)vF2n

H3h/g-c2_b8r154414示例:51Testing软件测试网 I{ H#HJY
51Testing软件测试网k!QwB!l Iut0i{
一台 ATM 机器的主角和用例。51Testing软件测试网-`D;u+\ bM
51Testing软件测试网j8a8y$A9fA'r4ZH6hx3UI
下表包含了上图中提款用例的基本流和某些备用流:51Testing软件测试网6pg*e x$\8d;S BOe

6e0_)[mGi154414    本用例的开端是 ATM 处于准备就绪状态。
J:}8vL'{B-|15441451Testing软件测试网b/ybuO
   1. 准备提款 - 客户将银行卡插入 ATM 机的读卡机。
;_9N/IbE(X7k2^8^154414       51Testing软件测试网O O5X&f)m ~W
   2. 验证银行卡 - ATM 机从银行卡的磁条中读取帐户代码,并检查它是否属于可以接收的银行卡。
3]6Lv"dvvLx.dj154414       
s#E/xR*W'k154414   3. 输入 PIN - ATM 要求客户输入 PIN 码(4 位)51Testing软件测试网7Wx.@!S"n1r z+c
       
q3`"w8Or(Q c154414   4. 验证帐户代码和 PIN - 验证帐户代码和 PIN 以确定该帐户是否有效以及所输入的 PIN 对该帐户来说是否正确。对于此事件流,帐户是有效的而且 PIN 对此帐户来说正确无误。51Testing软件测试网.wW*NNc4MP:d
       51Testing软件测试网oM/}!D9f!HL
   5. ATM 选项 - ATM 显示在本机上可用的各种选项。在此事件流中,银行客户通常选择“提款”。
4[ R~7kp.r154414       51Testing软件测试网3gVXm\H
   6. 输入金额 - 要从 ATM 中提取的金额。对于此事件流,客户需选择预设的金额(10 美元、20 美元、50 美元或 100 美元)。51Testing软件测试网K b)wH0N-\R,_ {
       51Testing软件测试网*BC6U5oc[N'CTs$_
   7. 授权 - ATM 通过将卡 ID、PIN、金额以及帐户信息作为一笔交易发送给银行系统来启动验证过程。对于此事件流,银行系统处于联机状态,而且对授权请求给予答复,批准完成提款过程,并且据此更新帐户余额。51Testing软件测试网vf0gr AG
       
%P3Kb#Z-V&S+j O&j154414   8. 出钞 - 提供现金。51Testing软件测试网L!dI4tT z%J yy6Z
       51Testing软件测试网MoJJ&PM$|
   9. 返回银行卡 - 银行卡被返还。
8`I7["gW;q5i9t154414       
%{ P/@6O*kUh;[~154414  10. 收据 - 打印收据并提供给客户。ATM 还相应地更新内部记录。
2p9i zLz:C/Tc15441451Testing软件测试网Z3R"coW R'g`%E A*}c
用例结束时 ATM 又回到准备就绪状态。
m*| \&JUWZ,X"`H ft154414 51Testing软件测试网$XHo'sF\+dU
备选流 1 - 银行卡无效     在基本流步骤 2 中 - 验证银行卡,如果卡是无效的,则卡被退回,同时会通知相关消息。
$yuB0x@,A154414备选流 2 - ATM 内没有现金     在基本流步骤 5 中 - ATM 选项,如果 ATM 内没有现金,则“提款”选项将无法使用。51Testing软件测试网%\:E4G3@&r(E
备选流 3 - ATM 内现金不足     在基本流步骤 6 中- 输入金额,如果 ATM 机内金额少于请求提取的金额,则将显示一则适当的消息,并且在步骤 6 - 输入金额处重新加入基本流。
t*l;lpq.w ~154414备选流 4 - PIN 有误     在基本流步骤 4 中- 验证帐户和 PIN,客户有三次机会输入 PIN。
{5OxC4{ E0}154414
9O`.[Mzgt,@154414如果 PIN 输入有误,ATM 将显示适当的消息;如果还存在输入机会,则此事件流在步骤 3 - 输入 PIN 处重新加入基本流。
u7rF3f] i?u7m A154414
a.F~UkL5v:T154414如果最后一次尝试输入的 PIN 码仍然错误,则该卡将被 ATM 机保留,同时 ATM 返回到准备就绪状态,本用例终止。
{*\Y y2c,d;G D154414备选流 5 - 帐户不存在     在基本流步骤 4 中 - 验证帐户和 PIN,如果银行系统返回的代码表明找不到该帐户或禁止从该帐户中提款,则 ATM 显示适当的消息并且在步骤 9 - 返回银行卡处重新加入基本流。51Testing软件测试网0}+Mo~2D
备选流 6 - 帐面金额不足     在基本流步骤 7 - 授权中,银行系统返回代码表明帐户余额少于在基本流步骤 6 - 输入金额内输入的金额,则 ATM 显示适当的消息并且在步骤 6 - 输入金额处重新加入基本流。
] h x j|k`h@154414备选流 7 - 达到每日最大的提款金额     在基本流步骤 7 - 授权中,银行系统返回的代码表明包括本提款请求在内,客户已经或将超过在 24 小时内允许提取的最多金额,则 ATM 显示适当的消息并在步骤 6 - 输入金额上重新加入基本流。
)s } R Q*An:Q154414备选流 x - 记录错误     如果在基本流步骤 10 - 收据中,记录无法更新,则 ATM 进入“安全模式”,在此模式下所有功能都将暂停使用。同时向银行系统发送一条适当的警报信息表明 ATM 已经暂停工作。51Testing软件测试网$w} nSx/s Q~
备选流 y - 退出     客户可随时决定终止交易(退出)。交易终止,银行卡随之退出。
8aAV*@"I V:fC154414备选流 z - “翘起”     ATM 包含大量的传感器,用以监控各种功能,如电源检测器、不同的门和出入口处的测压器以及动作检测器等。在任一时刻,如果某个传感器被激活,则警报信号将发送给警方而且 ATM 进入“安全模式”,在此模式下所有功能都暂停使用,直到采取适当的重启/重新初始化的措施。
&~MJaad/tN J15441451Testing软件测试网s|3h$_e,bC
51Testing软件测试网:K4o E!?&K8?Vu
在第一次迭代中,根据迭代计划,我们需要核实提款用例已经正确地实施。此时尚未实施整个用例,只实施了下面的事件流:51Testing软件测试网^dyG2`9Ns `ZXP

O L2z0M0Z$x.n154414        * 基本流 - 提取预设金额(10 美元、20 美元、50 美元、100 美元)
XG{V4jTSfRM)N154414        * 备选流 2 - ATM 内没有现金51Testing软件测试网-g(i"x,h R:fqI
        * 备选流 3 - ATM 内现金不足
e9I;~y2cb I,x154414        * 备选流 4 - PIN 有误51Testing软件测试网 `e+{Vc;ZA:s
        * 备选流 5 - 帐户不存在/帐户类型有误
,`%h u5h7}6Q2O_154414        * 备选流 6 - 帐面金额不足51Testing软件测试网+F7`7Yj;XkGu:A

*wL:g8g@154414可以从这个用例生成下列场景
Y/^"jTG9?6o154414场景 1 - 成功的提款     基本流     
:D,O8u?*`-V154414场景 2 - ATM 内没有现金     基本流     备选流 251Testing软件测试网 A7JU:dumF'gi
场景 3 - ATM 内现金不足     基本流     备选流 351Testing软件测试网g~8K&o5v F
场景 4 - PIN 有误(还有输入机会)     基本流     备选流 4
)})?n;bU]154414场景 5 - PIN 有误(不再有输入机会)     基本流     备选流 4
7QI-_ I ~s154414场景 6 - 帐户不存在/帐户类型有误     基本流     备选流 5
#Se |8l2ab d"zI0bQ154414场景 7 - 帐户余额不足     基本流     备选流 6
;n DMKv-z)}.G/z1nz15441451Testing软件测试网w n SDG,q,\
注:为方便起见,备选流 3 和 6(场景 3 和 7)内的循环以及循环组合未纳入上表。
'j%s*cLku)F~$M154414
0P)`-C;V*n0S-e+^154414对于这 7 个场景中的每一个场景都需要确定测试用例。可以采用矩阵或决策表来确定和管理测试用例。下面显示了一种通用格式,其中各行代表各个测试用例,而各列则代表测试用例的信息。本示例中,对于每个测试用例,存在一个测试用例 ID、条件(或说明)、测试用例中涉及的所有数据元素(作为输入或已经存在于数据库中)以及预期结果。
\I/SoCW G1qFLjn154414
fB%]*`9sM(f5l4Z2DY154414通过从确定执行用例场景所需的数据元素入手构建矩阵。然后,对于每个场景,至少要确定包含执行场景所需的适当条件的测试用例。例如,在下面的矩阵中,V(有效)用于表明这个条件必须是 VALID(有效的)才可执行基本流,而 I(无效)用于表明这种条件下将激活所需备选流。下表中使用的“n/a”(不适用)表明这个条件不适用于测试用例。51Testing软件测试网ldyid9iU
TC(测试用例)ID 号     场景/条件     PIN51Testing软件测试网*d!R8qBH-k
51Testing软件测试网#`"U c|!gu)h'y]4K#t
 51Testing软件测试网q'ZNu"f,@(lXR
    帐号51Testing软件测试网-I Ms%T(sa8d

8`:nv3]5JB5qX154414 
D&Iq gx;J154414    输入的金额
C b`Y*T+AG ]154414
!j8M0] ps0d+d154414(或选择的金额)51Testing软件测试网,]n4m v[/W

w?)j\tIXe GQ154414 
.rQ/t ^h154414    帐面金额
8j%y)l)Uf15441451Testing软件测试网#\F.Y _,TY
 
g'L!V%k2D9`qC#S154414    ATM 内的金额51Testing软件测试网B[,Q*PK0E-jD Q9r

,iA8I5cl154414 51Testing软件测试网aA@B9g|T N1pb
    预期结果51Testing软件测试网RX0toM?+o0r(r
CW1.     场景 1 - 成功的提款     V     V     V     V     V     成功的提款。51Testing软件测试网ai z-J$ep&i7v.QM8r
CW2.     场景 2 - ATM 内没有现金     V     V     V     V     I     提款选项不可用,用例结束51Testing软件测试网Ef7ejEr\| h
CW3.     场景 3 - ATM 内现金不足     V     V     V     V     I     警告消息,返回基本流步骤 6 - 输入金额
kJx7aUt154414CW4.     场景 4 - PIN 有误(还有不止一次输入机会)     I51Testing软件测试网,`'}%R`s
51Testing软件测试网+b-P7E y(c Z2}
 
$`t] wzm/A7h154414    V     n/a     V     V     警告消息,返回基本流步骤 4,输入 PIN51Testing软件测试网9Tq%C G#dJWD
CW5.     场景 4 - PIN 有误(还有一次输入机会)     I51Testing软件测试网#W"H8\:_vq-W0^$q
51Testing软件测试网(B9nW Q(\O8DR_b.r w
 
.P7\m9A`'}Y d7G&{154414    V     n/a     V     V     警告消息,返回基本流步骤 4,输入 PIN
^%~5k!Cm154414CW6.     场景 4 - PIN 有误(不再有输入机会)     I51Testing软件测试网 h)x k5| | A

MG2k.m9C2F+l:b154414 
I Tf@rhO154414    V     n/a     V     V     警告消息,卡予保留,用例结束51Testing软件测试网 uK@j8{ ~ EK1G?i

([S&Cn~:m154414在上面的矩阵中,六个测试用例执行了四个场景。对于基本流,上述测试用例 CW1 称为正面测试用例。它一直沿着用例的基本流路径执行,未发生任何偏差。基本流的全面测试必须包括负面测试用例,以确保只有在符合条件的情况下才执行基本流。这些负面测试用例由 CW2 至 6 表示(阴影单元格表明这种条件下需要执行备选流)。虽然 CW2 至 6 对于基本流而言都是负面测试用例,但它们相对于备选流 2 至 4 而言是正面测试用例。而且对于这些备选流中的每一个而言,至少存在一个负面测试用例(CW1 - 基本流)。  
g ^&h9Z uO/|4L"`.g1MV154414
7A/FE_7M154414每个场景只具有一个正面测试用例和负面测试用例是不充分的,场景 4 正是这样的一个示例。要全面地测试场景 4 - PIN 有误,至少需要三个正面测试用例(以激活场景 4):51Testing软件测试网(nZ.S!L4kU CS~&I

Z%O;fC|[154414    * 输入了错误的 PIN,但仍存在输入机会,此备选流重新加入基本流中的步骤 3 - 输入 PIN。51Testing软件测试网2nm8pW%vg
    * 输入了错误的 PIN,而且不再有输入机会,则此备选流将保留银行卡并终止用例。
_5?[1} C`_9e1M154414    * 最后一次输入时输入了“正确”的 PIN。备选流在步骤 5 - 输入金额处重新加入基本流。
J@#G#O}D]15441451Testing软件测试网 S;MeEt z$p K
注:在上面的矩阵中,无需为条件(数据)输入任何实际的值。以这种方式
创建测试用例矩阵的一个优点在于容易看到测试的是什么条件。由于只需要查看 V 和 I(或此处采用的阴影单元格),这种方式还易于判断是否已经确定了充足的测试用例。从上表中可发现存在几个条件不具备阴影单元格,这表明测试用例还不完全,如场景 6 - 不存在的帐户/帐户类型有误和场景 7 - 帐户余额不足就缺少测试用例。
F)C5\2S_ W154414
8w+R#`[sq dUo h154414一旦确定了所有的测试用例,则应对这些用例进行复审和验证以确保其准确且适度,并取消多余或等效的测试用例。51Testing软件测试网!Rc;Vn%U`5b8Gt?1v _

ny~ U:?154414测试用例一经认可,就可以确定实际数据值(在测试用例实施矩阵中)并且设定测试数据51Testing软件测试网9RZU f ]H U/g
TC(测试用例)ID 号     场景/条件     PIN51Testing软件测试网(IC2I'zL'a'a l

8` J G,t'k"P O-D} d$m154414 51Testing软件测试网v'dN&p*rd
    帐号
ngN1V7Fi f154414
_M.G%F|ID154414 
5e$qL-}D&W.oGm{154414    输入的金额
+cS$Q5zEj154414
l%Gk&P'`!v]w154414(或选择的金额)51Testing软件测试网Sow^M!d9}

vh'BrWL154414 
6d`M]I154414    帐面金额51Testing软件测试网;FM$C2l sn
51Testing软件测试网"V6OE2tz
 
4R9n0~)^ @&L\154414    ATM 内的金额51Testing软件测试网 B8Y ]U9{vRu

KYUl4}mR154414 51Testing软件测试网`5yq;^1w4^&F'\f
    预期结果
e} Y-J@ \3g'X154414CW1.     场景 1 - 成功的提款     4987     809 - 498     50.00     500.00     2,000     成功的提款。帐户余额被更新为 450.00
:yb-d Z7k S-IYpi"w#j154414CW2.     场景 2 - ATM 内没有现金     4987     809 - 498     100.00     500.00     0.00     提款选项不可用,用例结束
"E,rA1z%kB? f;@,Y154414CW3.     场景 3 - ATM 内现金不足     4987     809 - 498     100.00     500.00     70.00     警告消息,返回基本流步骤 6 - 输入金额51Testing软件测试网CS zY,P
CW4.     场景 4 - PIN 有误(还有不止一次输入机会)     497851Testing软件测试网 Rcj0t-L}F.`

#\'Ik7Y)DkzG$g154414 51Testing软件测试网yTCf[eV bv5N
    809 - 498     n/a     500.00     2,000     警告消息,返回基本流步骤 4,输入 PIN
3L @,Q)M O d154414CW5.     场景 4 - PIN 有误(还有一次输入机会)     497851Testing软件测试网OH&FB(hv

,D)Ws"q@u154414 
S m5O _!~ l*pGh-g154414    809 - 498     n/a     500.00     2,000     警告消息,返回基本流步骤 4,输入 PIN
}9QZ3MT154414CW6.     场景 4 - PIN 有误(不再有输入机会)     4978
N"W0X7XC)Jv15441451Testing软件测试网i,x*m!C3P1B
 
/PI+\U m.Z(lV154414    809 - 498     n/a     500.00     2,000     警告消息,卡予保留,用例结束51Testing软件测试网tu&X(CY
51Testing软件测试网6g1yuG5lrMy!_
以上测试用例只是在本次迭代中需要用来验证提款用例的一部分测试用例。需要的其他测试用例包括:51Testing软件测试网^~0_m9Wl` CH

;UOY/L+NH1L154414    * 场景 6 - 帐户不存在/帐户类型有误:未找到帐户或帐户不可用
]h {1`1P!T154414    * 场景 6 - 帐户不存在/帐户类型有误:禁止从该帐户中提款51Testing软件测试网"P#H2X2ww7V/{S
    * 场景 7 - 帐户余额不足:请求的金额超出帐面金额
f#b$F]TzA K \-s154414
%{QJ)N8WmI154414在将来的迭代中,当实施其他事件流时,在下列情况下将需要测试用例:
8[.Qz9|:\ |v J;u154414
[%e/N,m%sQ154414    * 无效卡(所持卡为挂失卡、被盗卡、非承兑银行发卡、磁条损坏等)
*D NGY`xG-sQ154414    * 无法读卡(读卡机堵塞、脱机或出现故障)
-Q2N}'aC.H R5l154414    * 帐户已消户、冻结或由于其他方面原因而无法使用51Testing软件测试网%~%}g;B/WweDTt
    * ATM 内的现金不足或不能提供所请求的金额(与 CW3 不同,在 CW3 中只是一种币值不足,而不是所有币值都不足)51Testing软件测试网v0g*fuT:@&b
    * 无法联系银行系统以获得认可
bKr`~&x;RG154414    * 银行网络离线或交易过程中断电
:DEIb d15441451Testing软件测试网C,G/j\ Ed
在确定功能性测试用例时,确保满足下列条件:51Testing软件测试网 _4jS.k ]yc

hz]w3l'Z@0QH0B8e154414    * 已经为每个用例场景确定了充足的正面和负面测试用例。
AL9\_:C'K-n;r]154414    * 测试用例可以处理用例所实施的所有业务规则,确保对于业务规则,无论是在内部、外部还是在边界条件/值上都存在测试用例。
$vUM~-P/v154414    * 测试用例可以处理所有事件或动作排序(如在设计模型的序列图中确定的内容),还应能处理用户界面对象状态或条件。51Testing软件测试网,j6KU3P:o0SEZ
    * 测试用例可以处理为用例所指定的任何特殊需求,如最佳/最差性能,有时这些特殊需求会与用例执行过程中的最小/最大负载或数据容量组合在一起。51Testing软件测试网gc8x L*| TfU6O
51Testing软件测试网Z4Y+SZ1Z? E
八、从补充规约中生成测试用例
AjrkN$XBK o154414
PY#[Cy8rJl r154414并不是所有的测试目标需求都将在用例中有所反映。非功能性需求(如性能、安全性和访问控制)以及配置要求等将会说明测试目标的其他行为或特征。补充规约是为其他行为生成测试用例的主要来源。51Testing软件测试网&B uT!YUF
51Testing软件测试网 C`&k#f'{QbcG-a'~m
关于如何生成这些其他测试用例的指南说明如下:
%c9x1Yt#lyo15441451Testing软件测试网`lo,i2@;CY
    * 为
性能测试生成测试用例
};b$OE%exf154414    * 为安全性/访问控制测试生成测试用例51Testing软件测试网r3j&|E0aW7E
    * 为配置测试生成测试用例51Testing软件测试网0Y/X-o.A:H:dAF'h
    * 为安装测试生成测试用例
T~vk)x(w"?$Y%h154414    * 为其他非功能性测试生成测试用例
{w[0? o[15441451Testing软件测试网_5g&o!T9z0R7a
为性能测试生成测试用例51Testing软件测试网SF)k,e4`7kR
51Testing软件测试网.[({Yj+S Z&Wb)FR1N*D%^
性能测试用例的主要输入是补充规约,补充规约中包含了非功能性需求(请参见工件:补充规约)。为性能测试生成测试用例时,请使用下列指南:
F1xT5EZq`154414
.M.kV7Y1ZE2N*ww O154414    * 对于补充规约内阐明性能标准的各条说明都应确保至少要确定一个测试用例。性能标准通常表示为时间/事务、事务量/用户或百分数的形式。
0X6a;l!~.d2C@154414    * 对每个关键用例,都应确保至少要确定一个测试用例。关键用例是在上述说明中和/或在工作量分析文档中确定的、必须采用性能评测方法来评估的用例(请参见工件:工作量分析文档)。51Testing软件测试网9V}m#R#@zb-a
51Testing软件测试网vIR2?$t$ZR
与功能性测试的测试用例类似,通常对于每个用例/需求都会存在不止一个测试用例。常见的情况是:存在一个低于性能阈值的测试用例、一个处于阈值上的测试用例,还有一个测试用例高于阈值。51Testing软件测试网c/pun&@yMkQ$x@
51Testing软件测试网.]|H\%t'p+l
除了以上性能标准以外,确保已确定影响响应时间的特定条件,包括:
U8T7n$h'h154414
-rz%[F u A'z;LY#k154414    * 数据库的大小 - 存在多少个记录?51Testing软件测试网X8DZfk V {
    * 工作量 - 同时执行操作的最终用户的数量和类型,以及要同时执行的事务的数量和类型51Testing软件测试网u6l zz C-~i
    * 环境特征(硬件、网件以及软件配置)51Testing软件测试网I8N f5nW4n3T)};q Ut
51Testing软件测试网\)IRN:{
将用于性能测试的测试用例记录在类似于功能测试所使用的矩阵中。
z d NI!M!m}0qR15441451Testing软件测试网3I,H}h+Y*J1a:c
以下是各种性能测试的一些示例:51Testing软件测试网n)nXq3\$_!g1{
51Testing软件测试网A Y:a*f8b~_E
对于
负载测试51Testing软件测试网'e1G!|c9fOk/}
TC(测试用例)ID 号     工作量     条件51Testing软件测试网P+lf.r s

F6k0J/v ?i154414 
$be G]*z.o1M'Tv"_154414    预期结果51Testing软件测试网 AP'[ u,f4rgm
PCW1.    51Testing软件测试网7x;N4qh_9Fs jP
51Testing软件测试网a FhEq] J
151Testing软件测试网0AF Y]:^.G8x

\!Mo/r@by+l154414(单个 ATM)51Testing软件测试网1| r O H} F } Y;V w)iA]
   
7ae Y}~M15441451Testing软件测试网1O-MF,F%?,r
完成提款交易51Testing软件测试网.K(D-L9m(|:o!CG:Uz
    全部交易(不依赖于主角的时间)在 20 秒之内完成51Testing软件测试网wz-sS'v#Ih;y&n
PCW2.    51Testing软件测试网`B)]j!RK B

jW)L b)TQ$XT1544142
;A1DvC3c y[154414
8F;T+w!k x r:R y;{154414(1,000 个同时运行的 ATM)51Testing软件测试网G PcH(@'txI:y
   
*r8|uC"S'f"\ X15441451Testing软件测试网HWw i]3oY
完成提款交易
9Q IS*@;J7ec154414    全部交易(不依赖于主角的时间)在 30 秒之内完成51Testing软件测试网jA-B B'I.E8L[
PCW3.    51Testing软件测试网rj,AUotk5KZ

(c,@8JMt~3A r1544143
M8y3bTT`+S15441451Testing软件测试网5d(f$qQ2?{GD
(10.000 个同时运行的 ATM)
8@C y| a$F s-hRV-n154414   51Testing软件测试网O!o Uc H x

n[yR5o3k'n{*T3R{154414完成提款交易
%p5]4^Os'b G154414    全部交易(不依赖于主角的时间)在 50 秒之内完成
;xZKe!s&zh154414
{9hg4E!P154414对于强度测试:
(~ z8Ncxa154414TC(测试用例)ID 号     工作量     条件51Testing软件测试网hHz2O k-n7ZI
51Testing软件测试网f d%@"e(c:@O c2l/C
 
gzl0DXB7oU e154414    预期结果
Cbf0V7X/n154414SCW1.    
uJ@#[H.fw/?8x154414
"w;Br1hk*gz f#F154414251Testing软件测试网#V-C:k:Dr4u2kZNr"W
51Testing软件测试网4q\A2c@ x
(1,000 个同时运行的 ATM)51Testing软件测试网"kYmHS-e1o%w[s
   51Testing软件测试网9HCF7gSi:u%^Y

Z#kU2[tJ154414数据库锁定 - 2 个 ATM 请求同一帐户
,q DwN@ ZiL#`154414    ATM 请求排成队列
.R mv,l8bQ@154414SCW2.    
8|R8R jU4mFRk15441451Testing软件测试网V9H(zq+o OU
2
I

TAG: 测试文档

 

评分:0

我来说两句

Open Toolbar