`
yangzb
  • 浏览: 3470811 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

软件测试之测试策略

    博客分类:
  • QC
阅读更多

  第一部分  软件测试 策略基础

  为什么要编写测试策略?测试策略就是如何进行软件测试的计划。测试策略的目标包括:

  取得利益相关者(比如管理部门、开发人员、测试人员、顾客和用户等)的一致性目标;

  从开始阶段对期望值进行管理;

  确保“开发方向正确”;

  确定所有要进行的测试类型。

  1、策略与软件测试策略

  (1)策略:在一定的政治路线指导下,根据具体条件而规定的斗争原则、方式和方法。<新华字典>

  (2)软件测试策略:在一定的软件测试标准、测试规范的指导下,依据测试项目的特定环境约束而规定的软件测试的原则、方式、方法的集合。

  测试策略为测试提供全局分析,并确定或参考:

  项目计划、风险和需求;

  相关的规则、政策或指示;

  所需过程、标准与模板;

  支持准则;

  利益相关者及其测试目标;

  测试资源与评估;

  测试层次与阶段;

  测试环境;

  各阶段的完成标准;

  所需的测试文档与检查方法。

  2、软件测试策略的重要性

  (1)任何一个完全测试或穷举测试的工作 量都是巨大的,在实践上是行不通的,因此任何实际测试都不能保证被测程序中不遗漏错误或缺陷;

  (2)为了最大程度较少这种遗漏,同时最大限度发现可能存在的错误,在实施测试前必须确定合适的测试方法和测试策略,并以此为依据制定详细的测试案例。

  3、软件测试策略的目的

  是不是所有软件测试都要运用现有软件测试方法去测试呢?答案是否定的。依据软件本身性质、规模和应用场合的不同,我们将选择不同测试方案,以最少的软硬件、人力资源投入得到最佳的测试效果,这就是测试策略的目标所在。

  4、软件测试策略的影响因素

  软件测试策略随着软件生命周期的变化、软件测试方法、技术与工具的不同发生的变化。这就要求我们在制定测试策略时候,应该综合考虑测试策略的影响因素及其依赖关系。这些影响因素可能包括:测试项目资源因素、项目的约束和测试项目的特殊需要等。

  5、软件测试策略的制定过程

  (1)输入

  需要的软硬件资源的详细说明;

  针对测试和进度约束而需要的人力资源的角色和职责;

  测试方法、测试标准和完成标准;

  目标系统的功能性和技术性需求;

  系统局限(即系统不能够提供的需求)等等。

  (2)输出

  已批准和签署的测试策略文档、测试用例、测试计划;

  需要解决方案的测试项目;

  (3)过程

  1)确定测试的需求

  测试需求所确定的是测试内容,即测试的具体对象。在分析测试需求时,可应用以下几条一般规则:

  测试需求必须是可观测、可测评的行为。如果不能观测或测评测试需求,就无法对其进行评估,以确定需求是否已经满足。

  在每个用例或系统的补充需求与测试需求之间不存在一对一的关系。用例通常具有多个测试需求;有些补充需求将派生一个或多个测试需求,而其他补充需求(如市场需求或包装需求)将不派生任何测试需求。

  测试需求可能有许多来源,其中包括用例模型、补充需求、设计需求、业务用例、与最终用户的访谈和软件构架文档等。应该对所有这些来源进行检查,以收集可用于确定测试需求的信息。

  2)评估风险并确定测试优先级¤

  成功的测试需要在测试工作中成功地权衡资源约束和风险等因素。为此,应该确定测试工作的优先级,以便先测试最重要、最有意义或风险最高的用例或构件。为了确定测试工作的优先级,需执行风险评估和实施概要,并将其作为确定测试优先级的基础。

  3)确定测试策略

  一个好的测试策略应该包括:实施的测试类型和测试的目标、实施测试的阶段、技术、用于评估测试结果和测试是否完成的评测和标准、对测试策略所述的测试工作存在影响的特殊事项等内容。

  如何才能确定一个好的测试策略呢?我们可以从基于测试技术的测试策略、基于测试方案的测试策略两个方面来回答这个问题。

  ①  基于测试技术的测试策略的要点

  著名测试专家给出了使用各种测试方法的综合策略:

  任何情况下都必须使用边界值测试方法;

  必要时使用等价类划分方法补充一定数量的测试用例;

  对照程序逻辑,检查已设计出的测试用例的逻辑覆盖程度,看是否达到了要求;

  如果程序功能规格说明中含有输入条的组合情况,则已开始可以选择因果图方法。

  ②  基于测试方案的测试策略

  对于基于测试方法的测试策略,一般来说应该考虑如下方面:

  根据程序的重要性和一旦发生故障将造成的损失来确定它的测试等级和测试重点;

  认真研究,使用尽可能少的测试用例发现尽可能多的程序错误,避免测试过度和测试不足!

  第二部分  测试策略的方法

  软件测试的策略、方法和技术是多种多样的。对于软件测试技术,可以从不同的角度加以分类:从是否需要执行被测软件的角度,可分为静态测试和动态测试。从测试是否针对系统的内部结构和具体实现算法的角度来看,可分为白盒测试和黑盒测试。

  1.  静态方法与动态方法

  所谓静态方法是指不运行被测程序本身,仅通过分析或检查源程序的文法、结构、过程、接口等来检查程序的正确性。静态方法通过程序静态特性的分 析,找出欠缺和可疑之处,例如不匹配的参数、不适当的循环嵌套和分支嵌套、不允许的递归、未使用过的变量、空指针的引用和可疑的计算等。静态测试结果可用 于进一步的查错,并为测试用例选取提供指导。

 

  动态方法是指通过运行被测程序,检查运行结果与预期结果的差异,并分析运行效率和健壮性等性能,这种方法由三部分组成:构造测试实例、执行程序、分析程序的输出结果。

  2.  功能测试与结构测试

  (1)功能测试

  功能测试是指在对程序进行的功能抽象的基础上,将程序划分成功能单元,然后在数据抽象的基础上,对每个功能单元生成测试数据进行测试。用这种方法进行测试时,被测程序被当作打不开的黑盒,因而无法了解其内部构造,因此又称为黑盒测试。

  黑盒测试也称功能测试或数据驱动测试,它是在已知产品所应具有的功能,通过测试来检测每个功能是否都能正常使用。在测试时,把程序看作一个不能 打开的黑盒子,在完全不考虑程序内部结构和内部特性的情况下,测试者在程序接口进行测试,只检查程序功能是否按照需求规格说明书的规定正常使用,程序是否 能适当接收输入数据而产生正确的输出信息,并且保持外部信息的完整性。

  在功能测试中,被测软件的输入域和输出域往往是无限域,因此穷举测试通常是不可行的。必须以某种策略分析软件规格说明,从而得出测试用例集,尽可能全面而又高效地对软件进行测试。下面就说明几种功能测试的方法:

  a.  等价类划分

  所谓等价类,就是指某个输入域的集合,集合中的每个输入对揭露程序错误来说是等效的,把程序的输入域划分成若干部分,然后从每个部分中选取少数代表性数据作为测试用例,这就是等价类划分方法。它是功能测试的基本方法。

  b.  因果图法

  因果图是一种形式语言,由自然语言写成的规范转换而成,这种形式语言实际上是一种使用简化记号表示数字逻辑图。因果图法是帮助人们系统地选择一组高效测试用例的方法,此外,它还能指出程序规范中的不完全性和二义性。

  c.  边值分析

  实践证明,软件在输入、输出域的边界附近容易出现差错,边值分析是考虑边界条件而选取测试用例的一种功能测试方法。所谓边界条件,是相对于输入和输出等价类直接在其边缘上,稍高于和稍低于其边界的这些状态条件。边值分析是对等价类划分的有效补充。

  (2)  结构测试

  结构测试是根据被测程序的内部结构设计测试用例的一类测试,又称为白盒测试。白盒测试也称结构测试或逻辑驱动测试,它是知道产品内部工作过程, 可通过测试来检测产品内部动作是否按照规格说明书的规定正常进行,按照程序内部的结构测试程序,检验程序中的每条通路是否都有能按预定要求正确工作,而不 顾它的功能。其主要方法有逻辑驱动、基路测试等,主要用于软件验证。白盒法全面了解程序内部逻辑结构、对所有逻辑路径进行测试。白盒法是穷举路径测试。在 使用这一方案时,测试者必须检查程序的内部结构,从检查程序的逻辑着手,得出测试数据。贯穿程序的独立路径数是天文数字。但即使每条路径都测试了仍然可能 有错误。第一,穷举路径测试决不能查出程序违反了设计规范,即程序本身错误的程序。第二,穷举路径测试不可能查出程序中因遗漏路径而出错。第三,穷举路径 测试可能发现不了一些与数据相关的错误。

  与功能测试不同的是,结构测试涉及程序内部结构。尽管用户更倾向于基于程序规格说明的功能测试,但是结构测试能发现潜在的逻辑错误,而这种错误往往是功能测试发现不了的。它们各有利弊,常常结合使用。

  第三部分  测试策略文档范例

  ●  测试目的:

  (1) 测试的范围,哪些功能要包括在内,哪些要排除在外

  (2) 谁是客户和最终用户,谁就是测试结果的验收者

  (3) 测试的次序和日程安排

  (4) 验收的条件,成功因素,限制

  ●  资源需求:

  (1) 制定计划和运行测试需要哪些技术和经验

  (2) 相关人员的角色和责任

  (3) 谁将对测试工作进行全盘协调

  (4) 谁负责测试资料管理,版本控制,错误跟踪

  ●  测试环境:

  (1) 用于测试的系统配置怎样

  (2) 需要什么自动化工具

  (3) 需要哪些测试数据(数据库和输入交易),如何安装

  (4) 您如何前调系统时钟

  ●  测试过程:

  (1) 运行测试时要遵循哪些过程(设置、执行、记录)

  (2) 测试案例如何制定,其标准格式是什么

  (3) 测试案例定义的覆盖要求是什么

  (4) 遇到问题如何决定其严重程度,对问题如何处理


分享到:
评论

相关推荐

    软件测试策略模板.docx

    软件测试策略模板.docx软件测试策略模板.docx软件测试策略模板.docx软件测试策略模板.docx软件测试策略模板.docx软件测试策略模板.docx软件测试策略模板.docx软件测试策略模板.docx

    软件测试策略,软件测试策略培训文档

    软件测试,软件测试策略,软件测试策略培训文档 

    软件测试策略.ppt

    软件测试的复杂性分析 软件测试基本技术 软件测试策略

    软件测试策略与过程

    对于测试人员有用,软件测试的复杂性分析 2.2 软件测试策略定义 2.3 软件测试分类与方法 2.4 软件测试过程及模型 2.5 单元测试与集成测试 2.6 确认、系统与验收测试

    软件测试里理论之软件测试策略ppt

    这个一个适合于初学者 的软件的软件测试策略的课件 很经典的

    软件测试策略与过程.ppt

    2.1 软件测试的复杂性分析 2.2 软件测试方法与策略 2.3 单元测试 2.4 集成测试 2.5 确认测试 2.6 系统测试 2.7 验收测试 2.8 测试后的调试 2.9 面向对象的软件测试

    论文研究-基于黑盒测试的软件测试策略研究与实践.pdf

    在软件测试的系统测试、验收测试等测试阶段中,传统的黑盒测试基本方法主要应用在细节测试方法中,但它不能给面向宏观的测试策略的设计提供有效的指导作用。为了弥补这方面的不足,从测试用例分布、测试角度确定和...

    软件系统测试策略模板

    测试策略描述测试工程的总体方法和目标。描述目前在进行哪一阶段的测试(单元测试、集成测试、系统测试)以及每个阶段内在进行的测试种类(功能测试、性能测试、覆盖测试等)

    嵌入式软件测试策略

    详细介绍了嵌入式编程中的各种测试策略。

    软件测试方法和技术(又名全程软件测试,电子版,朱少民著)

    本书以两个典型项目为背景,按实际项目进行的...最后,本书呈现了软件测试成熟度模型和对软件测试的总结和思考,帮助读者了解软件测试所面对的现实问题和应恪守的原则、领会测试方法的应用之道和品味测试的最佳实践。

    软件测试之魂:核心测试设计精解

    《软件测试之魂:核心测试设计精解(第2版)》以测试设计为主线,首先介绍了软件测试行业过去十多年的发展变化——如今,软件测试日益受到世界重视,已展现了朝阳行业的端倪。如何把握测试技术,把测试工作做得精透...

    软件测试策略

    介绍软件测试的理论资料

    软件测试课件-软件测试技术和方法

    第3章 质量保证与测试策略 第4章 软件测试依据和规范 第二篇 软件测试的技术 第5章 单元测试 第6章 集成测试和系统测试 第7章 验收测试 第8章 面向对象软件的测试 第9章 应用服务器的测试 第10章 软件本地化测试 ...

    浅谈手机软件测试的流程与策略

    浅谈手机软件测试的流程与策略

    《软件测试方法和技术》电子课件之四

    前 言 &lt;br&gt;第一篇 软件测试的原理 第1章 软件及其开发过程 第2章 软件测试的基本概念和方法 第3章 质量保证与测试策略 第4章 软件测试依据和规范 &lt;br&gt;第二篇 软件测试的技术 第5...

    软件测试大作业 软件测试的例子

    软件测试作业 软件测试的一个例子

    软件测试策略与过程 单元测试集成测试等

    第2章 软件测试策略与过程 2.1 软件测试的复杂性分析 2.2 软件测试方法与策略 2.3 单元测试 2.4 集成测试 2.5 确认测试 2.6 系统测试 2.7 验收测试 2.8 测试后的调试 2.9 面向对象的软件测试

    软件测试方法和技术(朱少民).rar

    15 -16 第17章 软件测试项目管理 17.1软件测试项目管理的概述 17.2 软件测试项目的组织 17.3软件测试项目的过程管理 17.4软件测试项目的资源管理 17.5 测试项目的进度管理 17.6 测试项目的风险管理 17.7 测试项目的...

Global site tag (gtag.js) - Google Analytics