通常大家发现软件缺陷时会对软件缺陷进行分类,可分类的方式只有一种,就是严重极别,难道没有其它的分法吗。比如我们碰到下面这种情况,测试人员发现有一种功能是必需加入进去的,这时他与程序员说,程序员说没有时间或是不必要,这时这种情况则会形成两者的扯皮,最终的结果也就不了了知了,这样会戳伤了测试人员的积极性,下次他们再也不会尽心的考虑产品的问题,只要可以运行就可以了。其实这种情况是可以解决的,下面我会提到一个新的软件缺陷分类概念,从而有效的解决这个问题。
在软件缺陷中不仅仅只是严重极别,更多的则是功能没有做到。说到这里也许大家都理解了,就是需求没有考虑到,可需求不会一次就很完美的,需要大家的共同努力,来不断的完善。那么怎样才能让测试人员提出的好的建议得到有效的执行?这就是我下面想说的。在软件缺陷中还有一种分法,跟据缺陷内容来分,主要分为需求Bug与程序Bug,对于这种分法的好处就是明确了Bug处理的责任人。对于程序Bug我们都知道是由相关开发人员进行处理。下面主要讨论一下需求Bug,需求Bug从名称上来就知道是要交由需求人员进行处理,可怎么处理,怎样在处理的过程中有效的让这些创意得到体现。现在我们都有Bug管理系统,这时我们的测试人员将需求Bug不是提交给程序员,而是提交给需求分析人员,由他们进行处理,不过这里我想强调的是对需求Bug的定位,如果这个Bug在软件需求说明书中明确提到了,这时就不可能定位它为需求Bug,它是必需让程序员实现的,称为软件功能缺陷,提交由程序员进行处理。但如果需求说明书没有明确提到的,我们则可以定位为需求Bug,处理的流程如图。
<?xml:namespace prefix = v ns = "urn:schemas-microsoft-com:vml" /><shapetype id="_x0000_t75" coordsize="21600,21600" o:spt="75" o:preferrelative="t" path="m@4@5l@4@11@9@11@9@5xe" filled="f" stroked="f"><stroke joinstyle="miter"></stroke><formulas><f eqn="if lineDrawn pixelLineWidth 0"></f><f eqn="sum @0 1 0"></f><f eqn="sum 0 0 @1"></f><f eqn="prod @2 1 2"></f><f eqn="prod @3 21600 pixelWidth"></f><f eqn="prod @3 21600 pixelHeight"></f><f eqn="sum @0 0 1"></f><f eqn="prod @6 1 2"></f><f eqn="prod @7 21600 pixelWidth"></f><f eqn="sum @8 21600 0"></f><f eqn="prod @7 21600 pixelHeight"></f><f eqn="sum @10 21600 0"></f></formulas><path o:extrusionok="f" gradientshapeok="t" o:connecttype="rect"></path><?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" /><lock v:ext="edit" aspectratio="t"></lock></shapetype><shape id="_x0000_i1025" style="WIDTH: 385.5pt; HEIGHT: 323.25pt" type="#_x0000_t75" o:ole="" o:bordertopcolor="this" o:borderleftcolor="this" o:borderbottomcolor="this" o:borderrightcolor="this"><font size="3"><img src="/Develop/ArticleImages/22/22352/CSDN_Dev_Image_2003-11-25158060.png" o:title=""><?xml:namespace prefix = w ns = "urn:schemas-microsoft-com:office:word" /><bordertop type="thinThickSmall" width="24"></bordertop><borderleft type="thinThickSmall" width="24"></borderleft><borderbottom type="thickThinSmall" width="24"></borderbottom><borderright type="thickThinSmall" width="24"></borderright></font></shape>
图1
这样处理有以下好处,首先需求Bug再不象以前,没有人进行确认,需求的处理人员本来就是需求人员,由他们确认与跟踪是最好不过的,因为他们对需求有绝对的权威。同时测试人员其实就是最早的用户,他们的需求就是用户的需求,这种方法加强了需求人员与测试人员的沟通,使需求得到有效的补充,从而让产品更加完善。还有测试人员从本质上来说与程序员还是对立的,这里如果为了这样一个不是软件本身问题的问题形成与开发人员的对立,则会出现赢得战役而丢失整个战争的情况,测试人员协调好与开发人员的关系,让他们更有效的对软件本身的缺陷形成有效的关注是最好的。还有最为关键的一点,测试人员的激情是最重要的,如果他们的想法没有得到体现,这时会渐渐的失去对测试的兴趣,从而软件的质量则会无法得到保证,通过这种方法可以让他们看到自己的建议可以通过对需求人员的反映得到实现,让他们时时觉得自己的想法是可以通过这种方法来有效的推行,这样工作的积极性才会有保障。
不过从实施的角度来说,还是有一定的困难的,首先要让大家改变以前那种凡是Bug就是由开发人员负责的观念,其次需求人员的工作量是要加大的,不过广泛的了解需求是他们的本份工作,想来不会很困难,还有必需要有有效的Bug管理工具,比如BugManage等等,不要出现那种对需求人员说了,可过两天就忘的情况出现,这时需求Bug的生命周期会出现跨越两个软件开发周期,因为有些需求会在下一版实现,这时测试人员需要延长对这些需求Bug的管理,不过我想这些需求是他们提出的,会有兴趣对这些Bug进行管理的。
陈卫俊
9/9/2003
分享到:
相关推荐
为了更好地管理和追踪这些缺陷,有必要建立一套统一的软件缺陷分类标准。本文档旨在为同行评审、软件测试提供一套标准化的缺陷分类体系。 #### 二、软件缺陷分类标准概述 本文档针对使用Rational Unified Process ...
为了有效地管理和追踪这些缺陷,制定一套合理的软件缺陷分类标准至关重要。本文将详细阐述软件缺陷的各类属性及其意义,帮助读者更好地理解和应用这一标准。 #### 二、软件缺陷属性详解 软件缺陷属性主要包括:缺陷...
软件缺陷管理是软件开发过程中至关重要的环节,旨在识别、记录、跟踪和修复软件产品中存在的问题,以提高软件质量和用户满意度。本文档“软件缺陷管理规范”提供了一套全面的流程,从缺陷的发现到解决,再到预防措施...
面向对象的软件缺陷管理是软件开发过程中的关键环节,它涉及到如何识别、记录、跟踪、修复和预防软件缺陷,以确保软件产品的质量和稳定性。在现代软件工程中,由于软件规模的扩大和复杂性的提升,有效的缺陷管理对于...
《软件测试缺陷管理规定》是针对软件产品全生命周期中可能出现的缺陷进行有效管理和控制的规范。这一规定旨在确保从缺陷的定义、提交、流转到解决的全过程都能有序进行,最终达到提升软件产品质量的目标。 首先,...
2. 缺陷分类与优先级:系统自动或人工对缺陷进行分类和优先级设定,便于管理和优先处理严重缺陷。 3. 缺陷跟踪:记录缺陷处理的全过程,包括状态变更、处理人、处理时间等,确保每个缺陷都能得到妥善解决。 4. ...
同时,tester 需要与项目管理者和开发人员合作,确保软件缺陷的定义和分类符合项目的需求和目标。 微软公司的缺陷流程是指在软件开发项目中,tester 对所有已知 Bug 进行有效的跟踪和管理,保证产品中出现的所有...
5. **软件缺陷管理**:此项目的核心目标是对软件缺陷进行有效管理,包括缺陷的记录、分类、优先级设定、分配给相应团队成员处理、跟踪进度以及最终关闭。一个完善的缺陷管理系统可以帮助团队更好地协调工作,提高...
缺陷管理规程的主要目的在于确保软件产品的质量,减少软件缺陷的数量和严重性,提高软件产品的可靠性和稳定性。该规程的实施将有助于提高软件开发和测试的效率,减少软件开发和测试的成本,提高软件产品的竞争力。 ...
理解和管理软件缺陷对于保证软件质量至关重要。 在软件开发生命周期中,缺陷管理通常包括缺陷的识别、记录、分类、优先级设定、跟踪修复以及验证。以下是一些关键知识点: 1. **缺陷识别**:这是发现缺陷的第一步...
3. **缺陷分类和优先级设定**:管理者或指定人员对报告的缺陷进行分类,如功能错误、性能问题、界面缺陷等,并根据业务影响和紧迫性设置优先级。 4. **缺陷分配**:将缺陷报告分配给相应的开发人员,让他们负责修复...