不要追求绝对的公平,红尘之中没有公平而言,人活一世,难得糊涂。                                           it is no use doing what you like, you have got to like what you do.

系统测试

上一篇 / 下一篇  2006-12-14 15:33:17 / 个人分类:软件测试技术

系统测试51Testing软件测试网(L$_L-{ X;_#G6Ws
51Testing软件测试网e_^8a }t4}spA+{z
51Testing软件测试网 aq&D.[mq V

F4e!_A+CFJ[0      系统测试(System Test, ST)是将经过测试的子系统装配成一个完整系统来测试。它是检验系统是否确实能提供系统方案说明书中指定功能的有效方法。51Testing软件测试网A5x6K iM#{Mk
51Testing软件测试网!HX%Y`GR7S_:A&E
       系统测试的目的是对最终软件系统进行全面的测试,确保最终软件系统满足产品需求并且遵循系统设计。
eYQ(cHF Y?.O0
R*zH%^'Js{0      系统测试过程域是SPP模型的重要组成部分。本规范阐述了系统测试的规程,该规程的“目标”、“角色与职责”、“启动准则”、“输入”、“主要步骤”、“输出”、“完成准则”和“度量”均已定义。
1n3?`~ J0
f#Fr8L }^4} p*r0
G,k.j&l4[Y/flC#V*a0一、介绍51Testing软件测试网S j{U#Ifb

"Cc?l)bx&SJ'iK'O x0      系统测试流程如图1所示。由于系统测试的目的是验证最终软件系统满足产品需求并且遵循系统设计,所以当产品需求和系统设计文档完成之后,系统测试小组就可以提前开始制定测试计划和设计测试用例,而不必等到“实现与测试”阶段结束。这样可以提高系统测试的效率。
`A-|p;{051Testing软件测试网st({L)Ou6Ii
      系统测试过程中发现的所有缺陷必须用统一的缺陷管理工具来管理,开发人员应当及时消除缺陷(改错)。
A$}*f[Yf051Testing软件测试网 C TH4Nl e%n c+?
图1 系统测试流程图
toz9PJM0         
tg(K:S9}0      项目经理设法组建富有成效的系统测试小组。系统测试小组的成员主要来源于:
9m W0Q7vd Rr0      ·机构独立的测试小组(如果存在的话)。51Testing软件测试网 KH Ad(Fu
      ·邀请其它项目的开发人员参与系统测试。
jO!T }-j.Ex,xg0      ·本项目的部分开发人员。
U m0]e9\ qF0      ·机构的质量保证人员。51Testing软件测试网)sqnp~

[su&g1F.H^0      系统测试小组应当根据项目的特征确定测试内容。一般地,系统测试的主要内容包括:
1x:SrZo|J%v0      ·功能测试。即测试软件系统的功能是否正确,其依据是需求文档,如《产品需求规格说明书》。由于正确性是软件最重要的质量因素,所以功能测试必不可少。51Testing软件测试网Ad3S]Zg
      ·健壮性测试。即测试软件系统在异常情况下能否正常运行的能力。健壮性有两层含义:一是容错能力,二是恢复能力。51Testing软件测试网ROZ,Afy0KF)V
      ·性能测试。即测试软件系统处理事务的速度,一是为了检验性能是否符合需求,二是为了得到某些性能数据供人们参考(例如用于宣传)。
ywc.P+~'BW%K3n0      ·用户界面测试。重点是测试软件系统的易用性和视觉效果等。51Testing软件测试网#@MDDL(YG:M&T] }_
      ·安全性(security)测试。是指测试软件系统防止非法入侵的能力。“安全”是相对而言的,一般地,如果黑客为非法入侵花费的代价(考虑时间、费用、危险等因素)高于得到的好处,那么这样的系统可以认为是安全的。
r1H&{|1Ys s0      ·安装与反安装测试。51Testing软件测试网J'@!B6v7I:d
51Testing软件测试网8p~OL"v%V#k7t
      系统测试过程域产生的主要文档有:51Testing软件测试网 v%i8WW%L{4^1^
      ·《系统测试计划》,模板见 [SPP-TEMP-ST-PLAN]。
SG'IQ9qa_A1Q/b0      ·《系统测试用例》,模板见 [SPP-TEMP-TEST-CASE]。51Testing软件测试网pIa8m+C+[5E%?
      ·《系统测试报告》,模板见 [SPP-TEMP-TEST-REPORT]。
;HxH1@5tU4m0      ·《缺陷管理报告》,由缺陷管理工具自动生成。51Testing软件测试网L(| L|7w _%`7c
51Testing软件测试网yRYgFL:io)c%c O
二、系统测试规程
T%czK$^*vC051Testing软件测试网"@*y&@O)`M*r\ t@
      1、目的
ejqB7Wi(?!a0      对最终软件系统进行全面的测试,确保最终软件系统满足产品需求并且遵循系统设计。
x1IRvo$Yh;@fA${051Testing软件测试网1ATSY7wF
      2、角色与职责
$SVN @n0      项目经理组建系统测试小组,并指定一名成员任测试组长。
6f9Aq` { |+~J{ j"dQ0      系统测试小组各成员共同制定测试计划、设计测试用例、执行测试,并撰写相应的文档。测试组长管理上述事务。51Testing软件测试网6^p5DN%y'k
      开发人员及时消除测试人员发现的缺陷。51Testing软件测试网!{"C mn qo&e&k

[ALN2d3v0      3、启动准则51Testing软件测试网;?f p sZ
      产品需求和系统设计文档完成之后。51Testing软件测试网}^ Y:R.r/a Ad9I
51Testing软件测试网{({m6Fv5q#Qw2L
      4、 输入51Testing软件测试网J2qc Esb%g;QU
      产品需求和系统设计文档51Testing软件测试网wz:IK&w8E

8iK'DY%J2@O*C0      5、主要步骤51Testing软件测试网 u;|#Bl&Q*g%l
      [Step1] 制定系统测试计划51Testing软件测试网+]5J!e {3kQ1H
51Testing软件测试网%}0toUcb
      系统测试小组各成员共同协商测试计划。测试组长按照指定的模板起草《系统测试计划》。该计划主要包括:51Testing软件测试网A:D;mK*n_gdA
      ·测试范围(内容)51Testing软件测试网#X2S!@4K*x5J2l? B
      ·测试方法51Testing软件测试网s s6e o%Nc j
      ·测试环境与辅助工具51Testing软件测试网S"nsP%ZQ
      ·测试完成准则
-\l\w9e`&It0      ·人员与任务表
HVL@9]]'}0
S3[H VxDD0      项目经理审批《系统测试计划》。该计划被批准后,转向[Step2]。
4oT;I%N9X}M0
*x9Q2Xa$|0g5G1M0      [Step2] 设计系统测试用例51Testing软件测试网 L:NZ`E a!Y
      ·系统测试小组各成员依据《系统测试计划》和指定的模板,设计(撰写)《系统测试用例》。
$p D!W \CR$m#b0      ·测试组长邀请开发人员和同行专家,对《系统测试用例》进行技术评审。该测试用例通过技术评审后,转向[Step3]。51Testing软件测试网8os^0` praF
51Testing软件测试网z1PQ9h5PNNb e4[
      [Step3] 执行系统测试51Testing软件测试网5}(`!nuT:d*e}$t \6[
      ·系统测试小组各成员依据《系统测试计划》和《系统测试用例》执行系统测试。
S(gvZC)Uxi q0      ·将测试结果记录在《系统测试报告》中,用“缺陷管理工具”来管理所发现的缺陷,并及时通报给开发人员。
F$bh$N u J0b6]]051Testing软件测试网)M t~O V N-j7r:F {
      [Step4] 缺陷管理与改错
(KR.N.[7b+xr:?0      ·从[Step1]至[Step3],任何人发现软件系统中的缺陷时都必须使用指定的“缺陷管理工具”。该工具将记录所有缺陷的状态信息,并可以自动产生《缺陷管理报告》。
'|P8QL1o0Y_$Q8M0      ·开发人员及时消除已经发现的缺陷。51Testing软件测试网{7n L9p7k!uh
      ·开发人员消除缺陷之后应当马上进行回归测试,以确保不会引入新的缺陷。51Testing软件测试网2} x;h$M m

2R*D%i%K)z(fCZ}p$iu0      6、输出
W{ E.K.J#A1N0      ·消除了缺陷的最终软件系统51Testing软件测试网-xC$t'S"Fwsru
      ·系统测试用例
wC~/X3y*T"B'C0      ·系统测试报告
R kF%q*D#F/z f u0      ·缺陷管理报告
2x:P4eU-X2O @051Testing软件测试网-}R!S Zu+t_6Y
      7、结束准则
Gn F ~2W0\1uB051Testing软件测试网 v&f2FBd#|4Q }3n
      对于非严格系统可以采用“基于测试用例”的准则:
@9q4O:ul5~ ](h3b0      ·功能性测试用例通过率达到100%;51Testing软件测试网-@ ig0M+FF"L5M V\Q
      ·非功能性测试用例通过率达到80%时。
z2FC0A+e+Yl0
FC$y{_BM9m0      对于严格系统,应当补充“基于缺陷密度”的规则:
s^ rJ cfS;~0      ·相邻n个CPU小时内“测试期缺陷密度”全部低于某个值m。例如n大于10,m小于等于1。51Testing软件测试网[,dG ]Fs QF3r3x)Aw

&C/M je:o0      本规程所有文档已经完成。
.li[K.^_8q$W$p,Q0
tCnt%[ rZ0      8、度量
6cbK6Ew0      测试人员和开发人员统计测试和改错的工作量,文档的规模,以及缺陷的个数与类型,并将此度量数据汇报给项目经理。
\3gLA(]VR:R$\}051Testing软件测试网,K0n@7QLoO:_ E/U%E
三、 实施建议51Testing软件测试网6d(yJiRB
51Testing软件测试网D-k'v r?)?jE
      对系统测试人员进行必要的培训,提高他们的测试效率。
ca0p6wgF3c)m/X0      项目经理和测试小组根据项目的资源、时间等限制因素,设法合理地减少测试的工作量,例如减少“冗余或无效”的测试。51Testing软件测试网0g)Y%G#[YeL4b
      系统测试小组根据产品的特征,可以适当地修改本规范的各种文档模板。51Testing软件测试网 @ T]x/T
      对系统测试过程中产生的所有代码和有价值的文档进行配置管理。51Testing软件测试网 z_%Dnl
      为了调动测试者的积极性,建议企业或项目设立奖励机制,例如:根据缺陷的危害程度把奖金分等级,每个新缺陷对应一份奖金,把奖金发给第一个发现该缺陷的人。
6b0YB W#Gs-F?9`0
8f"]'@Z9v }8o0四、系统测试的目标
UQ {D2x"A0
O:rs HzNk0      1、 确保系统测试的活动是按计划进行的;
\:BT]1v9C7r.e1w0      2、 验证软件产品是否与系统需求用例不相符合或与之矛盾;51Testing软件测试网5z1r3zb ]UA{
      3、 建立完善的系统测试缺陷记录跟踪库;51Testing软件测试网#[s,K u4Yv&b*h*T+[.ep
      4、 确保软件系统测试活动及其结果及时通知相关小组和个人;
_H$V8W`Mp#o0`0
}.dW0iU(m*ReJ0五、系统测试的方针
,[T"ggU8t![0a$M051Testing软件测试网 TJ?)M3b`%s8W
      1、 为项目指定一个测试工程师负责贯彻和执行系统测试活动;51Testing软件测试网*l2teX*hK%Q
      2、 测试组向各事业部总经理/项目经理报告系统测试的执行状况;
d'{*HlC h#y.I^(S0      3、 系统测试活动遵循文档化的标准和过程;51Testing软件测试网"['B0ONos%|
      4、 向外部用户提供经系统测试验收通过的预部署及技术支持;51Testing软件测试网wh-hBp)L.F;d9[R
      5、 建立相应项目的(BUG)缺陷库,用于系统测试阶段项目不同生命周期的缺陷记录和缺陷状态跟踪;51Testing软件测试网/Yk'KH6HBq
      6、 定期的对系统测试活动及结果进行评估,向各事业部经理/项目办总监/项目经理汇报/提供项目的产品质量信息及数据;
4Vqx u6U^4{0
zAxW${0六、系统测试的过程
]?8w7x8J9a jk-T)w051Testing软件测试网IbxQ]#x
      1、 软件项目立项,软件项目负责人将项目启动情况通报给测试组长,测试组长指定测试工程师对该项目进行系统测试跟进和执行。
l0S n$y JY Nr0      2、 测试工程师首先参与前期的需求分析活动、前景评审、业务培训、SRS评审。目的是了解系统业务及范围、了解软件需求及范围,验证需求可测性。并将所有收集到的测试需求汇总并输出到《测试需求管理表》中。
L'jeH&s"t&[&e0      3、 测试工程师根据测试需求定义测试策略,并进行工作量估计。51Testing软件测试网3U)OKr6LGh-U7bn["l
      4、 测试工程师根据测试需求制定测试策略和方法;系统测试工程师参与项目计划和SDP评审,依据项目计划(或周计划),编制《系统测试计划》。
5H;M:f X1N4lsFh!_0      5、 测试组长周期性地根据事业部项目的测试情况,进行总体测试工作量估计并进行测试任务分派。51Testing软件测试网 r+Yh.^9]{ Q&J7L
      6、 测试工程师组织《系统测试计划》评审,测试组长根据评审意见审批《系统测试计划》。
\ J$H/Oz X QMx+|[0      7、 测试工程师根据《系统测试计划》中的测试环境要求搭建测试环境。特别技术要求的需要项目组及其它相关职能部门的配合。
w w2IGn2n(D0      8、 测试工程师检查测试设计入口条件;根据《用例规约》、《补充规约》、《界面原型》、《词汇表》进行测试用例设计。
9r.W[3wo[1y0      9、 测试工程师组织《系统测试用例》评审,测试组长根据评审意见审批《系统测试用例》。
C T.n X'{0      10、 测试工程师定义系统测试用例执行过程,并更新《系统测试用例》。51Testing软件测试网 Ky O$W^` P}Z
      11、 测试工程师检查测试执行入口条件,从受控库获取测试版本,执行系统测试并记录 测试结果。51Testing软件测试网fv1R%\|^J*x
      12、 系统测试进入产品稳定期,由测试工程师召开缺陷评审会议;测试工程师对整个系统测试过程进行总结和评价,形成《软件缺陷清单》、《系统测试评估摘要》《系统测试总结报告》,并将系统测试过程的文档报送给项目组和测试组长。测试组长每月初或(事件驱动)汇总、整编上月的《产品质量简报》,报送给事业部总经理和项目办。
*_/\5jW_&L2?.q0      13、 如果根据系统测试结果,产品得以批准通过,系统测试工程师卸载被测软件,进行环境初始化,系统测试结束,转入验收测试阶段;否则视批示意见进行。
-iStgRjQ051Testing软件测试网'c\f8Vg

相关阅读:

TAG: 系统测试 System Test 软件测试技术

PYRHYH的个人空间 引用 删除 PYRHYH   /   2016-04-13 16:19:27
5
belie的个人空间 引用 删除 belie   /   2008-07-24 13:00:36
5
写的真好,学习到好多,谢谢!
 

评分:0

我来说两句

Open Toolbar