loadrunner录制0事件_LoadRunner脚本异常捕获处理

c8cf0d89ce132546d7b6856069487f9d.png

》》》推荐阅读《《《

1、性能测试学习笔记-场景设计

2、性能测试的重要意义

3、性能分析流程及方法

4、应用系统性能调优之性能分析

1.   错误类型

脚本执行中通常会遇到下面几类测试类型:

Ø  标准错误(如HTTP states code)

Ø  LoadRunner函数抛出错误(LR常用函数、特定协议下的函数,包括检查点函数)

Ø  脚本自定义的错误(通过逻辑编写脚本开发人员抛出的错误)

2.   错误抛出

Ø  标准错误(如HTTP states code)

LoadRunner可以识别并在脚本执行中抛出。

Ø  LoadRunner函数抛出错误(LR常用函数、特定协议下的函数,包括检查点函数)

LoadRunner可以识别并在脚本执行中抛出。

Ø  脚本自定义的错误

脚本开发人员通过逻辑编写抛出的错误,使用lr_error 来抛出错误。结合lr_exit

3.   错误处理

全局设置

通过runtime-setting 设置全局性的设置

(1)  出现错误时抛出错误描述,离开错误所在Action,执行下一个Action。

(2)  出现错误时抛出错误描述,仍继续运行,设置将应用于整个 Vuser 脚本。

备注:runtime-setting 设置不包含lr_error_message函数抛出的错误场景。

局部设置

使用 lr_continue_on_error函数控制Vuser 脚本特定段的错误处理(前提应该是“出现错误时仍继续运行”选项未选中时)

(1)  没有选项,以runtime-setting 设置为主。

(2)  出现错误时抛出错误描述,离开错误所在Action,执行下一个Action

(3)  出现错误时抛出错误描述,离开错误所在Iteration,执行下一个Iteration

(4)  出现错误时抛出错误描述,终止发送错误的VUser,场景中的表现为终止改Vuser的运行。

4.   错误描述优化

通过脚本开发中逻辑代码,捕获已知错误,使错误信息含有测试事务、测试关键数据、原始错误描述等关键信息,方便定义问题,特别是场景执行中,能够在线发现问题方便在线分析问题,避免复测,节省测试时间。

5.   错误处理示例

HTTP/HTML协议

这里的异常处理是指在LR脚本录制或开发中事务(transaction)执行后失败捕获异常的方法。某项目HTTP/HTML协议应用场景如下,粗体部分为脚本开发中添加的异常处理逻辑相关代码:

lr_start_transaction("01_国内证_01_信用证开立");

/*信用证开立_CONFIRM检查点*/

web_reg_find("Text=Transaction  Completed",

          "SaveCount=KL_Count",

         LAST);

web_submit_data("WSTrxManager_21",

           "Action=http://10.114.6.49/EximBillWeb/servlets/WSTrxManager",

           "Method=POST",

           "TargetFrame=",

           "RecContentType=text/html",

           "Mode=HTML",

           ITEMDATA,

………

LAST);

     if  (atoi(lr_eval_string("{KL_Count}")) > 0){

         lr_end_transaction("01_国内证_01_信用证开立", LR_PASS);

}

else{

         lr_error_message ("信用证开立CONFIRM Fail!【放贷流水号:%s】【信用证编号:RLC98042014%s】", lr_eval_string("{p_CL_FD_NO_HN}"),lr_eval_string("{p_LC_NO}"));

     lr_end_transaction("01_国内证_01_信用证开立", LR_FAIL);

     lr_exit(  LR_EXIT_ITERATION_AND_CONTINUE,LR_FAIL );

     }

处理代码分析如下:

(1) web_reg_find的使用

仅使用web_reg_find的保存预期检查点的个数的功能,如果找不到检查点,检查点的个数将被存为0,而不会启用LR函数抛出错误机制,不影响脚本代码的执行。

该案例为查找预期字段“TransactionCompleted”并将其个数存放在参数变量“KL_Count”。

(2) atoi(lr_eval_string("{KL_Count}"))

将获取的参数“KL_Count”值转化为字符串后再转化为整数,用与if语句的表达式中。

(3)  if-else

 if(atoi(lr_eval_string("{KL_Count}"))> 0)代表预期检查点在搜索页面中被找到情况。

该例子中找到预期检查点的处理为:使用函数lr_end_transaction("01_国内证_01_信用证开立", LR_PASS)定义所在事务通过。

备注:定义事务成功或失败,需根据具体预期内容和业务结合而定

else代表预期检查点在搜索页面中未找到情况。

该例子中未找到预期检查点的处理步骤为:

1)     使用函数lr_error_message抛出错误详细信息;

输出详细的错误信息:出错步骤、放贷流水号和信用证编号,这样直接获取出错对应的测试数据有助于在压力执行过程中快速分析定位问题

2)     使用函数lr_end_transaction("01_国内证_01_信用证开立", LR_FAIL)定义所在事务运行失败;

3)     使用函数lr_exit(  LR_EXIT_ITERATION_AND_CONTINUE,LR_FAIL )定义出现错误后的处理。

该函数优先级大于continue on error的设置。若脚本需要失败后继续错误所在Action中的后续操作,不需要使用该函数。本案例的处理选项:Vuser离开本次迭代继续下次迭代的执行。

备注:步骤1)lr_error_message和2)lr_end_transaction两个函数的功能可以简化使用一个函数lr_fail_trans_with_error来实现。对预期检查点未找到的情况进行抛出错误信息并定义所在事务运行失败。

if (atoi(lr_eval_string("{KL_Count}")) <= 0){

         lr_fail_trans_with_error("信用证开立CONFIRM Fail!   【放贷流水号:%s】【信用证编号:RLC98042014%s】", lr_eval_string("{p_CL_FD_NO_HN}"),lr_eval_string("p_LC_NO}"));

         lr_exit(    LR_EXIT_ITERATION_AND_CONTINUE,LR_FAIL );

     }

lr_end_transaction("01_国内证_01_信用证开立", LR_AUTO);

》》》推荐阅读《《《

1、性能测试学习笔记-场景设计

2、Web站点性能调优完全攻略

3、应用系统性能调优之性能分析

4、Windows监控——性能指标详解

6、性能测试的重要意义

7、软件性能测试的本质_致命版

8、性能分析流程及方法

9、性能测试流程

10、性能测试从需求分析开始

11、性能测试指标

12、双活数据中心揭秘之—DB2 PureScale

13、循序渐进学习oracle

14、软件项目管理中的十个误区

15、功能测试方法总结及常见面试问题

16、MQ来账通道及队列配置

17、Linux命令大全整理

18、JMeter工具简单介绍

19、性能瓶颈分析方法

20、性能测试-LoadRunner操作流程之一

22、性能测试-LoadRunner操作流程之二

23、性能测试-LoadRunner操作流程之三

24、性能测试-脚本编写之一

25、性能测试-脚本编写之二

26、性能测试-脚本编写之三

27、性能测试-性能调优之一

28、性能测试-性能调优之二

d84bd4409de589d5ad8be7d515ef71d8.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值