【ISO 14229-1:2023 UDS诊断(ECU复位0x11服务)测试用例CAPL代码全解析⑧】

ISO 14229-1:2023 UDS诊断【ECU复位0x11服务】_TestCase08

作者:车端域控测试工程师

更新日期:2025年02月17日

关键词:UDS诊断协议、ECU复位服务、0x11服务、ISO 14229-1:2023

TC11-008测试用例

用例ID 测试场景 验证要点 参考条款 预期结果
TC11-008 多复位请求冲突处理 连续发送3次复位请求 §8.4.1 仅首次请求生效,后续返回NRC=0x78

以下是为TC11-008设计的增强型CAPL测试用例,包含时序控制与状态跟踪机制,包含执行流程图和工业级异常处理:

cpp 复制代码
/*----------------------------------------------------------
  Title:TC11-008 多复位请求冲突处理验证 
  作者:车端域控测试工程师 
  日期:2025-02-17 
------------------------------------------------------------*/
 
variables {
  // 通信参数 
  const long DiagReqID = 0x732;       // 诊断请求标识符 
  const long DiagResID = 0x733;       // 诊断响应标识符 
  const byte ResetSvc = 0x11;         // 复位服务ID 
  const byte ResetSub = 0x01;         // 硬件复位子功能 
  const byte ExpectedNRC = 0x78;      // 预期否定响应码 
  
  // 测试控制参数 
  msTimer responseTimer;
  int requestCounter = 0;
  byte responseStatus[3];             // 存储三次响应状态 
}
 
testcase TC11_008_MultiResetTest() 
{
  TestModuleTitle("TC11-008 多复位请求冲突验证");
  
  // ███ 阶段1:连续发送三次复位请求 ███ 
  testStep("STEP1 发送三次复位请求(间隔150ms)");
  
  for(requestCounter=0; requestCounter<3; requestCounter++) 
  {
    // 发送复位请求 
    message DiagReqID [CAN] {
      dlc = 2;
      byte(0) = ResetSvc;
      byte(1) = ResetSub;
    }
    output(this);
    
    // 启动响应监测窗口 
    setTimer(responseTimer, 300);
    while(getTimer(responseTimer) < 300) 
    {
      if(TestWaitForMessage(DiagResID, 50)) 
      {
        // 响应解析逻辑 
        if(this.byte(0) == 0x51) {
          responseStatus[requestCounter] = 1;  // 肯定响应 
          testAddLog("请求%d: 收到肯定响应", requestCounter+1);
          break;
        } 
        else if(this.byte(0) == 0x7F && 
                this.byte(1) == ResetSvc && 
                this.byte(2) == ExpectedNRC) 
        {
          responseStatus[requestCounter] = 2;  // 否定响应 
          testAddLog("请求%d: 收到NRC=0x%02X", requestCounter+1, ExpectedNRC);
          break;
        }
      }
    }
    
    // 超时处理 
    if(responseStatus[requestCounter] == 0) {
      responseStatus[requestCounter] = 3;      // 响应超时 
      testAddLog("请求%d: 响应超时", requestCounter+1);
    }
    
    // 请求间隔控制 
    testWait(150);
  }
 
  // ███ 阶段2:结果验证 ███ 
  testStep("STEP2 响应结果验证");
  
  // 首次请求验证 
  if(responseStatus[0] == 1) {
    testStepPass("首次请求成功执行");
  } else {
    testStepFail("首次请求失败(状态码:%d)", responseStatus[0]);
  }
  
  // 后续请求验证 
  for(int i=1; i<3; i++) 
  {
    if(responseStatus[i] == 2) {
      testStepPass("请求%d返回NRC=0x78", i+1);
    } else {
      testStepFail("请求%d异常(状态码:%d)", i+1, responseStatus[i]);
    }
  }
  
  // 综合判定 
  if(responseStatus[0]==1 && responseStatus[1]==2 && responseStatus[2]==2) {
    testCasePass("多复位冲突处理验证通过");
  } else {
    testCaseFail("冲突处理机制异常");
  }
}
 
/*----------------------------------------------------------
  系统状态监控模块(扩展功能)
----------------------------------------------------------*/
on sysvar ECU::ResetStatus 
{
  if(@this::ResetStatus == 1) {
    testAddLog("ECU复位操作已触发");
    testAddCondition("复位持续时间:%dms", sysGetTimer(ECU_RESET_TIMER));
  }
}

流程图解(执行逻辑可视化)
Tester ECU 复位请求 肯定响应(0x51) 复位请求 NRC=0x78 复位请求 NRC=0x78 Tester ECU

关键参数说明表

参数名称 示例值 工程配置要点
请求间隔 150ms 需小于ECU复位执行时间
响应超时 300ms 覆盖ECU最大响应时间
NRC 0x78 请求未响应 ISO 14229-1标准定义
复位子功能 0x01 OEM定义的硬件复位类型

响应状态矩阵

请求序号 预期状态 失败场景示例
1 肯定响应(0x51) ECU未执行复位
2 NRC=0x78 返回其他NRC或超时
3 NRC=0x78 错误响应或系统崩溃

工业级增强功能

  1. 复位状态跟踪

    cpp 复制代码
    // 通过系统变量监控实际复位动作 
    on sysvar ECU::PowerStatus {
      if(@this::PowerStatus == 0x02) {
        testAddLog("ECU进入重启流程");
      }
    }
  2. 压力测试扩展

    cpp 复制代码
    void ExecuteStressTest() {
      // 可扩展:
      // 1. 连续发送10次复位请求 
      // 2. 随机间隔测试(50-500ms)
      // 3. 混合其他服务请求 
    }
  3. 时序校验逻辑

    cpp 复制代码
    // 验证响应时序合规性 
    if(getTimer(responseTimer) < 200) {
      testAddCondition("响应时间:%dms", getTimer(responseTimer));
    }

专家调试技巧:

  1. Graphics窗口添加观测信号:

    ini 复制代码
    ECU::ResetStatus 
    sysvar::DiagResponseTime 
  2. 使用Diagnostic Console设置过滤条件:

    bash 复制代码
    filter.id = 0x733 && (payload[0] == 0x51 || payload[0] == 0x7F)
  3. 添加总线监测断点:

    cpp 复制代码
    break if (this.id == 0x733 && this.byte(0) == 0x7F)
相关推荐
虾球xz7 分钟前
游戏引擎学习第278天:将实体存储移入世界区块
数据库·c++·学习·游戏引擎
水水沝淼㵘14 分钟前
嵌入式开发学习日志(数据结构--单链表)Day20
c语言·开发语言·数据结构·学习·算法
FAREWELL0007540 分钟前
Unity基础学习(九)输入系统全解析:鼠标、键盘与轴控制
学习·unity·c#·游戏引擎
郜太素1 小时前
PyTorch 中神经网络相关要点(损失函数,学习率)及优化方法总结
人工智能·pytorch·python·深度学习·神经网络·学习
threelab2 小时前
05.three官方示例+编辑器+AI快速学习three.js webgl - animation - skinning - ik
人工智能·学习·编辑器
threelab2 小时前
04.three官方示例+编辑器+AI快速学习webgl_animation_skinning_additive_blending
人工智能·学习·编辑器
深度学习机器学习2 小时前
计算机视觉最不卷的方向:三维重建学习路线梳理
人工智能·深度学习·学习·yolo·目标检测·机器学习·计算机视觉
IT小白农民工2 小时前
SAP Business One(B1)打开自定义对象报错【Failed to initialize document numbering:】
经验分享·sap
半导体守望者2 小时前
AE FC77X77XXFC78X78XXFC79X MFC质量流量计 Mass Flow Controllers user manual
经验分享·笔记·功能测试·自动化·制造
jimsten2 小时前
苍穹外卖 - Day02 学习笔记
java·笔记·学习