首页 考试吧论坛 Exam8视线 考试商城 网络课程 模拟考试 考友录 实用文档 缤纷校园 英语学习
2010考研 | 2010高考 | 2010中考 | 自学考试 | 成人高考 | 专升本 | 法律硕士 | MBA/MPA | 中科院
四六级 | 商务英语 | 公共英语 | 职称日语 | 职称英语 | 博思 | 口译笔译 | GRE GMAT | 日语 | 托福
雅思 | 专四专八 | 新概念 | 自考英语 | 零起点英韩语 | 在职申硕英语
在职攻硕英语 | 成人英语三级
等级考试 | 水平考试 | 微软认证 | 思科认证 | Oracle认证 | Linux认证
公务员 | 报关员 | 报检员 | 外销员 | 司法考试 | 导游考试 | 教师资格 | 国际商务师 | 跟单员
单证员 | 物流师 | 价格鉴证师 | 银行从业资格 | 证券从业资格 | 人力资源管理师 | 管理咨询师
期货从业资格 | 社会工作者
会计职称 | 注会CPA | 经济师 | 统计师 | 注册税务师 | 评估师 | 精算师 | 高会 | ACCA | 审计师
法律顾问 | 会计证
一级建造师 | 二级建造师 | 造价师 | 监理师 | 安全师 | 咨询师 | 结构师 | 建筑师 | 安全评价师
房地产估价师 | 土地估价师 | 设备监理师 | 岩土工程师 | 质量资格 | 房地产经纪人 | 造价员
投资项目管理 | 土地代理人 | 环保师 | 环境影响评价 | 物业管理师 | 城市规划师 | 公路监理师
公路造价工程师 | 招标师
执业护士 | 执业医师 | 执业药师 | 卫生资格
您现在的位置: 考试吧(Exam8.com) > 软件水平考试 > 心得技巧 > 正文

经验分享:浅谈软件测试用例设计的六大误区

来源:考试吧Exam8.com) 2010-11-6 13:25:21 考试吧:中国教育培训第一门户 模拟考场
[导读]考试吧整理了“经验分享:浅谈软件测试用例设计的六大误区”,帮助考生备考。

  误区一、好的用例是能发现未知BUG的用例首先必须说明,这句话其实是很有道理的,然而很多测试人员都曲解了这句话的原意。他们把测试用例看作孤立的个例,盲目追求设计“难于发现的缺陷”的用例,忘记了测试的目标是尽可能发现程序中存在的缺陷。

  软件测试用例是为了有效发现软件缺陷而编写的包含测试目的、测试步骤、期望测试结果的特定集合,对它的评价也只能对测试用例的集合来进行,测试本身是一种验证加确认(validation &verification)的活动,测试需要保证程序做了它应该做的事情,且没有做它不该做的事情。

  测试用例的好坏应以是否完整有效覆盖需求为依据,我们不应针对单个的测试用例去评判其好坏,而应对某次测试的用例集合总体作评价。

  误区二、测试用例应该详尽,使得未接触系统的人也能进行测试测试用例描述的详细程度困扰着许多测试人员。描述简单的用例不利于用例的传递,而描述复杂的用例的设计和维护需要耗费大量的时间。然而很多测试主管或者测试工程师本身,强调测试用例“越详细越好”,全然不顾实际的测试资源不足的事实,一定要写出“没有接触过系统的人员也能进行测试”的用例。

  这种做法无疑会耗费了很多的时间和资源,从而极大的压缩测试实施的时间和人力,没有足够的测试执行时间,就无法发现更多的软件缺陷,测试质量也就无从谈起。

  测试活动应需要结合自身的资源(测试人员对系统熟悉程度、测试工程师数量、测试时间等)和项目的需求来进行综合考量,以实现质量、时间和成本的最佳平衡。我们建议给测试设计安排30%-40%左右的测试时间,测试工程师可以根据项目的具体情况确定测试用例的颗粒度,在测试用例的评审阶段由相关人员对其把关即可。

  误区三、测试用例设计是一劳永逸的事情很多测试人员(尤其是对测试技术不太了解的主管)认为设计测试用例是一次性投入,片面追求测试用例设计一步到位,导致设计的测试用例与需求和设计不同步的情况在实际开发过程屡屡出现。

  这种认识造成的危害性在于使得设计的测试用例缺乏实用性,误报很多不是软件缺陷的BUG,误导测试用例执行人员,同时也浪费了开发人员的解决BUG的精力和时间。

  几乎所有软件项目的开发过程都处于不断变化(随着需求的变更)过程中。设计软件测试用例与软件开发设计并行进行,必须根据软件设计的变化,对软件测试用例进行内容的调整和数量的增减,增加一些针对软件新增功能的测试用例,删除一些不再适用的测试用例,修改那些模块代码更新了的测试用例。

  误区四、测试用例不包含实际的数据和明显的验证手段测试用例是通常是一组输入、执行条件、预期输出结果的组合,毫无疑问地应该包括清晰的输入数据和预期输出,没有测试数据的用例最多只具有指导性的意义,不具备可执行性。例如我们常用的边界值法就对数据提出了明显的要求。

  很多测试工程师(尤其是测试新手)编写的测试用例中,“预期输出”仅描述为程序的可见行为,实际上,“预期结果”的含义并不只是程序的可见行为。例如,对一个代表信息管理系统,输入代表信息,点击“保存”按钮后,系统提示“保存成功”,这样是不是一个完整的用例呢?是不是系统输出的“保存成功”就应该作为我们唯一的验证手段呢?显然不是,保存是否成功需要查看相应的数据记录是否在数据库中更新:在数据库中执行查询语句进行查询,看查询结果是否与预期的一致。

  因此,在测试用例中,还应该包含实际的测试数据和对测试结果的显式验证手段。

  误区五、测试输入数据设计方法等同于测试用例设计方法现在流行的一些测试书籍认为,测试用例的设计方法包括:等价类、错误推测法、场景设计法、边界值法、因果图法等。这种表述是极其片面的,这些方法只是软件功能测试用例设计中如何确定测试输入数据的方法,而不是测试用例设计的全部内容。

  确定测试的输入数据对于软件功能测试和性能测试的重要性不言而喻,它决定了测试的有效性和效率。但是,测试用例中输入数据的确定方法只是测试用例设计方法的一个很小的方面,除了确定测试输入数据之外,测试用例的设计还包括如何根据需求和行业软件的具体设计规范确定测试用例的设计策略、设计用例的表示方法以及测试用例组织管理形式等问题。

  我们绝对不能从心理上忽视测试用例设计内容的丰富性和技术的复杂性,而应综合考虑被测软件的功能、特性、组成元素、测试用例组织方法等内容。

  误区六、让测试新手设计测试用例很多测试新手被要求从测试用例的设计学起,往往感到无从下手。实际上,测试新手设计的测试用例往往存在设计出的测试用例对软件功能和特性的覆盖度不高、功能设计的颗粒度不合理、可复用性差等诸多缺陷。

  软件测试用例设计是软件测试的中高级技能,不是每个人(尤其是测试新手)都可以编写的,测试用例编写者不仅要掌握软件测试的技术和流程,而且要对被测软件的需求、功能规格说明以及程序结构等有比较透彻的理解。

  我们建议安排经验丰富的测试人员进行测试用例设计,测试新手可以从执行测试用例开始,随着测试人员的测试技术的提高和对被测软件的熟悉,可以学习测试经验丰富的测试人员的用例设计经验,尝试编写测试用例。

  相关推荐:考试吧策划:2010年软件水平考试完全指南

       2010年11月计算机软件水平考试备考宝典汇总

文章搜索
软件水平考试栏目导航
版权声明:如果软件水平考试网所转载内容不慎侵犯了您的权益,请与我们联系800@exam8.com,我们将会及时处理。如转载本软件水平考试网内容,请注明出处。