在此之前我搜集一些关于测试用例的知识,后来在我们的QQ群里专门定了一期讨论,来探讨测试用例,毕竟这是一个很大的话题,很难做到面面俱到,但我会尽量全面,用通俗的语言来说测试用例。

---------------------------------------------------------------------------------------

注:我们这里要说的测试用例指功能测试用例。

一、什么是测试用例?

测试用例是为某个特殊目标而编制的一组测试输入、执行条件以及预期结果,以便测试某个程序路径或核实是否满足某个特定需求。

通俗的讲:就是把我们测试系统的操作步骤用按照一定的格式用文字描述出来。

二、写测试用例有什么好处?

  • 理清思路,避免遗漏

这里是我们认为最重要的一点,假如我们测试的项目大而复杂,我们可以把项目功能细分,根据每一个功能通过编写用例的方式来整理我们测试系统的思路,避免遗漏掉要测试的功能点。

  • 跟踪测试进展

通过编写测试用例,执行测试用例,我们可以很清楚的知道我们的测试进度。

  • 历史参考

在我们所做的项目中,也许会有很多功能是相同或相近的,我们对这类功能设计了测试用例,便于以后我们遇到类似功能的时候可以做参考依据。

  • 重复性

我们测试一个系统不是一个人测一遍就算测完的,需要多人反复的进行测试,那么我们就需要测试用例来规范和指导我们的测试行为。

  • 告诉领导,这事俺干过,不然别人怎么知道你测没测,测的全面不全面,拿测试用例给他们看呗!俺就是照着这个干活,呵呵!

三、测试用例的方法

好吧,咱知道啥是测试用例了,也是知道为什么要写测试用例了,那到底应该怎么写?无从下手啊。我们在写测试用例之前,先学习几种方法,它是我们写测试用例的指导思想。

1.  等价类划分

在某个输入域的子集合,在该子集合中,各个输入数据对于揭露程序中的错误都是等价的。假如有一个输入框要求输入1-10000个 数,我们不可能用每一个数去试,我们输入5 和输入6去验证和揭露输入框的错误可以看做是等价的。那么这个时候我们就可以随机的抽取一些数据来进行验证。如:10 、99、7777......

等价类分:有效等价类和无效等价类

输入框要求输入1-10000的数

有效等价类:可以输入1-10000之间的数来验证,如:2、5、99、8495......

无效等价类:可以输入1-10000之外的任意字符验证,如:20000、字母、下划线、特殊符号、空格、回车.....

2.  边界值

边界值是对等价类的补充,测试工作经验告诉我们,大量的错误是出在输入输出的边界价上。我们还拿上面的例子,一个输入框要求输入 1-10000之间的数。我们要测它有没有超出这个范围,如:0、-1、-2、1000、10001.....等等,来判定是否超出了我们的范围。

3.  因果图

因果图方法最终生成的就是判定表,它适合于检查程序输入条件的各种组合情况。举个例子:原因:A=0,B=0,结果我就可以判定:A=B。确切的说他是一种因果关系思想。它会无形中指导这我们的测试。当然了,我们为了以免遗漏,可以把系统中的因果关系用图画出。不过系统大而复杂的话就是个体力活了。呵呵。

4.  错误推测法

基于经验和直觉推测出系统可能存在的错误,从而有针对性的设计测试用例的方法。

5.  其它

设计测试用例的方法有很多,我们常用就上面几种,其它的方法还有:状态迁移图、流程分析法、正交验证法等等。

四、测试用例的格式与要素

   一个测试用例应该包括:编号,标题,测试场景,测试步骤,预期结果。

当然还可加入一些它选项,如:优先级、测试阶段....

注:上面的格式取自《微软的软件测试之道》,它并不一定适合你,我只是让大家对测试格式有个了解。

关于测试用例的存放管理:

1.  项目管理系统自带的用例管理,一般用例会与项目挂钩,有固定的格式,搜索、修改等功能,使用起来非常方便。如:禅道项目管理、QC、bugfree 等等都带的有用例管理功能。

2.  通过world\Excel文档形式管理,这样的好处就是自己定义测试用例的格式。

-----------------------测试用例例子--------------------------------------------------------

基础知识了解的差不多了,下面来看一个具体的测试用例。我们会有更深刻的认识。

注:这不是一个完整的测试用例,格式也不是固定必须这样的,你们可以根据自己的需求编写设计测试用例。

==========================================================================

------------------------------------我们还需要知道的,关于测试用例的-------------------------------

一、.我们在什么时候可以设计测试用例?

当根据客户的需求整理出项目需求分析文档时,我们就可以根据需求文档来编写测试用例了。但是,一般我们(国内大多小公司)项目需求文档都非常“简陋”,所以,很难根据需求文档设计测试用例。

我们只有等到项目开发人员把项目开发出来,给我们系统文档、部署环境、数据库结构(如果系统牵涉到数据库的话),我们根绝这些文档来设计测试用例。

二、测试用例的评审与更新

我们设计的测试用例设计完成之后,是否完整?是否符合系统?符合客户要求?对用例做一个评审是必不可少。关于评审的方式,不同的公司有不同的流程。

我们编写的测试用例也不是经过评审之后就不变了,随着需求的变更、功能的改进,测试用例当然也需要更新和变动。

三、什么情况下不适合写测试用例

  • 文件时间

如果一个功能我很快就测试完了,而且只需要测试一遍,但我们设计测试用例时却比较麻烦,花时间也长。这个时候就没必要编写测试用例了。

  • 需求变动大且频繁

需求的功能变动非常频繁,而且变动很大,之前编写的测试用例根本没法使用,必须要重新编写,这个时候也没必要去设计测试用例了。

  • 项目时间不允许

这一项是不太厚道的做法,如果不是急需交付客户的话,尽量不要这样做;当然了,如果只是给客户展示或试用,可以在之后进行补充和完善测试用例。

  • 不要编写不完整或别人看不懂的测试用例,那样就没有意义了。

============个人闲聊内容,欢迎指正========

四、停止软件测试的标准。

语句覆盖最低不能小于80%,测试需求覆盖率达到100%,测试用例覆盖率达到100%,一、二级缺陷修复率达到100%,三、四级修复率达到80%。

(上面一句是再网上找的,不是标准,只是个参考)

bug等级:

一级:非常严重的bug

二级:严重的bug

三级:一般性的bug

四级:建议性问题

五、关于探索性测试

完全的执行测试用例时一件非常枯燥的事情,个人在执行测试用例时会做一些,其它的非常规性的操作,看系统是否会有相应的处理和提示。我的一部分bug就是再这种非常规操作下发现的。

当然了真正的探索性测试需要对产品的深入了解,以及软件开发技术有一定的深度和宽度。姑且把我们的探索性测试看成是瞎捣鼓吧!呵呵。

六、 交叉测试

有木有发现,当我们第一遍测试系统时,会非常认真,但要我们测试第二遍时,我们不愿意像第一次那样认真的去测了,这不能说明我们不负责,而是每个人都有的心理现象。这个时候,我们可以和其它测试人员交换功能来测试,提高效率,而且更容易发现问题。

七、测试的目的

1.  我们让它做的它必须会做。

2.  我们不让它做的它必须不会做。

可能你会发现有附加功能的时候,就是客户没有要求,我们加了这样的功能,可能加了这点功能系统看上去会更好。这时怎么办?算问题么?

作为开发人员,中规中矩的做东西最好,如果真的有非常好的功能要加的话,需要和客户沟通,然后写到需求里。毕竟多一点功能多一点风险。呵呵

作为测试人员,凡是不符合需求文档的都需要当问题点提出。责任分明,以免后续麻烦。

----------------------------------------------------

修改:

1.测试用例的格式的要素,去掉“实际结果”

2.关于测试方法“等价类划分”的解释。

浅说《测试用例》----给测试新手的相关推荐

  1. 浅谈软件测试人员不要这样写测试用例(给测试新手和老鸟的提示)

    试用例的编写是QA团队的主要活动之一,我们的大部份时间都花在了编写.审查.执行和维护这些用例上.很不幸的是,测试用例仍然是最容易出错的地方.由于理解上的差异,测 测试用例的编写是QA团队的主要活动之一 ...

  2. SAP UI5 应用开发教程之八十五 - 如何用 OPA5 编写测试用例来测试用户输入文本的功能试读版

    一套适合 SAP UI5 初学者循序渐进的学习教程 作者简介 Jerry Wang,2007 年从电子科技大学计算机专业硕士毕业后加入 SAP 成都研究院工作至今.Jerry 是 SAP 社区导师,S ...

  3. 游戏测试新手必看攻略

    游戏测试新人在刚接触测试,或者在游戏公司实习的童鞋们可以看看这篇攻略幺-看完这篇攻略我不敢说你就得到了测试的精髓,至少你会在实习时不会茫然无措. 1.在编写测试用例需要准确细致的了解模块的策划文档,策 ...

  4. 重拾算法(3)——用458329个测试用例全面测试二叉树和线索二叉树的遍历算法

    重拾算法(3)--用458329个测试用例全面测试二叉树和线索二叉树的遍历算法 在"上一篇"和"上上一篇"中,我给出了二叉树和线索二叉树的遍历算法.给出算法容易 ...

  5. 85. 如何用 OPA5 编写测试用例来测试用户输入文本的功能

    SAP UI5 应用开发教程之八十五 - 如何用 OPA5 编写测试用例来测试用户输入文本的功能 本教程之前的系列文章,我们已经学习了如何在测试用例里,用代码的方式,来模拟用户点击 SAP UI5 表 ...

  6. 【150】设计测试用例:假设京东有一个web API:输入打折价p1和原价p0,返回折扣信息0.9,请设计测试用例进行测试

    设计测试用例(原文见公众号python宝)   假设京东有一个web API:http://p.jd.com?p1=90&p0=100,输入打折价p1和原价p0,返回折扣信息0.9,请设计测试 ...

  7. 零基础转行成功的前辈写给测试新手的话

    目录 前言 1.你是一个检查者,你不需要为质量负责 2.缺陷都是有价值的 3.你报告第一个问题之前一切都是美好的 4.只能测试你能观察的 5.别忘记你是怎样到一个地方的 6.标准和流程是你的朋友 7. ...

  8. 什么是测试用例和测试规程,设计一个测试用例应当从哪几方面考虑?

    狭义来讲,一个测试用例就是 测试人员 用以测试被测软件的某个特性或特性组合的一组数据. 这组数据可能是从用户处得来的实际的一组数据,也可能是测试人员专门设计出来的测试软件某些功能的一组数据. 测试规程 ...

  9. qq登录界面句柄_别小看QQ邮箱测试,80%的测试新手都不能写出完整的测试用例~...

    对于很多刚进入测试行业的新手来说,由于自身的工作经验不足,虽有测试基础知识傍身,但仍然很难将测试用例写的尽善尽美.因此,学习别人的测试经验,将是你成为测试达人的必经之路. 今天,我们就以QQ邮箱为例, ...

最新文章

  1. mysql崩溃恢复过程_一起看下MySQL的崩溃恢复到底是怎么回事
  2. Redis笔记系列(特别总结篇)——常见配置redis.conf知识点总结
  3. 安卓x86程序安装目录_电脑上的安卓系统体验
  4. sklearn学习(三)
  5. LambdaMART的思想
  6. HDU 5527:Too Rich(DFS+贪心)***
  7. python中缩进在程序中_python代码缩进
  8. SpringCloud 超详细个人笔记
  9. mongodb的文档游标
  10. nc65 单据非向导开发 源代码_最受Java开发者喜爱的5款开发工具
  11. Java锁示例– ReentrantLock
  12. JVM初识之类加载器
  13. 农用地包括哪些地类_设施农用地属于什么地类、包括哪些用地?
  14. 光模块测试CEI-28G-VSR 浅析1---背景基础介绍
  15. 淘宝用户分析(步骤详细,数据分析项目)
  16. python累乘怎么写_Python3 实现列表元素求累和,求累乘
  17. c语言对称矩形的判定,八年级数学下册 第19章 矩形、菱形与正方形 19.1.2 矩形的判定教案 (新版)华东师大版...
  18. 百度IP地址查询API使用: 应用类型为浏览器端
  19. iphone通用设置里显示UDID(tweak)
  20. 3译码器与半加器的学习

热门文章

  1. 安全狗深圳主题沙龙会:企业如何打造云安全堡垒
  2. 我从Team Leader变成了CTO,有些不适应,不过我要调整
  3. 实现带下拉菜单的工具栏按钮
  4. Spring Boot 实战系列课程终于齐啦~
  5. Spring Security 基本介绍,初窥路径
  6. SEED实验系列:Collabtive系统SQL注入实验
  7. linux打补丁前如何备份,关于Linux下给文件打补丁
  8. 什么是认证、授权、会话
  9. MySQL高级 - 复制 - 原理
  10. 商品评价 - 实现分页