Testing - 测试基础 - 阶段

时间:2021-03-05 19:30:40

估算

测试对软件工作量的估算的准确性

测试评估软件系统的状况的准确性

关注点:

  • 不准确的估算
  • 不适当的开发过程
  • 不真实的状态报告

如何知道对工作量的估算是正确的

估算工作量的工具很容易出错

对软件工作量的估算需要策略

五个一般的方法

  • 推测
  • 加入一些约束条件
  • 以一些数据为基础
  • 模拟进行工作
  • 将一些参数模型化

参数模型

  • 回归模型:将现有的参数与已有的历史数据相拟和。
  • 启发式模型:对历史数据进行观察和解释
  • 现象模型:假设软件开发过程可以依据一些更广泛的可适用的过程解释。

模型遵循的共同模式

  • 估算软件的大小
  • 将大小转化成人力的估算,并且作出可能的成本的估算
  • 依据项目的特性进行估算的调整
  • 将整体的估算划分到不同的项目阶段中
  • 估算不包括技巧上面的人力和计算机的运行时间
  • 将以上内容相加

对估算进行检验

  • 检验估算模型的合理性
  • 检验模型是否包含了必须的测试要素
  • 检验模型的正确性

检验估算模型的正确性

  • 重新进行估算:输入是否正确;输入是否合理;对数据的计算是否合理有效
  • 比较延期的估算是否符合项目实际情况
  • 让谨慎的人来作测试验证工作
  • 对软件中的冗余价值估算

影响估算正确与否的因素

  • 软件规模
  • 新设计新代码的比例
  • 复杂程度
  • 设计和编码的困难
  • 使用什么语言
  • 安全性
  • 需求的挥发性
  • 组织因素:项目计划/人员/开发环境/硬件资源/人员利用率/膨胀因素
  • 估算就是估算,不是保证书

追踪测试工作的瓶颈

  • 工作完成点
  • 同配置管理系统紧密的结合
  • 如何使用:模块列表/里程碑/工作完成点
  • 用计算所有工作的完成度来检查系统工作过程。

测试计划

开发测试计划

目标:

详细的描述怎样能成功的完成测试工作,其中应包含必须的资源和实施计划。

可能的不利因素:

  • 没有得到足够的培训
  • 心里准备不足
  • 缺乏测试工具
  • 缺乏管理的标准和支持
  • 缺乏客户和最终使用者的参与
  • 没有足够的时间进行测试
  • 对于独立的测试人员过度信任
  • 版本改变的太快
  • 测试人员处于不受重视的情况中
  • 不能说不

实施过程

  • 听取各方面的意见和建议
  • 标明项目风险:测试要素/联系测试矩阵
  • 建立测试计划
  • 对计划进行评审

建立测试计划

定义测试目标

开发测试矩阵

  • 软件模型
  • 结构特性
  • 批量测试的阶段和用例
  • 为在线系统作概念上的测试脚本
  • 软件测试矩阵

    定义测试管理
  • 测试计划的一般性信息
  • 定义测试里程碑
  • 定义管理上的检查点

    书写测试计划

评审测试计划

涉及评审的问题

  • 评审测试的开始时间是否会延期
  • 有没有抵触评审的角色
  • 一段时间内是否很难得到工作的检查信息。
  • 更换工具有可能导致他们反感评审工作
  • 评审结果可能会影响对个人的工作评价

    对于最终成品的检查
  • 项目的需求规格说明书
  • 软件返工/维护的文档
  • 升级后的技术文档
  • 被更改的源程序
  • 测试计划
  • 用户手册(包括在线帮助)

    正式评审中的角色
  • 缓和剂(SQA)
  • 读者
  • 记录者
  • 作者
  • 检测员

    正式评审发现的缺陷应包含的信息
  • 起因
  • 类型
  • 分类
  • 级别

评审流程

计划和组织

通篇的讲解(可选)

个人准备

评审会议

修订和反复


需求阶段的测试

测试成本

被设计用来减少测试成本

IBM的数据:大约 60个缺陷/千行;2/3的缺陷产生在需求和设计阶段

在需求和设计阶段发现的缺陷修正的花费最小

修正系统测试阶段发现的缺陷,花费是以上的10倍

发布产品以后,修正缺陷的花费是原来的100倍

生命周期的测试概念

  • 在软件开发过程中持续的进行测试
  • 在尽可能早的阶段点去修正缺陷
  • 需要正式的开发流程来支持
  • 组建测试团队
  • 当开发开始进行的时候,测试就开始进行了

需求阶段的测试

所有的花费都是值得的

大部分缺陷将不会进入到设计&编码阶段

目标

  • 需求正确的表现出了用户的需要
  • 需求已经被定义和文档化了
  • 花费和收益成正比
  • 需求的控制被明确
  • 有合理的流程可遵循
  • 有合理的方法可供选择

    准备风险列表
  • 确定风险组
  • 确定风险(风险分析 & 风险检查表)
  • 建立控制目标
  • 确定有足够的控制力度

分析测试要素

  • 需求的设计是否遵循了已定义的方法
  • 提交了已定义的功能说明
  • 定义了系统界面
  • 已经估计了性能标准
  • 容忍度被预先估计
  • 预先定义了权限规则
  • 需求中预先定义了文件完整性
  • 预先定义了需求的变更流程
  • 预先定义了失败的影响
  • 权限定义

需求走查

  • 建立基本规则
  • 选择小组/通报参与者
  • 项目介绍
  • 问题/建议
  • 形成最终报告

设计阶段的测试

设计阶段的测试任务

  • 给测试要素打分
  • 分析测试要素
  • 对设计进行评审
  • 检查修改的部分

交付的产品

  • 输入说明
  • 过程说明
  • 文件说明
  • 输出说明
  • 控制说明
  • 系统流程图
  • 硬件和软件的需求
  • 操作手册说明书
  • 数据保留的策略

分析测试要素涉及的内容

  • 设计了对数据完整性的控制
  • 设计了权限规则
  • 设计了对文件完整性的控制
  • 设计了审计追踪
  • 设计了发生意外情况时的计划
  • 设计了如何达到服务水平的方法
  • 定义了权限流程
  • 定义了完整的方法学
  • 设计了保证需求一致性的方法
  • 进行了易用性的设计
  • 设计是可维护的
  • 设计是简单的
  • 交互界面设计完毕
  • 定义了成功的标准
  • 需要同实际操作者沟通

对设计进行评审

选择评审组成员

对评审组进行培训

通报项目组

分配足够的时间

只对文档化的事实进行评审

和项目组一起进行评审

对评审形成建议

和项目组对建议一起进行评审

准备正式的报告


编码阶段的测试

测试的职责

  • 编码是一个纯技术的工作,几乎不需要用户的参与
  • 项目领导者有参与测试的责任
  • 监督过程的有效性

形成的输出

  • 编码说明书
  • 程序文档
  • 计算机程序列表
  • 可执行的程序
  • 程序流程图
  • 操作介绍
  • 单元测试结果

关注点

  • 完成对数据完整性的控制
  • 定义完毕授权的规则
  • 完成对文件完整性的控制
  • 实现审计追踪
  • 规划出意外情况发生后的处理计划
  • 对系统如何达到预定义的服务水平做了计划
  • 完成了对安全问题的处理流程
  • 编码工作是依据规定的方法完成的
  • 编码与设计相一致(正确性)
  • 编码与设计相一致(易用性)
  • 代码是可维护的
  • 编码与设计相一致(简洁性)
  • 编码与设计相一致(耦合性)
  • 已开发了操作流程
  • 定义出程序成功的标准(性能上)

建议的测试方式

桌面调试

  • 语法上的
  • 结构上的
  • 功能上的

    代码互查
  • 建立基本的互查规则
  • 选择互查的team
  • 对成员进行培训
  • 选择互查的方法
  • 提供互查的材料
  • 流程图,源程序,典型的处理流程
  • 对互查进行必要的管理
  • 给出互查结论
  • 提供最终的报告

编码阶段测试需要解决的问题

  • 系统是可维护的吗?
  • 系统说明是否已经完成了?
  • 编码是否按照既有的标准进行,过程是否易于实践?
  • 是否有足够的测试计划用来评估可执行的程序?
  • 是否编制了足够的文档。

测试阶段

在需求,设计,编码阶段多进行一些测试,在系统测试阶段就会少一些问题。

文档

  • 测试阶段的测试计划
  • 测试用例
  • 前期测试的测试结果
  • 第三方测试反馈,例如:计算机操作人员
  • 正式的测试总结报告

测试用例的概念是简单的

建立有效的测试用例是复杂的

设计测试文件

  • 测试用例应当包含合法的和非法的输入
  • 每一个动作只进行一次关键操作

    输入测试数据

    分析结果

    尝试将测试文件违反程序的规则进行输入

典型的测试类型

  • 手册,回归,功能点测试
  • 一致性测试(授权)
  • 功能点测试(完整性)
  • 功能点测试(审计,追踪)
  • 覆盖性的测试(测试的连续性)
  • 压力测试(服务水平)
  • 一致性测试(安全性)
  • 依照预先定义的测试方法
  • 功能点测试(正确性)
  • 支持手册的测试(易用性)
  • 检查(可维护性)
  • 灾难性的测试(可携带性)
  • 功能和回归测试(耦合性)
  • 一致性的测试(性能)
  • 操作性的测试(易用性)

测试总结

测试报告

目标

  • 表示出目前项目的实际状况
  • 明确什么是测试做的工作,什么是不作的工作。
  • 给出系统的操作性能的评价
  • 明确什么时候系统可以进行产品化的工作

    关注点
  • 测试报告只有真正需要的时候才有用,需要配合市场和管理
  • 测试的信息是不充分的(对于评价一个项目来说)
  • 测试状况并不能真实的反应个人的状况

测试期间的数据收集

有关测试结果的积累数据

测试任务,测试集合和测试事件的描述

缺陷分析:

  • 由于计划的问题,导致没有发现的缺陷的数据
  • 严重的缺陷
  • 缺陷类型
  • 为什么缺陷没有发现

    效果

测试报告

  • 报告目前的软件状态
  • 功能/测试矩阵
  • 功能测试的状态报告,侧重点分析
  • 关于功能的工作时间轴
  • 期望发现 VS 实际发现的缺陷比
  • 没有发现的缺陷和改正的缺陷的差距
  • 按照类型分类,没有改正的缺陷的平均值
  • 缺陷分类报告
  • 测试活动报告

报告汇总

  • 各个阶段的项目测试总结报告
  • 继承性测试报告
  • 系统测试报告
  • 确认测试报告