Bug“指挥棒”
一个优秀软件产品的成功,除了其先进的技术含量之外,产品开发过程的有序和有效科学的管理也是另一个不可或缺的重要因素。微软的产品开发基本上遵循一个完整的开发周期,其间包括规划阶段、开发阶段、测试阶段(也叫稳定化阶段)和产品发送/出品四个阶段。
在软件开发过程中,开发人员的作用不言而喻,其实,真正保证软件项目高质量地如期完成的不仅有开发人员,而且还有测试人员。在一切都不确定的软件开发过程中,测试人员的“Bug指挥棒”来让大家什么时候知道该表现,什么时候知道该退后一点,正是微软将软件开发过程带向高潮的不二法则!
测试组与开发组并驾齐驱
对于一个具体的软件产品的开发过程来说,测试与软件成本的关系是,发现产品中存在的问题越早,开发费用越低,产品质量越高,软件发布后维护费用越低。
具体来说,测试的具体任务包括五个方面:首先,试图在产品开发过程中找出所有的BUG;其次,系统、深入、广泛的测试以保证质量;第三,既测代码,也测设计;第四,关心产品的规格、进度、资源以及产品开发后期的任何变化;最后,负责最终的发布认可。
在开发过程中,开发人员很可能会偶尔偏离了事实的需要,暂时忘记了什么才是产品最该有的功能,把他们拉回原定轨道的正是测试工程师。测试人员的职责是配合整个项目组,保证按照预定的时间表完成预定设计目标;独立地完成测试任务;定期给出测试报告,包括BUG趋势、测试的覆盖面等等。测试人员的工作是一项具有整体性、持续性的软件开发活动中的一环,它是产品质量的重要保证。
软件测试的阶段性
在微软产品开发的规划阶段,测试人员应当研究规格说明,编写测试计划;在开发阶段,测试人员则开始设计测试用例,开发自动测试工具和程序,熟悉必需的环境、工具、软件和硬件,不断地丰富测试用例,直到达到CC(代码完成)里程碑。此时的软件可以进行一个整体测试,用户界面虽不完美但能工作,还可能有很多明显的BUG。
进入开发周期的第三阶段,测试人员大显身手,展开大规模的测试,如系统级整体测试,交互性和深层测试,这个事后的测试人员应当对新增的功能说“不”,直到达到Bata测试里程碑,达到这个里程碑,意味者所有的Beta致命问题已经被修正和关闭,所有计划的功能都已经在软件中并能工作,产品稳定,可以供用户试用,大部分界面还可以,尽管可能只是一部分,但已经有了在线帮助,可能还有用户手册,即使是发布了也不会引起负面的影响。
秘密武器:测试用例和测试计划 总之,微软测试的精髓是:基于产品规划、产品设计规格的测试计划;系统可重用的测试用例;以问题(BUG)发现和跟踪为核心的测试活动;独立的测试人员;与整个项目配合的基于里程碑的软件测试周期。而基于产品规划、产品设计规格的测试计划和系统可重用的测试用例则是微软的“秘密武器”。
在微软,测试计划是帮助测试人员管理测试项目和发现BUG的重要工具,是纲领性文件。测试计划明确了项目的测试任务、测试内容清单,这些内容不能只存在于测试人员的脑海里,而必须被项目经理、开发经理所了解,测试计划必须增强测试任务和测试实施过程的沟通,具有指导性。测试计划还必须提供组织管理测试项目的框架结构,帮助控制进度。测试计划涉及的范围应当有产品概述、测试策略、测试的方法学、测试区域、测试的配置(软件环境、硬件环境、网络环境)、测试周期(与项目的里程碑配合)、测试资源的规划、风险分析和案例等。