【ISO 14229-1:2023 UDS诊断(会话控制0x10服务)测试用例CAPL代码全解析②】

news2025/2/19 23:25:47

ISO 14229-1:2023 UDS诊断【会话控制0x10服务】_TestCase02

作者:车端域控测试工程师
更新日期:2025年02月15日
关键词:UDS诊断、0x10服务、诊断会话控制、ECU测试、ISO 14229-1:2023

TC10-002测试用例

用例ID测试场景验证要点参考条款预期结果
TC10-002扩展会话超时管理S3定时器超时后自动返回默认会话Annex A.3超时60s±5%触发会话切换
/*-------------------------------------------------------------------
  测试用例 TC10-002:扩展会话超时管理 
  标准依据:ISO 14229-1 Annex A.3 
  验证目标:S3定时器超时后自动返回默认会话 
  时间要求:60s±5%(57s-63s)
-------------------------------------------------------------------*/
variables {
  message 0x7E0 DiagReq = {dlc=8};  // 诊断请求报文 
  message 0x7E8 DiagRes;           // 诊断响应报文 
  msTimer sessionTimer;            // 会话计时器 
  dword sessionStartTime;          // 会话开始时间戳 
  byte currentSession;             // 当前会话状态 
}
 
testcase TC10_002_SessionTimeout() 
{
  //==================== 测试初始化 ====================
  sysSetVariable("Diag::Session", 0x01);  // 强制重置为默认会话 
  currentSession = 0x01;
 
  //==================== 激活扩展会话 ====================
  DiagReq.byte(0) = 0x10;          // 诊断会话控制服务 
  DiagReq.byte(1) = 0x03;          // 子功能:扩展会话 
  DiagReq.dlc = 2;
  output(DiagReq);
  
  // 等待正响应 
  testWaitForMessage(0x7E8, 1000);
  if(DiagRes.byte(0) != 0x50 || DiagRes.byte(1) != 0x03) {
    testStepFail("扩展会话激活失败");
    return;
  }
  sessionStartTime = timeNow();    // 记录会话激活时间 
  write("扩展会话激活时间:%d ms", sessionStartTime);
 
  //==================== 超时监控 ====================
  setTimer(sessionTimer, 65000);   // 设置65秒监控周期 
  write("开始监测会话超时...");
  
  // 定时器回调处理 
  on timer sessionTimer {
    dword elapsedTime = timeNow() - sessionStartTime;
    currentSession = sysGetVariable("Diag::Session");
    
    // 验证时间窗口和会话状态 
    if(currentSession == 0x01) {
      if(elapsedTime >= 57000 && elapsedTime <= 63000) {
        testStepPass("定时器在%0.1fs触发切换(符合57-63s要求)", elapsedTime/1000.0);
      } else {
        testStepFail("切换时间异常:%0.1fs", elapsedTime/1000.0);
      }
    } else {
      testStepFail("会话未切换,当前状态:0x%02X", currentSession);
    }
  }
  
  // 等待测试完成 
  testWaitForTimeout(66000);
}
 
/*------------------------- 执行日志示例 ------------------------- 
[2025-02-15 09:55:12] TC10-002 测试启动 
[2025-02-15 09:55:12] 发送请求: 10 03 @ 7E0 
[2025-02-15 09:55:12] 收到响应: 50 03 @ 7E8 
[2025-02-15 09:55:12] 会话激活时间:43650000 ms 
[2025-02-15 09:56:15] 定时器在61.3s触发切换(符合57-63s要求)
[2025-02-15 09:56:15] 测试通过 
----------------------------------------------------------------*/

代码执行流程图

测试系统 ECU 10 03 (扩展会话) 50 03 (正响应) 启动65秒计时器 监控会话状态 当前会话状态 loop [超时监控] 验证切换时间和状态 测试系统 ECU

关键实现说明

  1. 时间窗口验证逻辑
if(elapsedTime >= 57000 && elapsedTime <= 63000) {
  // 符合±5%精度要求 
}
  1. 会话状态实时监控
on sysvar Diag::Session {
  currentSession = @this;  // 实时捕获会话状态变化 
  write("会话状态变更:0x%02X @ %dms", currentSession, timeNow());
}
  1. 容错机制设计
// 增加网络静默检测 
testWaitForBusSilence(1000);  // 确保测试期间无其他通信 

测试数据记录表

测试轮次触发时间(s)会话状态测试结果
158.90x01PASS
262.10x01PASS
356.80x03FAIL
463.50x01FAIL

常见问题处理方案

  1. 超时时间偏差过大

    • 检查ECU配置参数:
      sysGetParameter("Diag::S3_Timeout"); // 读取实际配置值 
      
    • 使用示波器监控硬件唤醒信号
  2. 会话状态未切换

    • 添加诊断服务重试机制:
      for(int i=0; i<3; i++) {
        output(DiagReq);
        if(testWaitForMessage(0x7E8, 1000)) break;
      }
      
  3. 偶发性测试失败

    • 增加预测试环境检查:
      if(sysGetVariable("PowerVoltage") < 11.5) {
        testStepWarning("电压不稳定:%.1fV", sysGetVariable("PowerVoltage"));
      }
      

操作建议:

  1. 测试前使用sysSetParameter("Diag::DebugMode", 1)开启调试模式
  2. 配合CANoe的Graphics窗口可视化定时器状态
  3. 建议在-40°C、25°C、85°C三个温度点执行测试
  4. 完整测试需包含500次压力测试循环

将代码复制到CANoe Test Module后,通过以下步骤执行:

  1. 配置ECU工程文件加载诊断数据库
  2. 设置系统变量Diag::Session的监控
  3. 运行测试用例并查看生成的HTML报告

遇到技术问题可在评论区留言,建议配合使用CANoe的实时曲线功能监控时间参数。

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

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

相关文章

MATLAB图像处理:图像特征概念及提取方法HOG、SIFT

图像特征是计算机视觉中用于描述图像内容的关键信息&#xff0c;其提取质量直接影响后续的目标检测、分类和匹配等任务性能。本文将系统解析 全局与局部特征的核心概念&#xff0c;深入讲解 HOG&#xff08;方向梯度直方图&#xff09;与SIFT&#xff08;尺度不变特征变换&…

kibana es 语法记录 elaticsearch

目录 一、认识elaticsearch 1、什么是正向索引 2、什么是倒排索引 二、概念 1、说明 2、mysql和es的对比 三、mapping属性 1、定义 四、CRUD 1、查看es中有哪些索引库 2、创建索引库 3、修改索引库 4、删除索引库 5、新增文档 6、删除文档 5、条件查询 一、认识…

手写一个Java Android Binder服务及源码分析

手写一个Java Android Binder服务及源码分析 前言一、Java语言编写自己的Binder服务Demo1. binder服务demo功能介绍2. binder服务demo代码结构图3. binder服务demo代码实现3.1 IHelloService.aidl3.2 IHelloService.java&#xff08;自动生成&#xff09;3.3 HelloService.java…

【动态规划篇】:当回文串遇上动态规划--如何用二维DP“折叠”字符串?

✨感谢您阅读本篇文章&#xff0c;文章内容是个人学习笔记的整理&#xff0c;如果哪里有误的话还请您指正噢✨ ✨ 个人主页&#xff1a;余辉zmh–CSDN博客 ✨ 文章所属专栏&#xff1a;动态规划篇–CSDN博客 文章目录 一.回文串类DP核心思想&#xff08;判断所有子串是否是回文…

Windows 安装 GDAL 并配置 Rust-GDAL 开发环境-1

Rust-GDAL 是 Rust 语言的 GDAL&#xff08;Geospatial Data Abstraction Library&#xff09; 绑定库&#xff0c;用于处理地理数据。由于 GDAL 依赖较多&#xff0c;在 Windows 上的安装相对复杂&#xff0c;本文档将介绍如何安装 GDAL 并配置 Rust-GDAL 的开发环境。 1. 检…

第1期 定时器实现非阻塞式程序 按键控制LED闪烁模式

第1期 定时器实现非阻塞式程序 按键控制LED闪烁模式 解决按键扫描&#xff0c;松手检测时阻塞的问题实现LED闪烁的非阻塞总结补充&#xff08;为什么不会阻塞&#xff09; 参考江协科技 KEY1和KEY2两者独立控制互不影响 阻塞&#xff1a;如果按下按键不松手&#xff0c;程序就…

开源语音克隆项目 OpenVoice V2 本地部署

#本机环境 WIN11 I5 GPU 4060ti 16G 内存 32G #开始 git clone https://github.com/myshell-ai/OpenVoice.git conda create -n opvenv python3.9 -y conda activate opvenv pip3 install torch torchvision torchaudio --index-url https://download.pytorch.org/whl/…

DeepSeek大模型一键部署解决方案:全平台多机分布式推理与国产硬件优化异构计算私有部署

DeepSeek R1 走红后&#xff0c;私有部署需求也随之增长&#xff0c;各种私有部署教程层出不穷。大部分教程只是简单地使用 Ollama、LM Studio 单机运行量化蒸馏模型&#xff0c;无法满足复杂场景需求。一些操作配置也过于繁琐&#xff0c;有的需要手动下载并合并分片模型文件&…

如何利用PLM软件有效地推进制造企业标准化工作?

在智能制造浪潮的推动下&#xff0c;中国制造业正面临从“规模扩张”向“质量提升”的关键转型。工信部数据显示&#xff0c;85%的制造企业在产品研发、生产过程中因标准化程度不足导致效率损失超20%&#xff0c;而标准化水平每提升10%&#xff0c;企业综合成本可降低5%-8%。如…

环境影响评价(EIA)中,土地利用、植被类型及生态系统图件的制作

在环境影响评价&#xff08;EIA&#xff09;中&#xff0c;土地利用、植被类型及生态系统图件的制作需依据科学、法规和技术规范&#xff0c;以确保数据的准确性和图件的规范性。以下是主要的制作依据&#xff1a; 1. 法律法规与政策依据 《中华人民共和国环境影响评价法》 明确…

更高效实用 vscode 的常用设置

VSCode 可以说是文本编辑神器, 不止程序员使用, 普通人用其作为文本编辑工具, 更是效率翻倍. 这里分享博主对于 VSCode 的好用设置, 让 VSCode 如虎添翼 进入设置 首先进入设置界面, 后续都在这里进行配置修改 具体设置 每项配置通过搜索关键字, 来快速定位配置项 自动保存…

【异或数列——博弈论】

题目 思路 异或和为0&#xff08;即每一位都有偶数个1&#xff09;&#xff1a;平局最高有效位只有唯一的1&#xff1a;先手必胜最高有效位有奇数个1&#xff0c;偶数个0&#xff1a;先手必胜 若先选1产生优势&#xff0c;则剩下偶数个1&#xff0c;偶数个0&#xff1a;对手选…

草图绘制技巧

1、点击菜单栏文件–》新建–》左下角高级新手切换–》零件&#xff1b; 2、槽口&#xff1a;直槽口&#xff0c;中心点槽口&#xff0c;三点源槽口&#xff0c;中心点圆弧槽口&#xff1b; 3、草图的约束&#xff1a;需要按住ctrl键&#xff0c;选中两个草图&#xff0c;然后…

Spring Boot中如何自定义Starter

文章目录 Spring Boot中如何自定义Starter概念和作用1. 概念介绍2. 作用和优势2.1 简化依赖管理2.2 提供开箱即用的自动配置2.3 标准化和模块化开发2.4 提高开发效率2.5 提供灵活的配置覆盖3. 应用场景创建核心依赖1. 确定核心依赖的作用2. 创建 starter-core 模块2.1 依赖管理…

内容中台构建高效数字化内容管理新范式

内容概要 在数字化转型浪潮中&#xff0c;高效的内容管理能力已成为企业构建核心竞争力的关键要素。通过动态发布引擎、元数据智能分类与跨平台协作机制&#xff0c;企业能够实现内容的实时触达与精准分发&#xff0c;同时确保知识资产在多终端环境下的无缝适配与安全共享。这…

PyQt组态软件 拖拽设计界面测试

PyQt组态软件测试 最近在研究PyQt,尝试写个拖拽设计界面的组态软件&#xff0c;目前实现的功能如下&#xff1a; 支持拖入控件&#xff0c;鼠标拖动控件位置 拖动控件边缘修改控件大小支持属性编辑器&#xff0c;修改当前选中控件的属性 拖动框选控件&#xff0c;点选控件 控…

深度学习R4周:LSTM-火灾温度预测

&#x1f368; 本文为&#x1f517;365天深度学习训练营中的学习记录博客&#x1f356; 原作者&#xff1a;K同学啊 任务&#xff1a; 数据集中提供了火灾温度&#xff08;Tem1&#xff09;、一氧化碳浓度&#xff08;CO 1&#xff09;烟雾浓度&#xff08;Soot 1&#xff09;…

Datawhale 数学建模导论二 笔记1

第6章 数据处理与拟合模型 本章主要涉及到的知识点有&#xff1a; 数据与大数据Python数据预处理常见的统计分析模型随机过程与随机模拟数据可视化 本章内容涉及到基础的概率论与数理统计理论&#xff0c;如果对这部分内容不熟悉&#xff0c;可以参考相关概率论与数理统计的…

UIView 与 CALayer 的联系和区别

今天说一下UIView 与 CALayer 一、UIView 和 CALayer 的关系 在 iOS 开发中&#xff0c;UIView 是用户界面的基础&#xff0c;它负责处理用户交互和绘制内容&#xff0c;而 CALayer 是 UIView 内部用于显示内容的核心图层&#xff08;Layer&#xff09;。每个 UIView 内部都有…

一键安装教程

Maven 安装 右键 以管理员身份运行点击 下一步安装完成后会同步配置环境变量打开 cmd, 输入 mvn 查看mvn版本修改 maven 本地仓库地址 见图三, 本地新建文件夹&#xff0c;修改为你本地文件夹地址 Redis 安装 右键 以管理员身份运行点击 下一步会安装到选择的文件夹下 JAVA\R…