软件测试过程改进模型入门介绍

上传人:博****1 文档编号:544646038 上传时间:2022-12-05 格式:DOCX 页数:14 大小:35.43KB
返回 下载 相关 举报
软件测试过程改进模型入门介绍_第1页
第1页 / 共14页
软件测试过程改进模型入门介绍_第2页
第2页 / 共14页
软件测试过程改进模型入门介绍_第3页
第3页 / 共14页
软件测试过程改进模型入门介绍_第4页
第4页 / 共14页
软件测试过程改进模型入门介绍_第5页
第5页 / 共14页
点击查看更多>>
资源描述

《软件测试过程改进模型入门介绍》由会员分享,可在线阅读,更多相关《软件测试过程改进模型入门介绍(14页珍藏版)》请在金锄头文库上搜索。

1、软件测试过程改进模型入门介绍转自 51testing摘要:测试常被看作是一个昂贵且不可控的过程。测试花费太多的时间,耗费的比计划投入的多,无法提 供充分的关于测试过程本身的质量情况。因此,信息系统的质量和商务风险难以判断。很多组织意识到改进测试过程可以解决这些问题。但是,实际上为了改进和控制测试过程到底应该采 取什么步骤以及什么次序是困难的。基于实践知识和测试过程开发经验,测试过程改进模型(以下简称V)被开发出来。TP/提出了一个 组织内测试过程成熟度的观点。在这份文件里将介绍斤/的内容和结构。同时,测试过程改进的一些方面及面临的挑战也将做些讨论。1、概述测试常被看作是一个昂贵且不可控的过程。

2、测试花费太多的时间,耗费的比计划投入的多,无法提供充分的关于测试过程本身的质量情况。因此,信息系统的质量和商务风险难以判断。很多组织意识到改进测试过程可以解决这些问题。但是,实际上为了改进和控制测试过程到底应该采 取什么步骤以及什么次序是困难的。基于实践知识和测试过程开发经验,测试过程改进模型(以下简称TPI)被开发出来TPI提出了一个 组织内测试过程成熟度的观点。在这份文件里将介绍TPI的内容和结构。同时,测试过程改进的一些方面及面临的挑战也将做些讨论。2、软件测试的目的一个信息系统开发阶段的测试活动可以这样来加以说明:测试活动是从测试计划、测试准备到测试执行、测试分析这样一个过程,测试的目

3、标是对信息系统(泛指软件)的特性进行确认,以发现该系统应有状态与实际状态的差异。测试计划和测试准备活动用以定义测试过程何时开始。在任何测试方法应用前(即测试执行阶段前), 测试过程要求有明确的计划和准备阶段。测试可以降低系统质量的不确定度级别,但是测试效果的好坏依赖于系统发布所带来的风险,还有我们愿意花费在降低不确定度等级上的时间和资金。3、测试等级为了有效地组织测试,不同的测试等级需要加以应用。每一个测试等级对应某一组需求、功能或者技 术说明。本章内容主要基于KoP99和ISEO4。3.1低级测试低级测试陷于系统的各个组成部分的测试中,例如程序单元,单独的或者关联的。从系统开发开始, 即开始

4、单元,程序和模块的测试。如上面所述这种分离性依赖于程序下部结构和所使用的编程语言。这类 测试的执行者多数时候是开发人员。当众多的系统基本单元确认巳经符合他们的技术规格时,作为系统构成的稍大些的模块在集成测试中 进行测试。集成测试主要关注与数据流和程序间的接口部分。3.2高级测试高级测试全面、彻底的测试产品。在低级测试巳经完成并且缺陷巳得到纠正后,要进行系统测试以检 验系统是否满足了功能和技术规格说明书中定义的要求。系统测试完成后,向客户提交产品进行验收。验收测试需要模拟搭建一个产品环境。高级测试尤其应该被作为一个单独的过程来执行。过去的经验显示高级测试过程的设计远比低级测试 过程的设计更重要。

5、4、关于测试的几个问题本章指出测试中的一些常见问题以及测试过程改进的一些必要方面,本章内容基于KoP99。4.1测试的原始形式在系统进入产品阶段即将被发布前,测试工作短暂的开展一段时间,并且执行测试工作的人员是非专 业的,而是随机的,谁有空闲谁来做。这就是测试的最初形式和状态。这类测试往往在系统进入产品发布 阶段后或者近期没有发现新的缺陷即宣告终止,结果就是系统带着一些隐含的缺陷即被发布,导致在后续 的因为这些缺陷而引发的软件重做、重测上付出高昂的代价。4.2当前情势现在,在很多单位或者组织中间对于一个可管理的测试过程的重要性巳经有了越来越多的共识。测试 在执行前应首先进行计划制定和准备工作,

6、计划和准备的内容应该建立于开发文档上。组织内应该清楚地 知道哪些测试过,哪些未被测试过。但是,不管怎样,测试始终面要面对时间短、人员少、资源短缺以及 技术支持度低等现状。测试处在开发周期的末端,并且往往陷入一个反复开发、反复测试的无休止的死循 环中。即便测试停止之后,对于系统的质量等级依然是一个不确定的答案。4.3最新发展要想能够面对当前市场的激烈竞争,组织必须要缩短新产品投向市场的时间。尽管开发过程正在不断 加快,但是在开发过程的任何一环节都有可能引入的错误却没有丝毫迹象显示正在减少。相关经验的缺乏 和不断上升的技术复杂度佐证了上述现象是正常的。即使现在的测试过程对于当前情势来说看起来是相当

7、 令人满意的,但是有一点很明显这不是软件测试的未来模式。5、改进测试过程5.1测试过程改进的必要性前一章提及的那些问题的产生原因可以归结于不可控的或者准备不足的测试过程。消除这些原因就是 测试过程改进的原动力。参考Koomen和Pol关于测试过程改进的论述,TPI可以定义如下:从信息服务整体出发,统筹与优化测试过程的质量、成本和周期的过程。这里的质量是指测试过程关于被测对象质量方面的度量程度,即测试质量,系统或者程序等具体测试 对象的质量不在此范畴。当然,一个质量上改良的测试过程并不能给被测系统带来更好的质量。测试本身不会提高系统的质量。 事实上,它能做到的是确认系统巳具有的质量特征,并试图通

8、过所提供的这些质量信息驱使组织去改善产 品质量。在整个信息服务来看,测试过程并不是孤立的。低成本、高效率的追求,不是测试的本质目的,测试 应该为信息服务更高的效能(信息服务的整体水平)做出更多贡献。测试过程改进的一个目标应该是尽可能多地发现缺陷、降低改正成本、更早的报告系统质量情况。所 有的评测标准要谨慎地相互兼容,以此取得一个能够尽可能早的发现更过重要缺陷的总体策略。测试要朝着更加专业化的方向发展,提高专业测试技能,职能分工细化,如测试管理、测试技术专家、 测试工程师。整个测试过程的进步和质量可以被度量,其度量结果在将来可以作为测试过程改进的输入项 加以利用。5.2测试过程改进步骤改进测试过

9、程类似于任何其他过程的改进。测试过程的改进,通常遵循以下步骤:1. 确定目标和需要考虑的域。要确定测试的质量特性:是使测试速度更快、费用更低还是覆盖率更高? 什么样的测试过程最需要改进,改进过程需要持续多长时间,具有什么效果?2. 确定当前的条件。评估当前情势的优缺点。3. 确定需要的条件。基于对当前条件的分析结果和改进目标,确定需要的条件和行动步骤。4. 实施改革。根据预先拟制的改进计划,按照建议的改进操作步骤实施改革,同时跟踪改进信息,填 写条件检查项,用以验证是否达到了改进目标。5. 通过一个参照系,使测试过程的优缺点呈现出来。这个参照系可以是测试方法论或者是一个测试过 程改进模型。依照

10、Koomen和Pol的通用软件过程改进模型(如SPICE和CMM),它为测试过程的逐步改进提供 了一个不是很充分的参照体系。因为是个更高层次的抽象,在这个参照体系中测试过程的改进往往是作为 一个步骤来处理。当然,有些专门针对测试过程改进而设计的模型,如测试能力度量模型,测试改进模型以及测试度量 模型等,这些模型都不包含足够的可应用的改进步骤、详细的描述和使用说明。6. TPI模型6.1 TPI模型综述测试过程改进模型必须从多个视角观测测试过程,例如测试工具的使用,测试技术以及报告。在TPI 模型中,这些观测点叫作关键域。每一个关键域可以归类到成熟度中。对于整个测试过程的效能来说,并 不是所有的

11、关键域都是同等的,在不同的关键域和等级之间存在着一些关系。确认在各个层级上的归类是客观的,在每个层级上设置一个或多个检查点。一个检查点是一个需求。 如果一个测试过程符合某个层级的所有检查点,那么这个过程就属于这个层级。除了评估测试过程的当前情势外,关键域和层级同样可以用于定义需要的条件和为达到这些条件而需 要实施的中间步骤。在这个模型中附有改进建议,给出了如何达到某一特定水平的说明和建议。6.2 TMap 模型TMap,组织测试的方法体系以及第5.2章中所提到的模型的其他方面构成TPI模型的基础。TMap方 法体系包括4个环节,这四个环节组成开发周期中所有测试活动的一个生命周期,好的组织体系,

12、正确的 测试框架和测试工具以及为执行测试活动可用的技术。这些环节是通用的,并且在每一个测试过程中必须给予每一个环节一定的关注度。要有一个和谐的测 试过程,则这些环节上的测试开发应该要保持和谐。6.3关键域和等级通过查看一个结构化测试过程的每一环节的不同方面,总计20个关键域在TPI模型中得到公认。通过测试过程中关键域的应用来判断过程的成熟度。但是无论如何,每一个关键域在使用期间不会是 均等的彻底的,因为每个测试过程有它自己的优势和弱势。为了能够更深入的观察这些关键域的状态,模型给每个关键域设置了一个上升的等级(通常为从A到 D)。一般地说,每个关键域有3至4级。每个高一点的等级在效率、成本和(

13、或)质量方面要优于它前 面的层级。每个层级由适用于这个关键域的一定的需求组成。这些一定层级的要求(即检查点)同样包含 低层的需求:一个B级的测试过程应该同时完全满足A级和B级的要求。如果一个B级的测试过程不能 够满足A级的要求,那么它应该被视作在低一级的层级上或者是针对那个特别的关键域尚未定义的层级上。Level KeyareaCornerstone关键域层级里程碑ABCDTest strategy L 测试策略Strategyfor singlehigh-leveltest针对单一的高级测试的策略Combined strategy for high-level tests针对高级测 试的组合

14、策 略Combined strategy for high-level testsandlow-level testsorevaluation 针对高级测 试、低级测试 和评价的组Combined strategy for all test and evaluation levels 针对所有层 次的测试和 评价的组合 策略不同层级的关键域的描述详见表1。表1中关键域的不同级别中都包含里程碑,例如,测试过程每周 报一次,周报包含发现的缺陷和花费的小时数的概述。因为缺陷没有指出优先级,测试进度也未在报告中 提及,合策略Life-cyclemodel L生命周期模型Planning, Specif

15、ica-t ion, Execution 计划、方案、执行Planning,Preparation,Specificati on, Execu-tion, Completion 计划、准备、 方案、执行、 完成Moment of involvement L 参与时机Completion ofsis test 完成主要部 分测试Startoftest basis 从主要部分 测试开始Startofrequirement s definition 从需求定义 开始Project initiation 项目启动Estimating and planning T 评估和计划Substantiat ed estimating and planning 评估和计划 的案例Statistical ly substanti-a ted estimating and planning 可统计的评 估和计划的 案例Test specificati on techniquesInformal techniques 不正式的技 术Formal techniques 正式的技术T测试设计技术Static test techniques T静态测

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 学术论文 > 其它学术论文

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号