在测试时,我们可以根据文本检查点判断事务是否执行正确。
我们在启动流程时,成功返回:
我们检查这个响应结果是否有。
int i=0;
i=web_reg_find("Text=\":1,\"",
"Search=Body", LAST);web_submit_data("startFlow.ht",
"Action=, "Method=POST", "RecContentType=text/html", "Referer=, "Snapshot=t235.inf", "Mode=HTTP", ITEMDATA, "Name=actDefId", "Value=csqdxn:1:10000027300065", ENDITEM, "Name=defId", "Value=10000027300066", ENDITEM, "Name=businessKey", "Value=", ENDITEM, "Name=runId", "Value=0", ENDITEM, "Name=startNode", "Value=", ENDITEM, "Name=m:jdbcs:xm", "Value=a", ENDITEM, "Name=m:jdbcs:bianma", "Value=", ENDITEM, "Name=formKey", "Value=10000027300052", ENDITEM, "Name=formData", "Value={\"main\":{\"fields\":{\"xm\":\"a\",\"bianma\":\"\"}},\"sub\":[],\"opinion\":[]}", ENDITEM, LAST);if(i==0){
lr_end_transaction("startFlow", LR_PASS); } else{ lr_end_transaction("startFlow", LR_FAIL); }这个代码根据响应判断事务是否成功。
在vuser_gen下这个执行是正确的。
但是在controller下并发执行,发现出现事务错误。
在服务端调试时并没有发现启动流程有报错记录。
在通过问老师,老师让我去打印一下相应的情况,看看日志结果。
代码改成如下:
使用关联,左右边界都为空。
打印响应的内容。
通过打印日志,发现:
Action.c(10): web_set_max_html_param_len was successful [MsgId: MMSG-26392]
Action.c(19): Registering web_reg_save_param_ex was successful [MsgId: MMSG-26390] Action.c(28): Redirecting "http://192.168.1.154:8080/bpmhac/platform/bpm/task/startFlow.ht" (redirection depth is 0) [MsgId: MMSG-26694] Action.c(28): To location "http://192.168.1.154:8080/bpmhac/loginRedirect.ht" [MsgId: MMSG-26693] Action.c(28): Redirecting "http://192.168.1.154:8080/bpmhac/loginRedirect.ht" (redirection depth is 1) [MsgId: MMSG-26694] Action.c(28): To location "http://192.168.1.154:8080/bpmhac/loginRedirect.ht" [MsgId: MMSG-26693] Action.c(28): Redirecting "http://192.168.1.154:8080/bpmhac/loginRedirect.ht" (redirection depth is 2) [MsgId: MMSG-26694] Action.c(28): To location "http://192.168.1.154:8080/bpmhac/login.jsp" [MsgId: MMSG-26693] Action.c(28): web_submit_data("startFlow.ht") was successful, 3124 body bytes, 1072 header bytes [MsgId: MMSG-26386] Action.c(47): output:HTTP/1.1 302 Found Server: Apache-Coyote/1.1 Cache-Control: no-cache Pragma: no-cache Expires: Wed, 31 Dec 1969 23:59:59 GMT Location: http://192.168.1.154:8080/bpmhac/loginRedirect.ht Content-Type: text/html;charset=UTF-8 Content-Length: 0 Date: Fri, 23 Jan 2015 09:24:47 GMT
发现启动流程时,发生了登录跳转。
结合服务器查看,终于找到问题的原因,因为在录制脚本是,都统一使用同一个用户进行登录,服务端有配置了单一用户登录。
意思就是同一个用户,一个时间点只能登录一次,去掉这个限制,再重新测试,结果终于正常了。