首页 考试吧论坛 Exam8视线 考试商城 网络课程 模拟考试 考友录 实用文档 求职招聘 论文下载 | ||
2011中考 | 2011高考 | 2012考研 | 考研培训 | 在职研 | 自学考试 | 成人高考 | 法律硕士 | MBA考试 MPA考试 | 中科院 |
||
四六级 | 职称英语 | 商务英语 | 公共英语 | 托福 | 雅思 | 专四专八 | 口译笔译 | 博思 | GRE GMAT 新概念英语 | 成人英语三级 | 申硕英语 | 攻硕英语 | 职称日语 | 日语学习 | 法语 | 德语 | 韩语 |
||
计算机等级考试 | 软件水平考试 | 职称计算机 | 微软认证 | 思科认证 | Oracle认证 | Linux认证 华为认证 | Java认证 |
||
公务员 | 报关员 | 银行从业资格 | 证券从业资格 | 期货从业资格 | 司法考试 | 法律顾问 | 导游资格 报检员 | 教师资格 | 社会工作者 | 外销员 | 国际商务师 | 跟单员 | 单证员 | 物流师 | 价格鉴证师 人力资源 | 管理咨询师考试 | 秘书资格 | 心理咨询师考试 | 出版专业资格 | 广告师职业水平 驾驶员 | 网络编辑 |
||
卫生资格 | 执业医师 | 执业药师 | 执业护士 | ||
会计从业资格考试(会计证) | 经济师 | 会计职称 | 注册会计师 | 审计师 | 注册税务师 注册资产评估师 | 高级会计师 | ACCA | 统计师 | 精算师 | 理财规划师 | 国际内审师 |
||
一级建造师 | 二级建造师 | 造价工程师 | 造价员 | 咨询工程师 | 监理工程师 | 安全工程师 质量工程师 | 物业管理师 | 招标师 | 结构工程师 | 建筑师 | 房地产估价师 | 土地估价师 | 岩土师 设备监理师 | 房地产经纪人 | 投资项目管理师 | 土地登记代理人 | 环境影响评价师 | 环保工程师 城市规划师 | 公路监理师 | 公路造价师 | 安全评价师 | 电气工程师 | 注册测绘师 | 注册计量师 |
||
缤纷校园 | 实用文档 | 英语学习 | 作文大全 | 求职招聘 | 论文下载 | 访谈 | 游戏 |
误区一、好的用例是能发现未知BUG的用例首先必须说明,这句话其实是很有道理的,然而很多测试人员都曲解了这句话的原意。他们把测试用例看作孤立的个例,盲目追求设计“难于发现的缺陷”的用例,忘记了测试的目标是尽可能发现程序中存在的缺陷。
软件测试用例是为了有效发现软件缺陷而编写的包含测试目的、测试步骤、期望测试结果的特定集合,对它的评价也只能对测试用例的集合来进行,测试本身是一种验证加确认(validation &verification)的活动,测试需要保证程序做了它应该做的事情,且没有做它不该做的事情。
测试用例的好坏应以是否完整有效覆盖需求为依据,我们不应针对单个的测试用例去评判其好坏,而应对某次测试的用例集合总体作评价。
误区二、测试用例应该详尽,使得未接触系统的人也能进行测试测试用例描述的详细程度困扰着许多测试人员。描述简单的用例不利于用例的传递,而描述复杂的用例的设计和维护需要耗费大量的时间。然而很多测试主管或者测试工程师本身,强调测试用例“越详细越好”,全然不顾实际的测试资源不足的事实,一定要写出“没有接触过系统的人员也能进行测试”的用例。
这种做法无疑会耗费了很多的时间和资源,从而极大的压缩测试实施的时间和人力,没有足够的测试执行时间,就无法发现更多的软件缺陷,测试质量也就无从谈起。
测试活动应需要结合自身的资源(测试人员对系统熟悉程度、测试工程师数量、测试时间等)和项目的需求来进行综合考量,以实现质量、时间和成本的最佳平衡。我们建议给测试设计安排30%-40%左右的测试时间,测试工程师可以根据项目的具体情况确定测试用例的颗粒度,在测试用例的评审阶段由相关人员对其把关即可。
误区三、测试用例设计是一劳永逸的事情很多测试人员(尤其是对测试技术不太了解的主管)认为设计测试用例是一次性投入,片面追求测试用例设计一步到位,导致设计的测试用例与需求和设计不同步的情况在实际开发过程屡屡出现。
这种认识造成的危害性在于使得设计的测试用例缺乏实用性,误报很多不是软件缺陷的BUG,误导测试用例执行人员,同时也浪费了开发人员的解决BUG的精力和时间。
几乎所有软件项目的开发过程都处于不断变化(随着需求的变更)过程中。设计软件测试用例与软件开发设计并行进行,必须根据软件设计的变化,对软件测试用例进行内容的调整和数量的增减,增加一些针对软件新增功能的测试用例,删除一些不再适用的测试用例,修改那些模块代码更新了的测试用例。
误区四、测试用例不包含实际的数据和明显的验证手段测试用例是通常是一组输入、执行条件、预期输出结果的组合,毫无疑问地应该包括清晰的输入数据和预期输出,没有测试数据的用例最多只具有指导性的意义,不具备可执行性。例如我们常用的边界值法就对数据提出了明显的要求。
很多测试工程师(尤其是测试新手)编写的测试用例中,“预期输出”仅描述为程序的可见行为,实际上,“预期结果”的含义并不只是程序的可见行为。例如,对一个代表信息管理系统,输入代表信息,点击“保存”按钮后,系统提示“保存成功”,这样是不是一个完整的用例呢?是不是系统输出的“保存成功”就应该作为我们唯一的验证手段呢?显然不是,保存是否成功需要查看相应的数据记录是否在数据库中更新:在数据库中执行查询语句进行查询,看查询结果是否与预期的一致。
因此,在测试用例中,还应该包含实际的测试数据和对测试结果的显式验证手段。
误区五、测试输入数据设计方法等同于测试用例设计方法现在流行的一些测试书籍认为,测试用例的设计方法包括:等价类、错误推测法、场景设计法、边界值法、因果图法等。这种表述是极其片面的,这些方法只是软件功能测试用例设计中如何确定测试输入数据的方法,而不是测试用例设计的全部内容。
确定测试的输入数据对于软件功能测试和性能测试的重要性不言而喻,它决定了测试的有效性和效率。但是,测试用例中输入数据的确定方法只是测试用例设计方法的一个很小的方面,除了确定测试输入数据之外,测试用例的设计还包括如何根据需求和行业软件的具体设计规范确定测试用例的设计策略、设计用例的表示方法以及测试用例组织管理形式等问题。
我们绝对不能从心理上忽视测试用例设计内容的丰富性和技术的复杂性,而应综合考虑被测软件的功能、特性、组成元素、测试用例组织方法等内容。
误区六、让测试新手设计测试用例很多测试新手被要求从测试用例的设计学起,往往感到无从下手。实际上,测试新手设计的测试用例往往存在设计出的测试用例对软件功能和特性的覆盖度不高、功能设计的颗粒度不合理、可复用性差等诸多缺陷。
软件测试用例设计是软件测试的中高级技能,不是每个人(尤其是测试新手)都可以编写的,测试用例编写者不仅要掌握软件测试的技术和流程,而且要对被测软件的需求、功能规格说明以及程序结构等有比较透彻的理解。
我们建议安排经验丰富的测试人员进行测试用例设计,测试新手可以从执行测试用例开始,随着测试人员的测试技术的提高和对被测软件的熟悉,可以学习测试经验丰富的测试人员的用例设计经验,尝试编写测试用例。
相关推荐:考试吧策划:2010年软件水平考试完全指南北京 | 天津 | 上海 | 江苏 | 山东 |
安徽 | 浙江 | 江西 | 福建 | 深圳 |
广东 | 河北 | 湖南 | 广西 | 河南 |
海南 | 湖北 | 四川 | 重庆 | 云南 |
贵州 | 西藏 | 新疆 | 陕西 | 山西 |
宁夏 | 甘肃 | 青海 | 辽宁 | 吉林 |
黑龙江 | 内蒙古 |