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

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

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

由于理解上的差异,测试实践组织方式的不同,以及时间的缺乏等等原因,我们经常看到一些难以让人满意的测试用例。

网上有很多关于要怎样写测试用例的文章,但这篇文章却是告诉你不要这样写测试用例——几个将有助于创造独特、优质且有效的测试用例的技巧。

现在,让我们开始。请注意,这些技巧不只适用于测试新手,它们同样适用于有经验的测试人员。

先说最重要的——什么是测试用例?如何编写测试用例?

测试用例是指导测试人员验证一个特定的指标或目标的一组指令,随后可以告诉我们,系统行为是否与预期一致。

有关如何编写测试用例的基本说明,请参阅下面的文章:
通过需求规格说明书(SRS)编写测试用例

并观看这个很赞的视频,它介绍了一些编写良好的测试用例的要诀和技巧:

测试用例中最常见的三个问题:

这些天,从我的学生和工作中的同事那儿,我看到的最常见的测试用例中的问题是:

  1. 步骤混合
  2. 将应用程序行为作为预期行为
  3. 一条用例中包含多个条件

在我记录的测试用例编写过程中最常见的问题列表中,这几条被列在了前三的位置。

有趣的是,这些既发生在测试新手身上,也发生在有经验的测试人员身上。我们只是一味地遵循着相同的存在缺陷的过程,却从来没有意识到,一些简单的措施就可以很容易解决这些问题。

我们来逐个讨论下细节。

不要这样写测试用例(给测试新手和老鸟的提示)(3)
发表于:2016-12-07来源:kiford作者:翻译:wisp点击数:32720 标签:测试用例
#1. 步骤混合 首先,什么是步骤混合? 例如,你正在给别人指从A点到B点的方向:如果你说去XYZ,然后去ABC,这并没有多少意义,因为我们需要思考首先,
#1. 步骤混合

首先,什么是步骤混合?

例如,你正在给别人指从A点到B点的方向:如果你说“去XYZ,然后去ABC”,这并没有多少意义,因为我们需要思考——“首先,我如何到达XYZ”——而“从这里左转,直行1英里,然后在第11号路右转就可以到达XYZ”可能会取得更好的效果。

同样的规则也适用于测试用例及其步骤。

例如:我正在为Amazon.com写一条测试用例 - 订购任何产品

以下是我的测试用例步骤(注:我只是写的步骤,而不包含测试用例的其他部分,如预期结果等)

a. 访问Amazon.com
b. 通过在屏幕顶部的”搜索”栏输入产品关键字或名字搜索产品
c. 从显示的搜索结果中,选择第一个
d. 在产品详情页,单击“添加到购物车”
e. 结算并支付
f. 检查订单确认页

现在,你能指出哪一步混合了多个步骤吗?

住,测试用例总是关于“如何”来测试,所以,在你的测试用例中写出“如何检查和支付”的确切步骤是非常重要的。

因此,这条用例如果写成下面这样会更有效:

a. 访问Amazon.com
b. 通过在屏幕顶部的”搜索”栏输入产品关键字或名字搜索产品
c. 从显示的搜索结果中,选择第一个
d. 在产品详情页,单击“添加到购物车”
e. 在购物车页面点击“结算”
f. 输入信用卡信息、物流信息和账单信息
g. 单击”结算”
h. 检查订单确认页

因此,一个混合了多步的步骤可以被分解成若干个单独的步骤。下一次我们写测试用例的时候,请大家都注意这一点,我相信你们会同意我的,因为我们在无意中经常这么做。
#2. 将应用程序行为作为预期行为

近来,越来越多的项目不得不得处理这种情形。

缺乏文档、极限编程、快速的开发周期,这些原因迫使我们依赖于旧版本应用程序来编写测试用例或将其作为测试的基础。通常,这是一个糟糕的实践——但并不总是这样。它是无害的,只要你保持开放的心态并明白——“应用程序可能是有缺陷的”。只有当你不这么认为的时候,事情才会变得不好。

像往常一样,我们通过实例来说明。如果你正在为下面这个页面编写/设计测试步骤: 用例1: 如果我的测试用例步骤是下面这样的: 1.打开购物网站 2.单

像往常一样,我们通过实例来说明。如果你正在为下面这个页面编写/设计测试步骤:
获取更多相关知识访问如下链接
https://edu.csdn.net/lecturer/3215
https://edu.csdn.net/course/detail/31909
https://edu.csdn.net/course/detail/30898
https://edu.csdn.net/course/detail/25768
https://edu.csdn.net/course/detail/22948
https://edu.csdn.net/course/detail/28104
https://edu.csdn.net/course/detail/28103
https://edu.csdn.net/course/detail/27231
用例1:
如果我的测试用例步骤是下面这样的:

1.打开购物网站
2.单击”配送和退货”——期望结果:”配送和退货”页显示“在这里填写你的信息”和一个“继续”按钮。

那么,这是不对的。

用例2:

1.打开购物网站
2.单击”配送和退货”
3.在屏幕上显示的“输入订单号”文本框中,输入订单号。
4.单击“继续”——期望结果:显示订单相关的配送和退货详情。

用例2更好,因为即使作为参考的应用程序行为不正确,我们也只不过是用它来指导我们做进一步研究并按照预期的正确功能来编写期望结果。

意: 将应用程序作为参考是一条捷径,但是有风险。只要我们足够小心,它可以产生令人吃惊的结果。 #3. 一条用例中包含多个条件 我们再次从例子中
注意:将应用程序作为参考是一条捷径,但是有风险。只要我们足够小心,它可以产生令人吃惊的结果。

#3. 一条用例中包含多个条件

我们再次从例子中学习——来看下面的步骤:这是一个登录功能的测试用例中的步骤。

a. 输入有效的详情信息,然后点击“提交”
b. 保持“用户名”字段为空,点击“提交”
c. 保持“密码”字段为空,点击“提交”
d. 使用已经登录的用户名/密码,点击“提交”

将4个不同的测试用例组合成了一个。你可能会说“这有什么不好?”不但节省了纸张,而且只用了1个用例就把原本用四个用例才能做的事情都做了,不是更好吗?好吧,不那么好。为什么?往下看:

如果其中一个失败了会怎么样?——我们不得不将整条用例标记为“失败”。如果我们将整条测试用例标记为“失败”,就意味着四种情况都不工作,但事实并非如此。

1

测试用例必须有一个流向。从预置条件到步骤1,然后是所有步骤。如果我遵循这个测试用例,如果第一步(a)成功,我将在登录后的页面,那里不会再有

测试用例必须有一个流向。从预置条件到步骤1,然后是所有步骤。如果我遵循这个测试用例,如果第一步(a)成功,我将在登录后的页面,那里不会再有“登录”选项。所以当我到了第二步(b)的时候,测试人员在哪里输入用户名?看,流向乱了。

因此,要将测试用例模块化。这听起来好像挺麻烦的,但是你需要做的只是将事情分解,并使用 Ctrl+C 和 Ctrl+V。
总结

这是对一些测试用例文档中的常见问题的简单总结,如果你遇到了其他问题并且愿意让我们在以后的文章中讨论,请告诉我。

获取更多相关知识访问如下链接
https://edu.csdn.net/lecturer/3215
https://edu.csdn.net/course/detail/31909
https://edu.csdn.net/course/detail/30898
https://edu.csdn.net/course/detail/25768
https://edu.csdn.net/course/detail/22948
https://edu.csdn.net/course/detail/28104
https://edu.csdn.net/course/detail/28103
https://edu.csdn.net/course/detail/27231

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
件开发和软件测试是软件工程中不可或缺的两个环节。软件开发是指将软件需求转化为可执行的软件系统的过程,而软件测试则是为了保证软件系统的质量和稳定性而进行的一系列活动。 在软件开发过程中,需求分析是非常重要的一步。在这一步中,开发人员需要与客户沟通,了解客户的需求,并将其转化为可执行的软件需求。接下来是设计阶段,开发人员需要根据需求设计出软件系统的架构和模块,确定软件系统的功能和性能。然后是编码阶段,开发人员需要根据设计文档编写代码,并进行单元测试。最后是集成测试和系统测试,开发人员需要将各个模块进行集成测试,并对整个系统进行测试,以保证软件系统的质量和稳定性。 软件测试是软件开发过程中不可或缺的一环。软件测试可以分为手动测试和自动化测试两种方式。手动测试是指测试人员根据测试用例一步一步地执行测试,并记录测试结果。自动化测试是指将测试用例转化为可执行的脚本,并通过自动化测试工具执行测试。自动化测试可以提高测试效率和测试覆盖率,减少测试成本。 总之,软件开发和软件测试是软件工程中不可或缺的两个环节。软件开发需要遵循软件工程的规范和标准,进行需求分析、设计、编码、测试等一系列活动,以保证软件系统的质量和稳定性。而软件测试则是为了保证软件系统的质量和稳定性而进行的一系列活动,可以通过手动测试和自动化测试两种方式进行。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

传说三哥

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值