软件缺陷生命周期.doc

上传人:F****n 文档编号:105278861 上传时间:2019-10-11 格式:DOC 页数:9 大小:131KB
返回 下载 相关 举报
软件缺陷生命周期.doc_第1页
第1页 / 共9页
软件缺陷生命周期.doc_第2页
第2页 / 共9页
软件缺陷生命周期.doc_第3页
第3页 / 共9页
软件缺陷生命周期.doc_第4页
第4页 / 共9页
软件缺陷生命周期.doc_第5页
第5页 / 共9页
点击查看更多>>
资源描述

《软件缺陷生命周期.doc》由会员分享,可在线阅读,更多相关《软件缺陷生命周期.doc(9页珍藏版)》请在金锄头文库上搜索。

1、缺陷生命周期(K3)根据IEEE Std 10441993定义的异常管理生命周期进行缺陷管理。(K3)根据IEEE Std 10441993评估缺陷报告和缺陷分类以改进缺陷报告的质量。和软件开发生命周期一样,缺陷也是由一系列的阶段和活动组成的,即缺陷同样具有生命周期。如图1所示,根据IEEE Std 10441993 中的描述,缺陷生命周期主要由四个阶段组成:识别(Recognition)、调查(Investigation)、改正(Action)、总结(Disposition)。图1 缺陷分类过程对于缺陷生命周期的每个阶段,都包括记录(Recording)、分类(Classifying)和确定

2、影响(Identifying Impact)三个活动。缺陷生命周期的四个阶段看起来是按照顺序进行的,但是缺陷可能会在这几个阶段中进行多次迭代。下面对缺陷生命周期的每个阶段和阶段中的活动进行详细的讨论。1、识别缺陷的识别是整个缺陷生命周期的第一个阶段,它可以发生在软件开发生命周期的任何一个阶段。缺陷的识别可以由参与项目的任何利益相关者完成,例如:系统人员、开发人员、测试人员、支持人员、用户等。缺陷识别阶段的主要活动包括:记录:在缺陷识别阶段,需要记录缺陷的相关信息,包括发现缺陷时的支持数据信息和环境配置信息,例如:被测系统的硬件信息、软件信息、数据库信息和平台信息等。分类:在缺陷识别阶段,需要对

3、缺陷相关的一些重要属性进行分类,主要包括发现缺陷时执行的项目活动(如表1所示)、引起缺陷的原因、缺陷是否可以重现、缺陷发现时的系统状态、缺陷发生时的征兆等。确定影响:根据缺陷发现者的经验和预期,判断缺陷可能会造成的影响,例如:缺陷的严重程度(如表2所示)、优先级,以及缺陷对成本、进度、风险、可靠性、质量等的影响。表1 发现缺陷时的项目活动分类类 别符合度要求代 号分 类项目活动RR100强制性RR110分析强制性RR120评审强制性RR130审计强制性RR140审查强制性RR150编码/编译/汇编强制性RR160测试强制性RR170确认测试/鉴定测试强制性RR180支持/操作强制性RR190走

4、查表2 严重程度分类类 别符合度要求代 号分 类严重程度IM100强制性IM110危急强制性IM120高强制性IM130中强制性IM140低强制性IM150无2、调查经过缺陷识别阶段后,需要对每个可能的缺陷进行调查。调查阶段主要是用来发现可能存在的其他问题以及相关的解决方案,解决方案包括不采取任何行动。缺陷调查阶段的主要活动包括:记录:在缺陷调查阶段,需要记录相关的数据和信息,对缺陷识别阶段记录的信息进行更新。缺陷调查阶段记录的信息包括缺陷调查者的信息、缺陷调查的计划开始时间、计划结束时间、实际开始时间、实际结束时间、调查工作量等。分类:在缺陷调查阶段,需要进行分类的属性包括缺陷引起的实际原因

5、、缺陷的来源、缺陷的具体类型等。同时,对缺陷识别阶段中的分类信息,根据需要进行检查和更新。确定影响:根据缺陷调查阶段的分析结果,对缺陷识别阶段的影响分析进行更新。表3列举了调查阶段的支持数据。表3 调查阶段的支持数据表格接收确认验证接收日期缺陷的来源指定的报告号缺陷识别过程的数据调查员 姓名 代号或职能范围 电子邮件地址 电话号码 计划的调查开始日期 计划的调查结束日期 实际的调查开始日期 实际的调查结束日期 工时 接收确认的日期 调查使用的资料 名称 ID 版本 3、改正根据缺陷调查阶段中得到的结果和信息,就可以采取改正措施解决引起缺陷的错误。采取的行动可能是修复缺陷,也可能是针对开发过程和

6、测试过程的改进建议,以避免在将来的项目中重复出现相似的缺陷。针对每个缺陷的修复,需要进行相关的回归测试和再测试,避免由于缺陷的修复而影响原有的功能。缺陷改正阶段的主要活动包括:记录:在缺陷改正阶段,需要记录改正缺陷的相关支持数据信息,包括需要修改的条目、需要修改的模块、修改的描述、修改的负责人、计划修改开始的时间、计划修改完成的时间等。分类:当合适的修改计划或者活动确定以后,需要对下面的信息进行分类:缺陷修复的优先级(例如:是马上修改、延期修改还是不修改)、缺陷的解决方法(如表4所示)、缺陷修复的改正措施等。确定影响:对在缺陷识别阶段、缺陷调查阶段中得到的影响分析进行合适的检查,并在需要的时候

7、进行更新。表4 缺陷改正的分类表-解决方法4、总结经过了上面的几个阶段后,缺陷生命周期就到了缺陷的总结阶段。总结阶段的主要活动包括:记录:在缺陷总结阶段,需要对一些支持数据信息进行记录,例如:缺陷关闭时间、文档更新完成时间等。分类:针对缺陷进行确认测试和相关的回归测试以后,就可以将缺陷的状态进行分类,例如:关闭状态、延迟状态或者合并到其他项目中去等。确定影响:对在缺陷识别阶段、缺陷调查阶段和缺陷改正阶段中得到的影响分析进行合适的检查,并在需要的时候进行更新。表5列出了缺陷总结阶段的分类数据。表5 缺陷总结阶段的分类表类 别符合度要求代 号分 类缺陷总结DP100强制性DP110已关闭DP111

8、 已完成缺陷改正DP112 不是错误DP113 不属于项目范围(不能解决)DP114 外部供应商问题DP115 重复问题DP120延期改正DP130与其他缺陷合并DP140划归其他项目5、案例本节介绍一个根据IEEE Std 10441993制定的缺陷生命周期案例,如图2所示。图2 缺陷状态转换图图2是某项目的缺陷生命周期中的缺陷状态转换图。下面分别从角色、状态、严重程度和优先级四个方面阐述该项目使用的缺陷生命周期。(1)相关角色测试人员:主要是指发现和报告缺陷的测试人员。通常情况下,测试人员需要对该缺陷后续相关的状态负责,包括回答相关人员对这个缺陷信息的询问,以及在正式版本上进行再测试和回归

9、测试。开发人员:主要指对缺陷进行调查和修复的开发人员。注意在提交测试人员正式再测试之前,需要对修改后的缺陷在开发环境上进行验证。缺陷评审委员会:主要由项目经理、测试经理、质量经理、开发经理以及资深的开发人员、测试人员等组成。他们对缺陷进行确认,并将其分配给相应的开发人员进行修复,同时对有争议的缺陷进行仲裁。版本经理:负责将已经解决的缺陷相关的配置信息合并到新的版本。(2)缺陷状态新缺陷(New):软件中新发现的缺陷通常由测试人员提交。当然也可能是开发人员自己在组件测试或代码走读过程中提交,还有可能是从软件使用的最终用户或使用现场反馈得到的缺陷报告。具体缺陷发现的阶段包括:需求和设计阶段:文档评

10、审过程中发现的缺陷。编码阶段:代码评审和代码静态分析过程中发现的缺陷。测试阶段:动态测试过程中发现的缺陷。使用阶段:用户反馈的缺陷。接受(Accepted):相关人员提交的缺陷报告,需要经过缺陷评审委员会的评审。缺陷评审通过后,将缺陷状态置为接受。缺陷评审委员会评审的主要内容包括:报告中描述的问题是否确实是一个缺陷。提交的缺陷报告是否符合要求。分配(Assign):将缺陷状态为接受的缺陷分配给相关人员进行问题定位和修复。相应的缺陷状态被置为分配。打开(Open):当缺陷处于打开状态时,说明开发人员已经开始对该缺陷进行修复。交付(Deliver):解决缺陷的方法已经找到,并且已经将修改后的代码等

11、打上标签,交付给版本经理。解决(Resolved):版本经理将相关的标签等合入某个版本,交付给相关的开发小组进行验证,测试通过,则缺陷状态置为解决。已修改(Fixed):版本经理将已经解决的缺陷标签合入某个版本,交付给相关的测试小组进行确认测试,测试通过,则缺陷状态为已修改。结束(Closed):缺陷状态处于已修改后,缺陷评审委员会对整个缺陷修复过程进行评审,评审通过后将缺陷状态修改为结束状态。上面介绍的缺陷状态是在缺陷管理过程中主要的状态,或者是在缺陷处理顺利时所经历的状态。实际上,缺陷还有一些其他的状态,分别是:研究(Investigate):当缺陷分配给开发人员时,开发人员并不是都能直接

12、找到相关的解决方案。开发人员需要对缺陷和引起缺陷的原因进行调查研究,这时候可以将缺陷状态改为研究状态。询问和回答(Query&Reply):假如负责缺陷修复的人员认为缺陷描述的信息不够明确,或希望得到更多与缺陷相关的配置和环境条件等,可以将缺陷状态改为询问和回答。拒绝(Declined):缺陷评审委员会通过讨论研究,认为提交的问题不是缺陷;或通过开发人员的研究分析,认为不是缺陷,开发人员可以将具体的理由加入到缺陷描述中,缺陷评审委员会据此将缺陷状态修改为拒绝。重复(Duplicated):缺陷评审委员会认为该缺陷和某个已经提交的缺陷描述的是同一个问题,可以将该缺陷状态设置为重复。延期(Defe

13、rred):缺陷不在当前版本解决。无计划(Unplanned):在用户需求中没有要求或计划。(3)严重程度缺陷的严重程度指的是假如缺陷没有修复时,软件缺陷对软件质量的破坏程度,即此软件缺陷的存在对软件功能特性和非功能特性产生的影响。缺陷的严重程度关注的是缺陷引发的问题对客户的影响程度。在给缺陷确定严重程度的时候,应该从软件最终用户的角度进行判断,即根据缺陷会对用户使用造成的影响程度来确定。软件缺陷的严重程度和缺陷发生的可能性没有直接的关系。一般而言,缺陷的影响越大,缺陷的严重程度越高。下面是该项目的缺陷严重程度的分类,缺陷的严重程度被分为四个等级。严重程度1(致命的):产品在正常的运行环境下无

14、法给用户提供服务,并且没有其他的工作方式可以补救;或者软件失效会造成人身伤害或危及人身安全,例如:问题会自发地影响系统的数据传输。用户使用正常的操作步骤就会影响系统提供的服务。软件的操作系统崩溃,造成数据丢失。无法提供系统的主要功能。可能会造成人身伤害。严重程度2(严重的):极大地影响系统提供给用户的服务,或者严重影响系统要求或者基本功能的实现,例如:系统中的一些硬件单板会自动重启,但没有影响它们所提供的传输性能。用户使用正常的命令会导致系统重启或挂起,但不影响系统的数据传输。软件的某个子菜单不起作用,或者会产生错误的结果。严重程度3(一般的):系统功能需要增强或存在缺陷,但有相应的补救方法解决这个缺陷,例如:系统的一块硬件单板失效了,但系统没有上报相应的告警。功能特征设计不符合系统的需求,不影响系统的业务,并且有相应的补救方法。本地化软件的某些字符没有翻译或者翻译错误。严重程度4(轻微的):细小的问题,不需要补救方法或对功能进行增强;或者操作不方便,容易使用户误操作,例如:上报的信息不符合系统的需求,描述不精确或可能对用户有些

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 办公文档 > 事务文书

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