登陆注册
8925700000034

第34章 物流信息系统的实施(3)

3.人工测试

人工测试又称代码复审,主要有代码复查、代码走查和代码会审三种方法。

代码复查是指源程序编写完毕后,直接由程序员自己进行检查。由于程序员心理上对自己编写的程序有偏爱,所以一些习惯性的错误自己不易发现。此外,对功能理解的错误也不易发现,所以,代码复查是针对小规模程序常用的方法,效率不是很高。此外,代码复查也是源程序进行测试的第一步。

代码走查一般由三至五人组成测试小组,在预先阅读过该软件资料和源程序的前提下,由测试人员扮演计算机的角色,用人工方法将测试数据输入被测程序,并在纸上跟踪监视程序的执行情况,让人代替机器沿着程序的逻辑走一遍,发现程序中的错误。测试小组成员应是从未介入过该系统设计实施的有经验的程序设计人员。由于人工运行速度很慢,因此代码走查只能使用少量简单的测试用例。

代码会审的人员构成和代码走查类似。在会审时,要求程序作者逐个阅读和讲解程序,测试人员逐个审查、提问、讨论可能产生的错误。代码会审要对程序的功能、结构和风格等进行审定。

6.4.4 系统测试用例设计

1.测试用例在物流信息系统测试中的作用

测试用例被看做是有效发现软件缺陷的最小测试执行单元,也被视为软件的测试规格说明书。在测试工作中,测试用例的设计是非常重要的,是测试执行的正确性、有效性的基础。如何有效地设计测试用例,一直是测试人员所关注的问题;设计好测试用例,也是保证测试工作的最关键的因素之一。

物流信息系统测试工作中处于重中之重的测试用例不但构成了设计和制定测试过程的基础,而且测试的深度与测试用例的数量成正比。一般来讲,判断测试是否完全的一个主要方法是基于需求的覆盖,而这又是以确定、实施和(或)执行的测试用例的数量为依据的;测试工作量与测试用例的数量成比例;测试设计和开发的类型以及所需的资源主要受控于测试用例。这些都使得测试用例在整个物流信息系统开发过程中处于更加重要的地位。

测试用例是为某个特殊目标而编制的一组测试输入、执行条件以及预期结果,以便测试某个程序路径或核实是否满足某个特定需求。测试用例应该包含软件或者项目名称、所服务的范围、背景、作者、编写时间等文档类信息;根据测试用例的定义和目的,测试用例的内容应该有:标题和用例编号、版本号、修改记录,针对目标和假设前提可能发现的错误、输入数据或代码、测试步骤、预期输出和错误发现方法。

对于每个测试需求,在测试用例中需要考虑在正面测试和负面测试条件下的测试,或者通过确定两个测试用例来实现:一个测试用例代表预期的条件,它可用于核实行为是否正确或符合预期(正面测试);另一个测试用例则代表不可接受的、异常的或意外的条件,它可用于核实测试需求是否未以非预期方式执行(负面测试)。

在一般情况下,对于测试的每个需求来说,至少要有一个正面测试用例和为数较多的负面测试用例,以此来检查在异常情况下系统能否正常处理,或者用户进行了错误的操作时的友好提示等等。

测试用例已被确定用来执行测试目标中所有的产品需求行为,包括(视情况而定):

功能、数据确认、业务规则实施、测试目标工作流程或控制、数据流、对象状态、性能(包括工作量、配置和强度)、安全性可访问性、兼容性。每个测试用例都说明或者代表一个唯一的输入集或事件顺序,它能够产生唯一的测试目标行为,复审那些产生相同行为的测试用例并判定它们是否等同,即它们是否都执行测试目标中的路径。

2.测试用例的设计方法

根据动态测试的方法分为黑盒测试和白盒测试,相应的测试用例的设计方法也可以分为针对黑盒测试的用例设计和针对白盒测试的用例设计。针对白盒测试的测试用例设计方法有语句覆盖、判断覆盖、条件覆盖、判断/条件覆盖、条件组合覆盖等;黑盒测试的测试用例设计方法主要有等价类划分、边界值分析、因果图法和错误推测法等。

(1)白盒测试的测试用例设计方法

1)语句覆盖

由于程序中有分支语句,程序的某次执行一般并不能执行到其中的每一条语句。因此,如果某语句中含有一个错误,而它在测试中没执行,这个错误就不可能被发现。为了提高发现错误的可能性,应该在测试时执行程序中的每一个语句。

语句覆盖是一个比较弱的测试标准,其含义是选择足够的测试用例,使得程序中每条语句至少都被执行一次,以此尽可能多地发现程序中的错误。

2)判断覆盖

判断覆盖又称分支覆盖,其含义是选择足够多的测试用例,使得程序中每条判断语句至少获得一次“真”值和“假”值,也就是每个判断语句的每个分支都至少被执行一次。

3)条件覆盖

条件覆盖的含义是执行足够多的用例,使得判断语句中的每个条件均获得各种可能的结果,它比判断覆盖测试能力要强。

4)判断/条件覆盖

判断/条件覆盖的含义是指执行足够多的测试用例,使得判断表达式中每个条件都取到各种可能的值,并且使每个判断表达式也都取到各种可能的结果。

5)条件组合覆盖

条件组合覆盖是一种更强的逻辑覆盖标准,它要求选取足够多的测试用例,使得判断表达式中所有条件的各种可能组合都至少出现一次。凡是满足这种覆盖的用例,一定满足判断覆盖、条件覆盖和判断/条件覆盖。

6)路径覆盖

路径覆盖的含义是选取足够多的测试数据,使程序的每条可能路径都至少执行一次(如果有循环,则要求每个循环至少经过一次)。

路径覆盖是相当强的标准,它保证程序中每条可能的路径都至少执行一次,因此这样的测试数据更有代表性,暴露错误的能力也比较强。但是,为了做到路径覆盖只需考虑每个判断表达式的取值,并没有检验表达式中条件的各种可能组合情况。如果把路径覆盖和条件组合覆盖结合起来,可以设计出检错能力更强的测试数据。

(2)黑盒测试的测试用例设计方法

1)等价类划分

按照黑盒测试思想,输入所有可能的数据来测试某个程序是不可行的。所以,只能在可能的输入数据中选取一个最具代表性的有限子集,作为测试用数据,期望用较小的代价暴露程序中的较多错误。

等价类划分方法的基本思想是设想用一组有限的数据去代表近似无限的数据,就是基于对输入或输出数据的评估将数据划分为两个或更多子集(如有效的和无效的数据集),从每个等价类中选择一定的代表值进行测试,来代表整个数据集的输入/输出。

等价类划分是将输入数据的可能值分成有效等价类(符合要求的输入)和无效等价类(非法输入)两种,每一类以一个代表性的测试数据进行测试,这个数据就等价于这一类中的任意其他数据。

例如,输入的数据范围是1~999,我们可以划分一个有效等价类(大于等于1且小于等于999的数)和两个无效等价类(小于1的数,以及大于999的数)。

等价类测试的关键是划分等价类。要做好这一点,一是要注意积累经验,二是要正确分析被测程序的功能。例如,某程序的功能是求解一元二次方程ax2+bx+c=0。

那么,根据功能可划分出如下的等价类:

满足a≠0,且b=0,c=0的输入数据;满足a≠0,且b=0,c≠0的输入数据;满足a≠0,且b≠0,c=0的输入数据;满足a=0,且b≠0,c≠0的输入数据;a=0,b=0,c≠0的输入数据,非法方程;a=0,b=0,c=0的输入数据,不是方程。

其中,前四个等价类为有效等价类,后两个为无效等价类。因此,测试用例数据就可分别从这些等价类中选取六组测试用数据。

2)边界值分析

在编写程序时,人们往往只注意正常情况,忽视了边界状态。边界值分析法就是在某个变量范围的边界上,验证独立的输入/输出是否正确的测试方法。因为实践证明,程序往往在输入/输出数据边界更容易发生错误,所以检查边界情况的测试用例是比较高效的,可以更快地查出错误。

采用边界值分析的基础也是划分等价类,是对等价类划分方法的补充。不同的是,对每一等价类所选取的测试数据应在其边缘值附近,而不是选取每个等价类的典型值或任意值作为测试用例。

例如,输入数据的值的范围是-1.0~1.0,则可选-1.0、1.0、-1.001和1.001等数据作为测试数据。

3)错误推测法

人们可以通过经验和直觉推测程序中可能存在的各种错误,从而针对性地设计测试用例。这种方法没有确定的步骤,在很大程度上是凭经验进行的。

例如,输入数据为0,或者输入数据为“空”;输入的学生成绩超过100分或为负值;输入一些不存在的数据等。

同类推荐
  • 中级会计实务

    中级会计实务

    《中级会计实务》是为学生今后从事企业财务一线会计核算工作而开设的系统介绍企业会计准则体系的一门课程。总论、货币资金、金融资产、存货、固定资产、无形资产、投资性房地产、长期股权投资、流动负债、非流动负债、所有者权益、收入、费用和利润、教材编写突出“以学习者为中心”,力图遵循行动导向进行教材设计。
  • 与官员谈领导科学与领导艺术

    与官员谈领导科学与领导艺术

    本书从领导工作的基本职能——决策、组织、指挥、协调、监督这五个方面出发,将领导艺术进一步细化为立德与立威、统筹与掌控、识人与用人、用权与授权、决策与指挥、造势与用势、协调与平衡、人际沟通、人际和谐等九个方面进行简明扼要的讲解。
  • 疯狂的管理术

    疯狂的管理术

    本书将众多管理法则一一分类列举,包括管理必须知道的12项原则、管理必须用到的12种手段、管理必须具备的12条素养、管理必须懂得12个模型、管理必须达到的12个目标、管理必须学会的12种方法等内容。
  • “甩手掌柜”的用人哲学:管人用人的9条金科玉律

    “甩手掌柜”的用人哲学:管人用人的9条金科玉律

    对于员工来说,企业管理者就是他们的掌柜,聪明的管理者应当充分调动员工的积极性与主动性。学会合理授权,学会当“甩手掌柜”。这里所谓的“甩手”并不是什么都不管,而是将“从头管到脚”转变为“管头管脚”。把管理者从事务性、常规性的工作中解放出来,使其有更多的时间与精力去关注和开拓新的领域。构思企业未来的发展战略。“甩手掌柜”的出现,正是这个商业时代变革的缩影,本书堪称为一部“甩手掌柜”的管理宝典,其中所有的话题都围绕着怎样选好人、用好人、管好人展开,告诉管理者如何让员工最大限度地发挥作用,
  • 中国证券市场功能、主体行为与制度研究

    中国证券市场功能、主体行为与制度研究

    本书共八章,内容包括:中国证券市场功能的总体分析、证券市场中的政府行为及其对市场功能的影响、证券市场中的上市公司行为及其对市场功能的影响等。
热门推荐
  • 我家小尸妹

    我家小尸妹

    灾难降临,宅男杜然带着小尸妹末世纵横。“我要活着!在这丧尸称霸的世界,我要用自己的力量,,保护朋友,保护我的她……”更新时间:早上十二点、晚上十点半不定期爆更。本书以签约,请放心收藏
  • EXO之浴火

    EXO之浴火

    故事背景在一个架空的年代,沙漠之城郾城遇到了前所未有的危机。主角龙云是郾城城主龙战天的独女。为了守护大漠,独自一人前往阵地偷袭敌营偶遇军师鹿晗,从而开始了一段不能结果的爱情。
  • 无生之主

    无生之主

    这是一个反抗者与毁灭者的故事,一个反抗既定命运,毁灭现有既有之一切的故事平原上,英勇的骑士骑乘着战马,七美德在手中闪耀,山峰中,主的牧羊人在金色光芒中渴望着地上天国的降临。古老的家族在绿色的魔火中,与不朽的魔神维系着亘古长存的契约。硝烟密布的战场,战车在轰鸣,枪炮在欢唱,信念让持枪的战士无所不能。漆黑的蝠翼比黑夜更加深沉,锋利的獠牙比新月更加诱惑。满月当空,巨狼守卫着族群,对月长啸。诡异的沼泽中,尖塔挥洒着魔法,探索着世间的一切奥秘。满天的黄沙之中,僧侣探寻着天地的真理。静谧的夜中,复仇者手持着怒火守望黎明的到来。这是最好的年代,也是最差的年代。这是结算一切因果的时代,也是因果再次诞生的时代
  • 妖神之战

    妖神之战

    她特殊的血统,千年前歃血封印她才得以保一条小命。也是因为这个血统,千年后她被硬生生推上了一条不归路。妖神成长的过程就像剥洋葱,剥掉一层就会留一次眼泪。那个在她面前温文尔雅的男子,许言他还有另一副不为人知的一面。
  • 凤逆之残颜狂妃

    凤逆之残颜狂妃

    金牌女特工一睁眼,竟穿越到红烛喜堂!从没见过这么苦逼的侯门新娘,渣男老公冷冰冰给她一针毙命:“瞎子丑女,死了干净!”唯一疼她爱她的慈父,在喜堂上被一张圣旨赐死抄家!听着,从今日起,我便是她,伤她之人,便是伤我之人,阴谋诡计,陷害吾父之人,都要他血债血偿!坐视不理,落井下石之人,都要他命不久长!斗苍穹,蓄妖兽,一剑既出,天地无光……长得漂亮,不如活得漂亮!那男子,逆天而来,用时时刻刻的守候,化解她心口坚冰……然而,他究竟是谁?殿下有毒,狂妃请小心!【情节虚构,请勿模仿】
  • 基层工会日常工作手册

    基层工会日常工作手册

    为了把广大基层工会干部和职工的思想行动统一到党的十七大精神上来,把贯彻落实工会十五大精神落实到基层、落实到行动中,因此,非常有必要在新形势下加强基层工会干部培训与日常工作业务指导,使得基层工会能够不断推出新举措,指导基层工会工作在各方面的创新发展。
  • 神秘老公头条见

    神秘老公头条见

    他是势跨亚欧的传奇风靡人物,一个令下,整个区域要抖三抖,却只视她如命,纵她翻天!某日,小女人嘟嘴打报告:“老公,有人笑话我嫁的是个又老又丑的穷光蛋。”男人及时赶到现场助阵,高调的场面亮瞎狗眼。又一日:“老公,佣人们都说我是个什么都不会做的粗人,根本配不上你。”第二天,秦府所有女佣全被一群新进的高级素质佣人取代,她们的指令是:服务贝筱筱。再一日:“老公,有人跟我表白,要我与他再续前缘。”
  • 千世劫:绝色魔神倾天下

    千世劫:绝色魔神倾天下

    一川风雪冤血醉,一江秋月镜入画。十万长山难瞑目,渭水深处祭灵宫。“我若与你心,你可愿为我而安。”“倘若我答应,只怕转眼,花落尽风静过,终究吹寒了这笔风流。”眉眼微展,“那又如何!”
  • 忆迹

    忆迹

    命若天定,我便破了这个天!!!!!封天望着远方,傲然自立。坚毅的神色,出现在每个队友的脸庞……
  • 福妻驾到

    福妻驾到

    现代饭店彪悍老板娘魂穿古代。不分是非的极品婆婆?三年未归生死不明的丈夫?心狠手辣的阴毒亲戚?贪婪而好色的地主老财?吃上顿没下顿的贫困宭境?不怕不怕,神仙相助,一技在手,天下我有!且看现代张悦娘,如何身带福气玩转古代,开面馆、收小弟、左纳财富,右傍美男,共绘幸福生活大好蓝图!!!!快本新书《天媒地聘》已经上架开始销售,只要3.99元即可将整本书抱回家,你还等什么哪,赶紧点击下面的直通车,享受乐乐精心为您准备的美食盛宴吧!)