【软件测试】4、测试用例的设计

简介: 众所周知,试图对软件进行完全的测试并发现全部的问题是一件不可能的任务,对于测试而言,最有效的思想就是努力使测试尽可能完全。 在这个过程中,测试用例的设计至关重要。

众所周知,试图对软件进行完全的测试并发现全部的问题是一件不可能的任务,对于测试而言,最有效的思想就是努力使测试尽可能完全。

在这个过程中,测试用例的设计至关重要。因为软件测试最关键的问题是:如何从所有可能的测试用例全集中寻找可能发现错误最多的子集。


1、白盒测试


白盒测试的重点在于测试用例的执行程度,或测试用例覆盖程序源码逻辑结构的程度。完整的白盒测试将走过程序运行路径的每一种可能,然而这是不可能的。因此需要设定一些准则来约束并不完善的测试用例子集,以求尽可能多的发现程序中的潜在错误。

(1)语句覆盖

语句覆盖要求将程序的每一行代码都执行过一次。这个准则通常并不完善,依照此准则设计的测试用例常常会遗漏许多的错误。

(2)判定覆盖

判定覆盖又称为分支覆盖,该准则比语句覆盖稍强。判定覆盖要求设计足够的测试用例,使得代码中的每一个判断都至少得到一个为真和一个为假的输出结果。需要注意的分支或判定语句包括switch、do-while和if-else等。判定覆盖包含语句覆盖,要求每个判断都有是非两种判定结果,并且每条语句都被执行一遍。然而,仅仅是判定覆盖依然是不完善的,存在很多遗漏错误的可能。

(3)条件覆盖

条件覆盖是比判定覆盖稍强的准则。条件覆盖于判定覆盖不同的一点在于,条件覆盖重点考察判断中每个条件的所有可能结果。如存在判断if(A & B),则条件覆盖要求测试用例实现A为真+B为假,和A为假+B为真的情况,而不关心选择的结果。显而易见,条件覆盖也并不完善。

(4)判定/条件覆盖

该准则要求将所有条件的所有可能至少执行一次,将每个判断的所有可能结果至少执行一次,将每个入口点都至少调用一次。然而该准则也不是尽善尽美,因为有些特定的条件会屏蔽其他条件,所以并非所有可能性都被执行到。

(5)多重条件覆盖

多重条件覆盖要求设计足够多的测试用例,将每个判定中给所有可能的条件结果的组合,以及所有的入口点都至少执行一次。


2、黑盒测试


黑盒测试又称功能测试,作用在于检测软件是否可以正常实现其设定的功能。

(1)等价划分

等价划分法的两种思想:①每个测试用例尽可能体现更多不同的输入情况,以最大限度减小全部测试用例规模;②尽量将程序输入范围进行划分为数量有限的等价类。

等价划分法设计测试用例的步骤:

确定等价类:每选取一个输入条件,将其划分为两个或更多个组,其中至少包括一个有效等价类和一个无效等价类。

生成测试用例:①首先编写新的测试用例,尽可能多的覆盖尚未被涵盖的有效等价类,直到所有有效等价类都被覆盖。②编写新的测试用例,仅仅覆盖一个尚未被包括的无效等价类。

(2)边界值分析

如果开发经验较为丰富,那么可以理解很多程序的错误都发生在边界条件上。因此选择处于有效等价类边缘的测试用例常常比选择典型的用例更加有效。

边界值分析法的原则:

  1. 如果输入条件规定了值的范围,则应取刚达到这个范围的边界的值,以及刚刚超越这个范围边界的值作为测试输入数据。
  2. 如果输入条件规定了值的个数,则用最大个数,最小个数,比最小个数少一,比最大个数多一的数作为测试数据。
  3. 根据规格说明的每个输出条件,使用前面的原则1)。
  4. 根据规格说明的每个输出条件,应用前面的原则2)。
  5. 如果程序的规格说明给出的输入域或输出域是有序集合,则应选取集合的第一个元素和最后一个元素作为测试用例。
  6. 如果程序中使用了一个内部数据结构,则应当选择这个内部数据结构的边界上的值作为测试用例。
  7. 分析规格说明,找出其它可能的边界条件。

(3)因果图

当输入条件之间产生相互关系和组合的时候,情况可能会变得比较复杂,此时可考虑因果图法。因果图方法最终生成的就是判定表,适合于检查程序输入条件的各种组合情况。

生成测试用例:

  1. 分析软件规格说明描述中,哪些是原因(即输入条件或输入条件的等价类),哪些是结果(即输出条件),并给每个原因和结果赋予一个标识符。
  2. 分析软件规格说明描述中的语义。找出原因与结果之间,原因与原因之间对应的关系. 根据这些关系,画出因果图。
  3. 由于语法或环境限制,有些原因与原因之间,原因与结果之间的组合情况不可能出现. 为表明这些特殊情况,在因果图上用一些记号标明约束或限制条件。
  4. 把因果图转换为判定表。
  5. 把判定表的每一列拿出来作为依据,设计测试用例。

从因果图生成的测试用例(局部,组合关系下的)包括了所有输入数据的取TRUE与取FALSE的情况,构成的测试用例数目达到最少,且测试用例数目随输入数据数目的增加而线性地增加。

目录
相关文章
|
12天前
|
敏捷开发 Java 测试技术
探索软件测试中的自动化测试框架
在软件开发的生命周期中,软件测试扮演着至关重要的角色。随着技术的不断进步和软件项目的日益复杂化,传统的手动测试方法已经无法满足高效、准确的测试需求。自动化测试作为一种提高测试效率和质量的有效手段,越来越受到开发者和测试者的青睐。本文将深入探讨自动化测试框架的重要性、常见的自动化测试工具以及如何选择合适的自动化测试框架。
37 10
|
20天前
|
机器学习/深度学习 前端开发 测试技术
探索软件测试中的自动化测试框架选择与优化策略####
本文深入探讨了在当前软件开发生命周期中,自动化测试框架的选择对于提升测试效率、保障产品质量的重要性。通过分析市场上主流的自动化测试工具,如Selenium、Appium、Jest等,结合具体项目需求,提出了一套系统化的选型与优化策略。文章首先概述了自动化测试的基本原理及其在现代软件开发中的角色变迁,随后详细对比了各主流框架的功能特点、适用场景及优缺点,最后基于实际案例,阐述了如何根据项目特性量身定制自动化测试解决方案,并给出了持续集成/持续部署(CI/CD)环境下的最佳实践建议。 --- ####
|
2月前
|
机器学习/深度学习 人工智能 监控
提升软件质量的关键路径:高效测试策略与实践在软件开发的宇宙中,每一行代码都如同星辰般璀璨,而将这些星辰编织成星系的过程,则依赖于严谨而高效的测试策略。本文将引领读者探索软件测试的奥秘,揭示如何通过精心设计的测试方案,不仅提升软件的性能与稳定性,还能加速产品上市的步伐,最终实现质量与效率的双重飞跃。
在软件工程的浩瀚星海中,测试不仅是发现缺陷的放大镜,更是保障软件质量的坚固防线。本文旨在探讨一种高效且创新的软件测试策略框架,它融合了传统方法的精髓与现代技术的突破,旨在为软件开发团队提供一套系统化、可执行性强的测试指引。我们将从测试规划的起点出发,沿着测试设计、执行、反馈再到持续优化的轨迹,逐步展开论述。每一步都强调实用性与前瞻性相结合,确保测试活动能够紧跟软件开发的步伐,及时适应变化,有效应对各种挑战。
|
2月前
|
测试技术 UED
软件测试的艺术:探索性测试的力量
【10月更文挑战第6天】在软件开发的世界中,测试是确保产品质量的关键步骤。传统的测试方法往往遵循严格的脚本和预定义的路径进行,但探索性测试(ET)则提供了一种更为灵活、创造性的替代方案。通过模拟真实用户的行为和思考过程,ET能够揭示那些传统测试可能遗漏的问题。本文将深入探讨探索性测试的核心原则、实施策略以及它如何提高软件测试的效率和有效性。
|
24天前
|
测试技术 开发者 UED
探索软件测试的深度:从单元测试到自动化测试
【10月更文挑战第30天】在软件开发的世界中,测试是确保产品质量和用户满意度的关键步骤。本文将深入探讨软件测试的不同层次,从基本的单元测试到复杂的自动化测试,揭示它们如何共同构建一个坚实的质量保证体系。我们将通过实际代码示例,展示如何在开发过程中实施有效的测试策略,以确保软件的稳定性和可靠性。无论你是新手还是经验丰富的开发者,这篇文章都将为你提供宝贵的见解和实用技巧。
|
22天前
|
jenkins 测试技术 持续交付
软件测试中的自动化测试策略
在当今快速发展的软件行业中,自动化测试已成为确保软件质量和效率的关键工具。本文将探讨自动化测试的重要性、实施策略以及面临的挑战,旨在为软件开发团队提供实用的指导和建议。
|
1月前
|
测试技术
探索软件测试中的“思维侧翼”——如何以创新思维引领测试策略###
本文旨在探讨软件测试领域中,如何通过培养与运用创新思维,提升测试策略的有效性与效率。不同于传统的技术解析或理论阐述,本文将以“思维侧翼”为喻,启发读者从不同维度审视软件测试,寻找突破常规的思路与方法。我们相信,在快速迭代的软件开发周期中,灵活多变且富有创造力的测试思维,是发现潜在缺陷、保障产品质量的关键。 ###
|
1月前
|
测试技术 定位技术 UED
软件测试的艺术:探索性测试的深度与广度
【10月更文挑战第22天】在软件开发的广阔舞台上,测试扮演着不可或缺的角色。本文将带领读者深入理解探索性测试(Exploratory Testing)的精髓,揭示其在现代软件质量保证中的价值。我们将通过实际案例、生动比喻和具体步骤,展现如何像艺术家一样进行软件测试,确保产品质量的同时,提升测试的效率和乐趣。文章不仅适合初学者建立测试基础,也能帮助资深测试人员深化对探索性测试的理解和应用。
|
1月前
|
监控 安全 jenkins
探索软件测试的奥秘:自动化测试框架的搭建与实践
【10月更文挑战第24天】在软件开发的海洋里,测试是确保航行安全的灯塔。本文将带领读者揭开软件测试的神秘面纱,深入探讨如何从零开始搭建一个自动化测试框架,并配以代码示例。我们将一起航行在自动化测试的浪潮之上,体验从理论到实践的转变,最终达到提高测试效率和质量的彼岸。
|
2月前
|
测试技术
软件测试中的探索性测试(ET)实践
【10月更文挑战第5天】本文将深入探讨一种与传统脚本化测试不同的测试方法——探索性测试(Exploratory Testing,简称ET)。我们将通过一个实际案例来展示ET的有效性,并分享如何将ET融入日常的软件测试流程中。文章旨在为测试人员提供一种灵活、高效的测试策略,帮助他们更好地发现软件中的缺陷。