Web Service性能测试脚本的一些经验教训

来源:百度文库 编辑:神马文学网 时间:2024/04/27 13:32:51

今天因为要做接口的性能测试,所以录制了个web service的脚本。过程中有些教训,值得记录一下。

  录制完脚本,像往常一样,给脚本增加了手动关联的函数去获取接口的返回值,并没有用web service自带的去获取返回值。脚本如下:

   web_reg_save_param("returnCode",
        "LB=HTTP\/1.1",
        "RB=OK",
        "Ord=1",
        "NotFound=ERROR",
        LAST);

    web_service_call( "StepName=getDownloadKey_102",
        "SOAPMethod=MusicPaymentService.MusicPayment.getDownloadKey",
        "ResponseParam=response",
        "WSDL=http://192.168.104.51:28080/jboss-net/services/MusicPayment?wsdl",
        "UseWSDLCopy=1",
        "Snapshot=t1259034940.inf",
        BEGIN_ARGUMENTS,
        "xml:event=00000222222"
                "333333
{MSISDN}10.10.10."
                "10
"
                "0021010
"
                "123456789012345678
123456789012"
                "03
20"
                "{recieverNumber}"
                "
0000001024"
                "0020001"
                "
",
        END_ARGUMENTS,
        BEGIN_RESULT,
        END_RESULT,
        LAST);

    lr_log_message("returnCode is : %s",lr_eval_string ("{returnCode}"));

  回放的时候就出问题了,总是报“Warning: The string 'returnCode' with parameter delimiters is not a parameter.”的错误,日志输出也是“returnCode is :{returnCode}”。

开始的时候我以为输出日志的函数出了问题,检查了几遍脚本也没发现什么错误。后来才想起来这个warning是参数获取不成功的提示(一天不用手生啊.....)。于是用web service本身的设置去获取returnCode,如图:

  这下再运行脚本,果然,没有获取到参数。于是再修改下设置,如上啊开图一般,把整个返回的信息作为参数输出,结果很明了了,LR获取的接口返回信息,因为downURL里的特殊字符而没有获取完全,LR获取到的返回信息里根本就没有returnCode........

  有了这次的教训,以后对于web Service,还是用他自带的获取参数的方式全部获取出来看看......不然白白浪费时间......

  小贴士:只有切换到树状图脚本时,在树节点上点击右键,选择属性,才能打开脚本属性的设置页面: