CPAL脚本自动化测试 ———— Test Report系列函数及使用

在完成了测试用例的设计之后,最终的测试用例执行结果将会以Test Report形式展示。可能测试步骤中并没有包含我们所需要的信息,那这个时候test report系列函数将帮助我们完成这个功能。

  1. TestReportAddEngineerInfo/TestReportAddSetupInfo/TestReportAddSUTInfo 函数
    使用格式如下。主要用于在测试报告中添加一些信息(测试员、测试配置、待测样品)。
    在这里插入图片描述
    用例:
	// add information to SUT information table 
TestReportAddSUTInfo("Serial No.", "A012345BC");
TestReportAddSUTInfo("Manufactured", "2003-10-02");
	// add information to test engineer information table 
TestReportAddEngineerInfo("Test Engineer", "S. Grey");
TestReportAddEngineerInfo("Stuff No.", "12345");
	// add information to test setup information table 
TestReportAddSetupInfo("Tester", "TH12");
  1. TestReportAddExtendedInfo 函数
    使用格式如下。主要用于将信息添加CANoe本身不支持的协议,常见的有HTML、txt、其他文本(将在XML报告中体现,不会再HTML报告中体现)
    在这里插入图片描述
    用例:
	// add html line to report, e.g. a link to the homepage 
TestReportAddExtendedInfo("html", "<A HREF=\"http://www.vector.com\">Homepage</A>");

TestReportAddExtendedInfo("text", "Output voltage = %d volts)", voltage);
  1. TestReportAddExternalRef 函数
    使用格式如下。主要用于在测试报告中添加外部应用。向报告添加外部引用(URL,DOORS(IBM公司的一个需求管理系统)、eASEE链接),该引用在测试报告中显示为链接。
    在这里插入图片描述
    用例:
testcase tc_1_1()
{
   TestCaseTitle("tc_1_1", "Test Case 1.1");
TestReportAddExternalRef("url", "Requirement", "doors://doorssrv:36677/?version=1,prodID=0,dbid=42d2481361dc551c,container=00004600,object=19");
}
  1. TestReportAddImage 函数
    使用格式如下。主要是用于添加图片。在XML或HTML格式的报告中,对于图片的格式也是存在着一定的要求的,这里仅支持JPEG,GIF 和 PNG这三种格式。
    在这里插入图片描述
    用例:
	// add image to report, scale down to reasonable size 
TestReportAddImage("Oscilloscope Snapshot", "osc_01.png", "400px", "");
  1. TestReportAddMiscInfoBlock 函数
    使用格式如下。主要用于生成一个新的信息区域来记录一些额外的信息。具体的信息需要使用到TestReportAddMiscInfo函数来写入。重新启用TestReportAddMiscInfoBlock 函数、用例执行结束或者调用了新用例聚会导致一个信息块的终止。
    在这里插入图片描述
    用例:
// add info block to test case in report 
TestReportAddMiscInfoBlock("Used Test Parameters");
TestReportAddMiscInfo("Max. voltage", "19.5 V");
TestReportAddMiscInfo("Max. current", "560 mA");
  1. TestReportAddMiscInfo 函数
    使用格式如下。主要用于在测试报告中添加一些信息。在使用该函数之前必须先使用TestReportAddMiscInfoBlock创建附加信息区域。 如果使用此功能但没有相应的信息区域,则将在“Write”窗口中生成警告,并自动创建一个新的信息区域。 在此信息区域中,可以使用此功能写入任意数量的信息对。
    在这里插入图片描述
    用例:
// add info block to test case in report 
TestReportAddMiscInfoBlock("Used Test Parameters");
TestReportAddMiscInfo("Max. voltage", "19.5 V");
TestReportAddMiscInfo("Max. current", "560 mA");
  1. TestReportAddWindowCapture 函数
    使用格式如下。主要用于抓取某些窗口或面板(Panel)的图片。例如在自动泊车的过程中会有视频输出,我们可以每隔一段时间进行截取,从而记录整个过程中的状态变化。这里的窗口是CANoe工程里面自带的一个窗口,不支持外部设备。例如,可以使用该函数来截取CANoe工程中的Vedio窗口,但是不能截取电脑的Camera窗口。
    在这里插入图片描述
    用例:
testcase tc_1_1()
{
   TestCaseTitle("tc_1_1", "Test Case 1.1");
   TestReportAddWindowCapture("Trace - Report", "", 
                              "Trace before execution of test case:", 
                              "tc-1.1-trace-before");

      ... execute Test Pattern(s) ...

      if (TestGetVerdictLastTestCase() != 0) {
          TestReportAddWindowCapture("Trace - Report", "", 
                                     "Testfall failed. Trace am Ende:",
                                     "tc-1.1-trace-after");
   }
}
  1. TestReportWriteDiagObject/TestReportWriteDiagResponse 函数
    使用格式如下。主要是将获取到的诊断对象、诊断响应以HTML格式写入到测试报告中。这对于后续的分析还是存在着较大的便利。例如,如果回访log则需要花费太多的时间并且占用设备,如果能在报告中直接获取到响应内容则方便了许多。
    在这里插入图片描述
    用例:
TestCase Test1()
{
   // Send Request and react to all possible cases.
   diagRequest Door.EcuIdentification_Read idReq;
   diagSendRequest( idReq);
   switch( TestWaitForDiagResponse( idReq, 200))
   {
   case 0: // Timeout: The ECU did not respond within 200 ms.
      write("No answer from ECU!");
      TestStepFail("Read ID", "No answer from ECU!");
      break;
   case 1: // response received
      TestReportWriteDiagResponse(idReq); // write response to report
      if( diagGetLastResponseCode(idReq) == -1)
      {
      // A positive response was received
      write("ECU Diagnostics Identification: %d", (long)diagGetRespParameter(idReq,"Diagnostic_Identification"));
      TestStepPass("Read ID", "Positiv response received!");
      }
      else // A negative response was received
      {
      write( "ECU Diagnostics Identification failed: 0x%x", diagGetLastResponseCode( idReq));
      TestStepFail("Read ID", "Negative response received");
      }
      break;
      default: // internal or setup error
      TestStepFail("Read ID", "Error in TestCase! Verdict unreliable.");
      }
}

diagRequest是一个函数,用于发送诊断请求给目标ECU。它是在CAPL中使用的一个成熟的函数,可以帮助实现自动化测试。具体的格式如下: ``` diagRequest PAS3.* pasDiagReqst; dword diagLen; diagLen = stringToBytes(diagString, rawDiagReqst); diagResize(pasDiagReqst, diagLen); ``` 这个函数主要用于调整诊断对象的大小以匹配指定的参数迭代,或将总线消息的大小设置为给定的字节数。在上述示例中,首先将诊断请求字符串转换为字节数组,然后使用diagResize函数调整诊断对象的大小。 另外,还有其他与诊断相关的函数,如diagResponse用于处理诊断服务的响应,diagSetTarget用于设定诊断目标ECU,diagGenerateKeyFromSeed用于根据种子生成密钥等等。这些函数可以帮助我们完成日常的测试场景的覆盖。\[1\]\[2\] #### 引用[.reference_title] - *1* [CPAL脚本自动化测试 ———— Diag系列常用函数使用](https://blog.csdn.net/qq_42957717/article/details/117077022)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [CAPL诊断函数解释](https://blog.csdn.net/seekshero/article/details/113863812)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小趴菜_自动驾驶搬砖人

谢谢大爷赏饭吃

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值