测试用例之性能测试用例
上一篇 / 下一篇 2008-04-14 17:26:08 / 个人分类:转载
Y]6j~Fa0性能测试、压力测试、负载测试、强度测试、稳定性测试、健壮性测试、功能测试、接口测试……,这么多眼花缭乱的测试类型名称,估计很少有人能准确的区分并说出定义来,至于对应的测试用例如何编写和执行,就更不用说了。
T7xGBr1q6l051Testing软件测试网{9s+Qz'@oqp;w如果问测试工程师测试用例如何编写,就象是问程序员如何编写代码得到的答案一样,每个人都会给出不同的编写方法,但实用的测试用例却象优秀的程序一样难以编写。51Testing软件测试网-\I(afm
51Testing软件测试网%?%W`|t(n&vx%c {|3K目前国内,测试工程师却时常要面对“已经延期几倍计划时间的项目”,测试用例如何发挥更大的作用,是一个迫切需要解决的问题。事实上,完全可以把测试用例看成是测试工程师编写的程序:这个“程序”是为了辅助测试工作的进行而开发的,目的是为了发现软件问题,同时“顺便”证明软件功能是否符合要求。
$Uh;]_6k%R1cQ051Testing软件测试网kA*Jtz本文针对上面的问题,以设计性能测试用例为示范,讲解在企业实际工作中,如何有效划分测试种类和编写对应的测试用例,使测试工作更加合理、高效率的开展。51Testing软件测试网l,C(KP1?'J2|2X)]
51Testing软件测试网hCG ^6yd)z5d1测试种类和阶段
#WU"[%bY c0,dM[(\~*M"bH01.1 测试种类
J)pK6EVJ051Testing软件测试网T)F1Y!U V1HW~i{对于测试种类的说法多种多样,最多的能达到30多种测试类型。而实际工作中很多测试是互相包含的。按照企业中实际工作需要,通常主要进行下面几种类型的测试:功能测试、健壮性测试、接口测试、强度测试、压力测试、性能测试、用户界面测试、可靠性测试、安装/反安装测试、文档测试。
r(c2V%n7|051Testing软件测试网A7g'VGxWz.A`下面介绍几种重要的测试种类及其测试的内容:51Testing软件测试网2o~(ne@l(_wQ
51Testing软件测试网J f g&`4Kp%s2I.k功能测试:功能测试主要针对产品需求说明书的测试,是验证功能是否否合需求,包括原定功能的检验、是否有冗余功能、遗漏功能。这类测试应由测试员做,这并不意味着程序员在发布前不必检查他们的代码能否工作,他们也需要进行基本功能的测试。51Testing软件测试网)U T_Y i;{*cE
b3bi hj0接口测试:程序员对各个模块进行系统联调的测试,包含程序内接口和程序外接口测试。这个测试,在单元测试阶段进行了一部分工作,而大部分都是在集成测试阶段完成的。由开发人员进行。51Testing软件测试网+`Mj Es8E-K
R*d6QT/h:]G0性能测试:在交替进行负荷和强迫测试时常用的术语。性能测试关注的是系统的整体。它和通常所说的强度、压力/负载测试测试有密切关系。所以压力和强度测试应该与性能测试一同进行。
$Lp9nxG(CAz5bI#f0uhS HA` Y-L0用户界面测试:对系统的界面进行测试,测试用户界面是否友好、是否方便易用、设计是否合理、位置是否正确等一系列界面问题51Testing软件测试网8j*@KFg
2Pw+^ x7\S+F6[S/Jt Y0安装/反安装测试:安装测试主要检验软件是否可以正确安装,安装文件的各项设置是否有效,安装后能否影响原系统;反安装是逆过程,测试是否删除干净,是否给影响原系统等。
C8N~)ibk;H051Testing软件测试网tmq3`5]O,a'{文档测试:主要测试开发过程中针对用户的文档,以需求、用户手册、安装手册等为主,检验文档是否和实际应用存在差别。文档测试不需要编写测试用例。51Testing软件测试网r+^#s^K}?
f"H.L4l%D7pO a1b0测试种类的划分不要拘泥于上面的形式,总体来说应该服从于测试策略,可以根据具体工作的特点进行安排,为了工作更容易开展,完全可以把一些测试合在一起进行。在后面的性能测试用例的编写上,充分体现了这一思想。51Testing软件测试网Vqsmm/a$@
51Testing软件测试网7t-w+] Z`1.2 测试阶段51Testing软件测试网3@7o#oB@p:{
51Testing软件测试网-J{o@m6AU和开发过程相对应,测试过程会依次经历单元测试、集成测试、系统测试、验收测试四个主要阶段。对应关系如图1所示:51Testing软件测试网 grJFaX.^
51Testing软件测试网sK(xf(|需求开发51Testing软件测试网)W oj&u&Nm6F5l
51Testing软件测试网*Sd#[(? @2sQ高层设计
nWI}7F!gm|0?7}6Q e-SB h*[p4I0详细设计51Testing软件测试网k.c A mm zE2@
51Testing软件测试网)A3ye'i:ee-u+l_b编程51Testing软件测试网lW9qeN|
51Testing软件测试网Z!L)bu:M,ab7XqJN单元测试
3J7U+DTW rp e I0wP3a7g'vL0集成测试
"e W r1n!E `051Testing软件测试网 f6ym#e0](Fye m系统测试
x-Bz hp(P*|Y xm051Testing软件测试网+EFijRx}a*vE+d验收测试
$aMc'O3C(AW w051Testing软件测试网*j#j|&c"o9fxG p图1 开发与测试的“V”型关系
:~ e,E2gEA051Testing软件测试网4x"a_I/@+ci#u单元测试:单元测试是针对软件设计的最小单位––程序模块甚至代码段进行正确性检验的测试工作,通常由开发人员进行。51Testing软件测试网!\#}7N1mI1Z8K,u$i
8E UZ5Q7[0集成测试:集成测试是将模块按照设计要求组装起来进行测试,主要目的是发现与接口有关的问题。由于在产品提交到测试部门前,产品开发小组都要进行联合调试,因此在大部分企业中集成测试是由开发人员来完成的。。51Testing软件测试网z(W#ifxLfs
51Testing软件测试网y%K5TNa } K7n系统测试:系统测试是在集成测试通过后进行的,目的是充分运行系统,验证各子系统是否都能正常工作并完成设计的要求。它主要由测试部门进行,是测试部门最大最重要的一个测试,对产品的质量有重大的影响。51Testing软件测试网2n?O7X$H,H nJ
:?d"VFD)@"`2u,_0验收测试:验收测试以需求阶段的《需求规格说明书》为验收标准,测试时要求模拟实际用户的运行环境。对于实际项目可以和客户共同进行,对于产品来说就是最后一次的系统测试。测试内容为对功能模块的全面测试,尤其要进行文档测试。
+c ux*H ]051Testing软件测试网-g"D9p/d&oG"Rt$\尽管测试阶段的划分十分明确,但是在具体的项目和产品的测试中,尤其在执行测试时,会根据实际需要来开展。
s$\~8~+o1Z)S s'j051Testing软件测试网z"I1q4sby5X%_1.3 测试种类、阶段和用例的关系51Testing软件测试网5T"D ziQE
51Testing软件测试网u*X/U_q1}{[$Z+M-r'K F为了便于在实际工作中提高效率,同时方便测试用例的编写和执行,可以把上面提到的各个测试类型与对应的测试用例合并。合并后的测试用例主要有以下几种:
.k+hc'vN6_|8u#xi051Testing软件测试网A$r Z4z;C!i1. 功能测试用例:包含功能测试、健壮性测试、可靠性测试51Testing软件测试网'Ek^ `Sd!y
5h!B!W.f1Y!]q4A02. 性能测试用例:包含性能测试、压力测试、强度测试51Testing软件测试网 O j @g#m/d
@T,Kz0ac03. 集成测试用例:包含接口测试、健壮性测试、可靠性测试
Y c4^)N#c+dl*Q02aw~%ay-u&{04.安全测试用例:安全测试用例51Testing软件测试网`X1J$E8U Hz
51Testing软件测试网}Hy&?6PP6ay:p2T5. 用户界面测试用例:包含用户界面测试用例、少量功能测试用例51Testing软件测试网gB;lxZVP
51Testing软件测试网9?\Z*ri#H~4S3}6. 安装/反安装测试用例:安装/反安装测试用例51Testing软件测试网7d6B5q*D#YF7y.|
51Testing软件测试网HsC~X Sc综合上面的分析,测试种类、测试阶段以及执行人员具体的关系如表1所示。
4`6bN5I,C9o6C051Testing软件测试网5|L3`B.B$B51Testing软件测试网)m+f\/eg xsO
C/uMez-jy;V"^0总之,测试的种类应该尽量的少,这样每次都可以执行更多的测试内容。例如在进行功能测试的同时,完全可以进行健壮性的测试。(当然如果产品健壮性方面要求较高,就可以把健壮性测试作为独立的测试。)51Testing软件测试网 L4^(Mv$zC
$WZ2`-h,T,?rt2`02性能用例编写方案51Testing软件测试网&Ra?\/{R
51Testing软件测试网?nFp,`$eiyP性能测试在软件测试中占有重要的地位,而性能测试又关联很多内容。例如压力和强度测试就与性能测试密切相关:针对一个网站进行测试,模拟10到50个用户就是在进行常规性能测试,用户增加到1000乃至上万就变成了压力/负载测试,如果同时对系统进行大量的数据查询操作,就包含了强度测试。51Testing软件测试网"uO4g3nNe"~
51Testing软件测试网0{s ZqV#Te为了便于性能测试工作的实施,这里的性能测试综合了性能、强度、压力、负载等多方面的测试内容,主要包含的内容有:预期性能指标测试、用户并发性能测试、疲劳强度测试、大数据量测试和速度测试、网络、服务器等方面的内容。51Testing软件测试网.j+GZ/pxv3f:RMa
,vkR_%|8F#A0性能测试不同的系统有不同的要求,编写方法要根据实际要求进行编写,本文提出一个常见的参考方案,在实际工作中,可以根据需要加入其它例如内存泄露等和性能相关的测试用例。51Testing软件测试网 b R'fygr^:T
_7{.H+IS*yz,{D0下面介绍各个部分性能测试用例包含的内容:
)~7x!d{(P4V09yo-u$V8E#I$B02.1预期性能指标测试用例
.U.\ [n,D5M2gN0!g)KbV0PV\0通常系统在设计前都会提出一些性能指标,这些指标是性能测试要完成的首要工作之一。针对每个指标都要编写多个测试用例来验证是否达到要求,并根据测试结果来改进系统的性能。
1T*\$nJ(C:qc!g051Testing软件测试网]HB3JvEtu4Om3c这类通常以单用户为主,如果遇到并发用户的情况,可以归到并发用户测试用例中。这类用例通常都是可以通过手工来执行的用例,例如示例中的上传一份文件,期望的性能为2M/S,完全可以手动上传文件,同时用秒表计时。这些内容通常在需求说明书中可以显而易见的查到。不过当看到如支持并发用户300人,就应该放到后面进行。测试结果也是直接记录是否达到要求,如果系统没有达到要求则进行改善。
0n+zt^IZnO{0(Gx7up j6DS4v(Q:y02.2用户并发性能测试用例
.z2gP&g"L,u.I:v;b"k V%ux051Testing软件测试网*TT{+HhW E%@用户并发测试是性能测试的最主要部分,包含了负载测试和压力测试的过程。主要是逐渐增加用户数量来加重系统负担,直到出现不能接收的性能点或者瓶颈。一般要测试正常数量的用户并发和极限数量下用户并发的情况。
S`!qL3n0s-o ?u)[0|r!j-x3q5~d[A0并发用户测试主要是对系统的核心功能和重要业务进行测试,要以真实的业务数据作为输入,选择有代表性和关键的业务操作来设计测试用例。主要编写以下两个方面的用例: