本章有六个小节,仔细学完后,觉得测试是本章的重点内容,是考试的重点,例如:白盒黑盒测试,测试的类型等。具体笔记如下:
1. 软件测试概念与方法1.1. 软件测试概述
软件测试是在将软件交付给客户之前所必须完成的重要步骤。目前,软件的正确性证明尚未得到根本的解决,软件测试仍是发现软件错误(缺陷)的主要手段。软件测试的目的是验证软件是否满足软件开发合同或项目开发计划、系统/子系统设计文档、SRS、软件设计说明和软件产品说明等规定的软件质量要求。通过测试,发现软件缺陷,为软件产品的质量测量和评价提供依据。
1.1.1. 测试自动化
自动化测试通常需要构建存放程序软件包和测试软件包的文件服务器、存储测试用例和测试结果的数据库服务器、执行测试的运行环境、控制服务器、Web服务器和客户端程序。自动化测试的主要实现方法包括代码的静态与动态分析、测试过程的捕获与回放、测试脚本技术、虚拟用户技术和测试管理技术等。
自动化测试具有如下优点:
(1)提高测试执行的速度
(2)提高工作效率
(3)保证测试结果的准确性
(4)连续运行测试脚本
(5)模拟现实环境下受约束的情况
自动化测试工具:
(1)单元测试工具
(2)负载和性能测试工具
(3)GUI功能测试工具
(4)基于Web应用的测试工具
1.1.2. 软件调试
软件调试(排错)与成功的测试形影相随。测试成功的标志是发现了错误,根据错误迹象确定错误的原因和准确位置,并加以改正,主要依靠软件调试技术。
软件调试方法:
软件调试与软件测试的区别:
(1)测试的目的是找出存在的错误,而调试的目的是定位错误并修改程序以修正错误。
(2)调试是测试之后的活动测试和调试在目标、方法和思路上都有所不同。
(3)测试从一个已知的条件开始,使用预先定义的过程,有预知的结果;调试从一个未知的条件开始,结束的过程不可预计。
(4)测试过程可以事先设计,进度可以事先确定;调试不能描述过程或持续时间。
1.2. 软件测试方法1.2.1. 静态测试(纯人工)
(1)桌前检查
(2)代码审查
(3)代码走查
(4)静态分析
1.2.2. 动态测试(机器运行)
(1)白盒测试
白盒测试也称为结构测试,主要用于软件单元测试阶段。它的主要思想是,将程序看作是一个透明的白盒,测试人员完全清楚程序的结构和处理算法,按照程序内部逻辑结构设计测试用例,检测程序中的主要执行通路是否都能按预定要求正确工作。
白盒测试方法主要有:
(2)黑盒测试
黑盒测试也称为功能测试,主要用于集成测试、确认测试和系统测试阶段。黑盒测试将软件看作是一个不透明的黑盒,完全不考虑(或不了解)程序的内部结构和处理算法,而只检查软件功能是否能按照SRS的要求正常使用,软件是否能适当地接收输入数据并产生正确的输出信息,软件运行过程中能否保持外部信息(例如,文件和数据库等)的完整性等。
黑盒测试根据SRS所规定的功能来设计测试用例,一般包括:
黑白盒测试的常用的方法如下图所示:
1.2.3. 测试的阶段
(1)测试的阶段如下图所示:
(2)系统测试活动和步骤如下:
(3)狭义性能测试分类如下:
负载测试:确定在各种工作负载下系统的性能,目标是测试当负载逐渐增加时,系统各项性能指标的变化情况。
压力测试:通过确定一个系统的瓶颈或不能接受的性能点,来获得系统能提供的最大服务级别的测试。
强度测试:在系统资源特别低的情况下考查软件系统运行情况。
并发测试:并发测试也称为容量测试,主要用来确定系统可处理的同时在线的最大用户数。
(4)V模型测试过程
V模型的测试过程如下图所示:
1.2.4. 面向对象系统的测试
面向对象系统的测试包括以下方面内容:
1.3. 软件的评审
软件评审需注意的内容如下:
1.4. 软件的过程改进(CMMI)
软件阶段式的组织能力成熟度和连续式软件过程能力如下图所示:
2. 系统运行与评价2.1. 遗留系统演化策略2.1.1. 评价结果分析
遗留系统按照技术水平和业务价值的高低可分为如下情况:
2.1.2. 演化策略
(1)淘汰策略
遗留系统的技术含量较低且具有较低的业务价值。对遗留系统的完全淘汰是企业资源的根本浪费系统分析师应该善于“变废为宝”通过对遗留系统功能的理解和借鉴,可以帮助新系统的设计降低新系统开发的风险。
(2)继承策略
遗留系统的技术合量较低,已经满足企业运作的功能或性能要求,但具有较高的商业价值目前企业的业务尚紧密依赖该系统。对这种遗留系统的演化策略为继承。在开发新系统时,需要完全兼容遗留系统的功能模型和数据模型。为了保证业务的连续性,新老系统必须并行运行一段时间,再逐渐切换到新系统上运行。
(3)改造策略
遗留系统具有较高的业务价值基本上能够满足企业业务运作和决策支持的需要。这种系统可能建成的时间还很短,对这种遗留系统的演化策略为改造。改造包括系统功能的增强和数据模型的改造两个方面。系统功能的增强是指在原有系统的基础上增加新的应用要求,对遗留系统本身不做改变;数据模型的改造是指将遗留系统的旧的数据模型向新的数据模型的转化。
(4)集成策略
遗留系统的技术含量较高但其业务价值较低可能只完成某个部门(或子公司)的业务管理。这种系统在各自的局部领域里工作良好,但对于整个企业来说,存在多个这样的系统,不同的系统基于不同的平台、不同的数据模型,形成了一个个信息孤岛,对这种遗留系统的演化策略为集成。
2.2. 新旧系统的转换策略
新旧系统的转换策略通常有三种:直接策略、并行策略和分段转换策略,如下图所示。
2.3. 数据的转换与迁移
数据转换和迁移是新旧系统转换交接的主要工作之一。为使数据能平滑迁移到新系统中,在新系统设计阶段就要尽量保留现有系统中合理的数据结构,这样才能尽可能降低数据迁移的工作量和难度。数据转换和迁移过程如下图所示:
2.4. 系统运行与维护
系统维护就是在系统运行过程中,为了改正错误或满足新的需求而修改系统的活动,包括软件维护(程序维护)、数据维护、代码维护、设备维护,以及机构和人员的变动等。
软件维护是生命周期的一个完整部分。可以将软件维护定义为需要提供软件支持的全部活动,这些活动包括在交付前完成的活动,以及交付后完成的活动。交付前完成的活动包括交付后运行的计划和维护计划等二交付后的活动包括软件修改、培训、帮助资料等。其可维护性和维护类型如下图所示:
软件维护的分类(4种):