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

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

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 为测试层次分配质量特性

  • 用矩阵来表示,行为测试层次,列为质量特性;
  • 每一个交叉点的符号(++、+或空白)表示测试层次在质量特性中的覆盖程度;
++ : 该测试层次将完全覆盖质量特性;
 + : 该测试层次将覆盖一部分质量特性;
空 :该测试层次与质量特性无关。
  • 举例:
功能 连接性 可用性 可恢复性 性能 适用性
40 10 10 5 15 20
单元测试 ++ +
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部分 整个系统
100 30 10 30 5 25
功能性 40 ++ + + + +
性能 25 + ++ + +
可靠性 10 + ++
适用性 25 + + + ++

3.6 确定要使用的测试技术

影响选择测试技术的因素

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

4 测试过程中的策略变更

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

5 维护测试策略

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

  • 确定变更;
  • 确定变更和回归的重要性;
  • 选择质量特性;
  • 确定质量特性的相对重要性;
  • 确定每个变更(回归)/质量特性联合体的相对重要性;
  • 确定可用的测试技术。
目录
相关文章
|
9月前
|
人工智能 搜索推荐 数据管理
探索软件测试中的自动化测试框架选择与优化策略
本文深入探讨了在现代软件开发流程中,如何根据项目特性、团队技能和长期维护需求,精准选择合适的自动化测试框架。
362 11
|
3月前
|
测试技术 Python
Python测试报告生成:整合错误截图,重复用例执行策略,调整测试顺序及多断言机制。
如何组织这一切呢?你可以写一本名为“Python测试之道”的动作指南手册,或者创建一个包含测试策略、测试顺序、多断言机制的脚本库。只要你的测试剧本编写得足够独到,你的框架就会像一位执行任务的超级英雄,将任何潜伏于代码深处的错误无情地揪出来展现在光天化日之下。这些整理好的测试结果,不仅有利于团队协作,更像冒险故事中的精彩篇章,带给读者无尽的探索乐趣和深刻的思考。
96 10
|
9月前
|
测试技术 持续交付
探索软件测试中的自动化测试策略
随着软件开发周期的加速和市场需求的不断增长,传统的手动软件测试方法已难以满足现代软件开发的高效性和准确性要求。本文旨在探讨自动化测试在软件测试中的重要性、实施策略及其对提高软件质量的影响。通过分析自动化测试的优势与挑战,以及提供实用的自动化测试工具和框架选择指南,旨在帮助读者理解并应用自动化测试以提升软件开发效率和产品质量。
|
9月前
|
Java 测试技术 数据安全/隐私保护
软件测试中的自动化策略与工具应用
在软件开发的快速迭代中,自动化测试以其高效、稳定的特点成为了质量保证的重要手段。本文将深入探讨自动化测试的核心概念、常见工具的应用,以及如何设计有效的自动化测试策略,旨在为读者提供一套完整的自动化测试解决方案,帮助团队提升测试效率和软件质量。
|
9月前
|
机器学习/深度学习 人工智能 监控
软件测试中的自动化测试策略与最佳实践##
在当今快速发展的软件行业中,自动化测试已成为确保软件质量和加速产品上市的关键工具。本文将探讨自动化测试的重要性,分析不同类型的自动化测试工具和框架,并深入讨论实施自动化测试的最佳实践。通过案例研究和数据分析,我们将揭示如何有效整合自动化测试到软件开发生命周期中,以及它如何帮助团队提高测试效率和覆盖率。 ##
146 1
|
3月前
|
安全 测试技术 持续交付
软考软件评测师——基于风险的测试技术
本文详细阐述了测试计划的核心要素与制定流程,涵盖测试范围界定、实施策略规划、资源配置及风险管理机制。通过风险识别方法论和评估模型,构建了完整的质量保障体系。同时,针对不同测试级别与类型提供具体配置建议,并提出技术选型原则与实施规范,确保测试活动高效有序开展,为项目成功奠定基础。内容结合实际经验,具有较强指导意义。
|
7月前
|
存储 数据可视化 测试技术
一个测试工程师的实战笔记:我是如何在Postman和Apipost之间做出选择的?
优秀的API测试工具应该具备: 分层设计:既有可视化操作,也开放代码层深度定制 场景感知:自动识别加密需求推荐处理方案 协议包容:不强迫开发者为了不同协议切换工具 数据主权:允许自主选择数据存储位置
177 7
|
7月前
|
算法
MATLAB在风险管理中的应用:从VaR计算到压力测试
本文介绍如何使用MATLAB进行风险管理,涵盖风险度量(如VaR)、压力测试和风险分解。通过历史模拟法、参数法和蒙特卡洛模拟法计算VaR,评估投资组合在极端市场条件下的表现,并通过边际VaR和成分VaR识别风险来源。结合具体案例和代码实现,帮助读者掌握MATLAB在风险管理中的应用,确保投资组合的稳健性。
|
8月前
|
机器学习/深度学习 人工智能 自然语言处理
MarS:微软开源金融市场模拟预测引擎,支持策略测试、风险管理和市场分析
MarS 是微软亚洲研究院推出的金融市场模拟预测引擎,基于生成型基础模型 LMM,支持无风险环境下的交易策略测试、风险管理和市场分析。
266 8
MarS:微软开源金融市场模拟预测引擎,支持策略测试、风险管理和市场分析
|
9月前
|
数据管理 测试技术 持续交付
软件测试中的自动化测试策略与最佳实践
在当今快速迭代的软件开发环境中,自动化测试已成为确保软件质量和加速产品上市的关键手段。本文旨在探讨软件测试中的自动化测试策略,包括选择合适的自动化测试工具、构建有效的自动化测试框架以及实施持续集成和持续部署(CI/CD)。通过分析自动化测试的最佳实践,本文为软件开发团队提供了一系列实用的指南,以优化测试流程、提高测试效率并减少人为错误。
230 4