根据标准化开发流程---解析LIN总线脉冲唤醒的测试方法和用例设计思路

news2024/10/23 18:25:46

前言:本文从标准化开发流程的角度,以LIN总线脉冲唤醒为切入点。从测试工程师的角度来讲测试工作应当如何展开(结合我干测试总结出来的测试经验)。希望大家都能从中有收获!!谢谢!!

1:了解脉冲唤醒

“当总线处于休眠状态时,主/从机节点都可以向总线上发送唤醒信号(显性电压),唤醒信号持续 250μs~5ms。其余节
点(除发送唤醒信号以外的节点)以大于 150μs 为阈值判定唤醒信号。每个从机节点必须在唤醒信号显性脉冲的
结束处算起 100ms 以内准备接收来自主机的命令(帧头);主机节点也必须被唤醒, 100ms 之内主机节点发送帧
头开始通信。主机节点的同步间隔段也可以充当唤醒信号,由于从机节点需要作初始化处理,因此主机节点所发的这个帧有可能不会被正常接收
如果节点发送出唤醒信号后,在 150ms~250ms 之内没有接收到总线上的任何命令(帧头),则可以重新发送
一次唤醒信号。唤醒信号最多可以发送 3 次, 3 次之后,必须等待至少 1.5s 之后才可以再次发送唤醒信号。三个唤醒信号为一组,最大可以发送三组唤醒信号。唤醒信号一般由部分合适的从机节点发出!(合适的大致解释是,具有人机交互的从机,比如从机上有开关,有屏幕等,并且以开关或屏幕作为触发条件)”

连续发出9个唤醒信号后(即从最后第九个唤醒信号的上升沿处算起),一般等待(2*1.5或3*1.5)的时间后。才能再次发送唤醒信号。

根据标准的开发流程,如ASPICE首先我们需要分析需求,分析需求有以下几种

1:提取测试关键信息(也就是功能点)

2:审查需求中功能点错误,遗漏,或相互冲突的地方

3:评估功能点,结合现有软硬件条件,人员素质,是否可以进行测试(如果内部资源无法满足,功能点又必须测试。则可以考虑外包测试,或采购设备,培训或招聘测试人员)。

(此段描述是基于LIN规范总结出来的,没有错误,红色是我自己添加的,实际项目也基本这样做),故只需关注1和3点即可。

提取关键信息,上面的关键信息,我都用黑体加粗标注。总结为两个方面

**1)对脉冲唤醒信号参数的描述,如下图

图形说明则更加直观

看图并结合表格,非常清楚。

**2)不同节点需要对脉冲唤醒信号的处理方法

**3)不同节点被脉冲唤醒信号唤醒后的处理方法

 测试方案

根据标准开发流程(aspice)此时我们进入到测试方案的编写,测试方案主要是以下几点

1:从设备是否支持?支持的话,需要哪些设备,对设备的性能,精度,甚至是尺寸的要求是哪些

2:环境是否支持?支持的话,对环境有哪些需求,如无静电环境,无灰尘环境等。。

3:人员是否支持? 需要什么等级的人执行测试,测试的要求,效率和时间要求

4:对覆盖率的要求?对用例编写方法的要求?对用例编写方法的要求

5:对测试方法的说明,如:如何操作示波器,万用表,如何创建,打开和使用工程等

6:需说明,不同变更条件下,对测试范围的选择。

7:Bug的跟踪处理方法和机制

测试方案还需要跨部门评审,有时候附带着还要出具一份测试方法说明(指测试工具的使用,规范化的测试步骤等。。。)。

总之作为汽车电子行业的测试工程师,一定不能忽视测试方案的重要性,它是整个测试过程中的指导文件,必须重视。

测试计划

测试方案出具之后。需要编写测试计划,测试计划是基于客户的开发周期,结合本公司实际情况,制定的大致规划。说明了不同项目节点下,测试需要提交的报告。当然测试计划,不是必须遵守的

还要根据实际的开发情况,作出不同的修改!提前或延期交付。

测试用例的编写

这是非常重要的一环,是测试工作中的核心工作。我们需要结合测试方案,并结合一些常见的测试方法论。来编写。

编写用例的基本思想必须遵守

1:用例必须满足测试方案中规定的最低覆盖率

2:测试用例,必须有依据(如需求,系统规格书,架构框图,电子原理图,及客户或公司提供的其他资料)

3:测试用例,必须便于测试执行者理解(很多公司都要求,测试编写人和测试执行人必须不同),不能让执行者,再去翻阅其他资料,从而拉低测试效率。

5:步骤明确,描述清楚,不能产生歧义。尽量不要出现错别字哈

6:根据项目紧急程度,适当的分文档编写。(如项目开发周期短,架构复杂),这样做能提高测试的效率。

7:各个公司都具有,自己公司的一套测试模板,大家实际编写过程中,需要根据模板格式,来编写用例。

8:结合实际情况,必须考虑测试的可操作性

用例编写的方法论

我会根据脉冲唤醒信号,结合实例来阐述我总结的一些基本思想

1:分类(class级别)

1.1:基于产品层面的分类,汽车电子产业中,一个项目会延伸出几个不同的版本(如高配版本,低配版本)。根据评估如果产品差异不大,是可以写在一份测试用例里(必须做出必要的说明)。

如果产品差异很大,必须分开编写测试用例

1.2:基于ISO的各种规范标准下,进行分类

如脉冲唤醒信号的测试,必须要知道节点是主节点还是从节点,从节点又分为能发送脉冲信号的从节点只能接收脉冲信号的从节点

根据需求规格书中的定义,我们知道所测试的节点类型后,测试项目也就能定下来了。

2:测试用例编写的方法论:

2.1 合适选择功能点,从整体到细节,从简单到复杂

以发送唤醒信号的从节点为例说明。

根据上面描述。选取两个功能点分开

功能点1:发送唤醒信号的从节点,只要帧头没有被发送,就一直发送最多9个唤醒信号。且连续发出9个唤醒信号后(即从最后第九个唤醒信号的上升沿处算起)。

功能点2:一般等待(2*1.5或3*1.5)的时间后。才能再次发送唤醒信号。

考虑最简单的情况:

就是能发送唤醒信号的从节点,单独运行在总线上。模拟的主节点断开,或保持只读模式。测试从节点的波形和参数。

功能点1,测试

观察整体波形:

前期工作:搭建好测试环境,使用示波器量取总线波形

步骤1,总线单独运行该从节点,节点处于睡眠状态

步骤2,触发唤醒信号的发送。

判断依据,看总线是否发出如下图中的波形

步骤4:对波形详细的电压参数,时间参数进行测量(先暂停示波器,再使用示波器的光标进行测量)

用例应该对各种参数的范围,作出说明。上述测试用例,体现的就是先整体后细节方法论的体现

对此功能点2测试【即从最后第九个唤醒信号的上升沿处算起,一般等待(2*1.5或3*1.5)的时间后。才能再次发送唤醒信号】

重复上述触发过程,在最后一个唤醒信号发出后,一直执行触发唤醒信号,到唤醒信号再次被触发。量取1,2之间的时间

可以看到,功能点2比功能点1,在实现上复杂一点,我们先测容易测的,在到难测的,这就是由易到难的测试方法论。

2.1 测试边界值

只接收唤醒信号的节点,以大于 150μs 的显现脉冲为阈值。(上面为了不引起混乱,就没提)

此处提出,可以验真边界值测试的方法论。

前期工作:搭建好测试环境,使用示波器量取总线波形。设置好信号发生器模拟输入唤醒信号

步骤1,总线单独运行只接受唤醒信号,从节点,节点处于睡眠状态

步骤2,使用示波器唤醒信号的发送。设置唤醒信号的显性脉冲阈值为 148us 、149us、150us 151us,152us。

判断依据,观察模块是否被唤醒(可以根据模块电流来观察,被唤醒后电流提升4s左右)

2.3穷举法测试

穷举法测试(1:部分穷举 2:全部穷举)

以能发送唤醒信号的从节点为例。

知道,唤醒信号在触发帧头之后,便不再发送

1:部分穷举,利用自动化脚本,依次第1个/3个/5个/7个/9个  唤醒信号之后,发出帧头,观察唤醒信号是否停止发送。

2:全部穷举,就是全部1-9都测一遍。

本例中,因为状态少,可以全部穷举,要是遇到存在几百几千种状态的情况下,尽量采取部分穷举的方法测试

2.4 按逻辑测试

如总线上同时存在,主节点,发送唤醒信号的从节点,接收唤醒信号的从节点。就必须厘清之间的逻辑关系。

太晚了,明天再写吧!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1498198.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

吴恩达deeplearning.ai:机器学习项目的完整周期伦理

以下内容有任何不理解可以翻看我之前的博客哦:吴恩达deeplearning.ai专栏 文章目录 语音识别部署公平、偏见、伦理 这节博客中,我们主要看看构建一个机器学习的完整周期是什么,也就是说,当你想构建一个有价值的机器学习系统时&am…

【conda】实现conda环境迁移的4种方式

文章目录 方案1: 使用conda pack制作压缩包并在目标环境解压使用方案2: 使用package列表文件重新创建conda环境方案3: scp将环境文件夹拷贝到目标主机上方案4: 通过--clone先克隆一个环境再conda pack打包迁移 方案1: 使用conda pack制作压缩包并在目标环境解压使用 适合离线环…

python爬虫(2)

继上节 查看数组维数 可以使用数组的ndim属性 代码示例如下: import numpy as np c np.random.randint(1,9,5) print(c.ndim) 结果如下: 当然这些也可以结合前面的各种用法来使用 1、选取数组元素 (1)一维数组的元素…

NDK,Jni

使用 NDK(Native Development Kit)意味着在 Android 应用程序中集成 C/C 代码。通常情况下,Android 应用程序主要使用 Java 或 Kotlin 编写,但有时候需要使用 C/C 来实现一些特定的功能或性能优化。 NDK 提供了一组工具和库&…

onnx模型优化利器onnxoptimizer、onnxsim

ONNX性能优化和调试技巧 - 知乎ONNX模型是一种跨平台、跨框架的模型表示格式,允许用户在不同的深度学习框架之间共享模型和数据,从而加速模型开发和部署。然而,在实际应用中,我们通常需要对ONNX模型进行性能优化和调试,以确保其在不同硬件和…https://zhuanlan.zhihu.com/…

C#,哈夫曼编码(Huffman Code)压缩(Compress )与解压缩(Decompress)算法与源代码

David A. Huffman 1 哈夫曼编码简史(Huffman code) 1951年,哈夫曼和他在MIT信息论的同学需要选择是完成学期报告还是期末考试。导师Robert M. Fano给他们的学期报告的题目是,寻找最有效的二进制编码。由于无法证明哪个已有编码是…

和为K的子数组

题目: 使用前缀和的方法可以解决这个问题,因为我们需要找到和为k的连续子数组的个数。通过计算前缀和,我们可以将问题转化为求解两个前缀和之差等于k的情况。 假设数组的前缀和数组为prefixSum,其中prefixSum[i]表示从数组起始位…

JavaWeb-Maven基础

Maven是专门用于管理和构建Java项目的工具,是 Apache 下的一个纯 Java 开发的开源项目,基于项目对象模型(POM)概念。先来学习一下Maven基础,等后面学完开发框架后再学Maven高级,这次的内容如下 一、概述 …

主题乐园如何让新客变熟客,让游客变“留客”?

群硕跨越时间结识了一位爱讲故事的父亲,他汇集了一群幻想工程师,打算以故事为基础,建造一个梦幻的主题乐园。 这个乐园后来成为全球游客最多、收入最高的乐园之一,不仅在2023财年创下了近90亿(美元)的营收…

9款世界级垂直领域软件架构师Visio平替作图工具!

1 LucidChart 一个基于HTML5的在线流程图绘制和协作应用平台,用户可以通过它方便快速的实现流程图表的绘制,同时还可以实现与他人进行实时的流程图绘制和修改功能,对需要群组协作功能的团队来说,这点非常方便。 由于LucidChart是…

机器学习-面经(part8、贝叶斯和其他知识点)

机器学习面经其他系列 机器学习面经系列的其他部分如下所示: 机器学习-面经(part1)-初步说明 机器学习-面经(part2)-交叉验证、超参数优化、评价指标等内容 机器学习-面经(part3)-正则化、特征工程面试问题与解答合集机器学习-面经(part4)-决策树共5000字的面试问…

【CSP试题回顾】201503-3-节日

CSP-201503-3-节日 关键点:格式化输出 在C中,格式化输出通常利用iostream库中的功能,特别是iomanip头文件提供的一系列操作符。这些操作符用于控制输出格式,如宽度、填充、对齐方式等。在你提供的代码中,用于格式化输…

python 输入和输出

在 Python 中,输入和输出是最基本的操作之一。你可以使用内置函数 input() 来获取用户输入,使用 print() 函数来输出信息到控制台。 输入(Input) input() 函数用于从用户那里获取输入。这个函数会将用户的输入作为字符串返回。 示…

蓝桥杯(3.7)

P1102 A-B 数对 import java.util.Scanner; public class Main {public static void main(String[] args) {Scanner sc new Scanner(System.in);int n sc.nextInt();int c sc.nextInt();int[] res new int[n1];for(int i1;i<n;i)res[i] sc.nextInt();int sum 0;for(i…

Linux系统的进程,看完它,相信你想kill“it“就kill“it“o((>ω< ))o

Linux系统的进程 众所周知&#xff0c;不管在什么系统中&#xff0c;进程和线程都是操作系统中高并发处理中产生了重要的作用。Linux作为一个操作系统&#xff0c;也必须要拥有这两者才可以进行高并发。 进程是资源分配的最小单位。每一个进程都是相互独立的&#xff0c;不管是…

WordPress供求插件API文档:用户登录

该文档为WordPress供求插件文档&#xff0c;详情请查看 WordPress供求插件&#xff1a;一款专注于同城生活信息发布的插件-CSDN博客文章浏览阅读67次。WordPress供求插件&#xff1a;sliver-urban-life 是一款专注于提供同城生活信息发布与查看的插件&#xff0c;该插件可以实…

TCP收发——计算机网络——day02

今天主要讲了TCP的收发 TCP发端步骤 ①socket ②connect ③send ④closeTCP收端步骤 ①socket ②bind ③listen ④accept ⑤recv ⑥clise其函数主要有 connect int connect(int sockfd, const struct sockaddr *addr,socklen_t addrlen);功能:发送链接请求参数:sockfd:套接…

【设计数据密集型应用】复制

&#x1f44f;作者简介&#xff1a;大家好&#xff0c;我是爱敲代码的小黄&#xff0c;阿里淘天Java开发工程师&#xff0c;CSDN博客专家&#x1f4d5;系列专栏&#xff1a;Spring源码、Netty源码、Kafka源码、JUC源码、dubbo源码系列&#x1f525;如果感觉博主的文章还不错的话…

nginx 使用记录

使用&#xff1a; 去官网下载指定版本1.24.0&#xff0c;直接将压缩包解压到指定目录&#xff0c;打开cmd即可启动 启动服务器&#xff1a; 方法一&#xff1a;打开cmd命令窗口&#xff0c;切换到nginx解压目录下&#xff0c;输入命令start nginx &#xff0c;回车即可&…

数据结构:AVL树

目录 1、AVL树的概念 2、二叉搜索树的功能与实现 1、AVL树节点定义 2、AVL树的插入 3、AVL树的旋转操作 1、左旋 2、右旋 3、左右旋 4、右左旋 3、AVL树完整代码实现 1、AVL树的概念 在前面的文章中&#xff0c;我们学过了二叉搜索树&#xff0c;二叉搜索树虽可以缩短查…