【问题描述】用loadrunner测试ajax框架的系统时,录制回放都没有报错,但是回放后系统中没有产生数据,数据始终不能写入数据库。查了一下原因,应该是录制的脚本不完善的问题,因为JS是在客户端执行的程序,LR只能监控客户机与服务器之前的通信。
【解决方法】: Recording options> HTTP Properites> Advanced > Headers: 选择"Record headers not in list", 然后点ok。重新录制一遍脚本,会发现脚本里多出一些 web_add_auto_header, web_add_header函数。把这些函数中跟ajax相关的,加到原脚本里,重新回放,问题解决。
loadrunner11对网页AJAX的测试
业务流程:用户登录-搜索书籍-预订书籍
其中登录输入用户名和密码;搜索输入书籍名称点击button搜索;预订需要在书籍搜索结果点击书籍后面的request按钮,进入request页面,填写日期相关信息点击提交。
开始计划时,感觉这个脚本是最好录制的,于是把计划排在后面,但是在实际操作中遇到难题。
1.在预订书籍这个事务中,有二次提交数据,第一次是把书籍内容提交到表单,第二次是提交预订日期等信息。但是在这两次提交的数据中,找不到跟书籍有关的任何信息,无法对预订书籍事务进行参数化。
解决方法:
尝试1:对脚本中所有出现书籍名称的字段进行参数化,二个参数运行二次,第一次成功,第二次失败
尝试2:搜索的时候仅搜索出唯一一本书籍,只参数化搜索事务,二个参数运行二次,第一次成功,第二次失败
尝试3:设置loadrunner-record option-HTTP Property-Advanced-Header-Record header not in list. 重新录制,发现脚本多了许多web_add_auto_header,web_revert_auto_header函数,搜索的时候仅搜索出唯一一本书籍,只参数化搜索事务,二个参数运行二次,第一次成功,第二次失败
尝试4:协议选择AJAX,设置loadrunner-record option-HTTP Property-Advanced-Header-Record header not in list。设置参数二次运行二次,均成功。
AJAX预订脚本如下:
//search one book and request this book
lr_start_transaction("search");
lr_think_time(24);
//input book name
web_edit_field("query",
"Snapshot=t4.inf",
DESCRIPTION,
"Type=text",
"Name=query",
ACTION,
"SetValue={title}",
LAST);
//if on search result,this text will display
web_reg_find("Text=No results were found for your search request",
"SaveCount=count2",
LAST);
//click search button
web_button("INPUT_2",
"Snapshot=t5.inf",
DESCRIPTION,
"Type=submit",
"Tag=INPUT",
"ID=search_submit",
ACTION,
"UserAction=Click",
LAST);
if (atoi(lr_eval_string("{count2}"))==0)
{
lr_end_transaction("search", LR_PASS);
lr_output_message("search suss,because %d", atoi(lr_eval_string("{count2}")));
lr_output_message("search title is %s",lr_eval_string("{title}"));
}
else
{
lr_end_transaction("search", LR_FAIL);
lr_error_message("search fail,because %d", atoi(lr_eval_string("{count2}")));
}
//starting request transaction
lr_start_transaction("request");
lr_think_time(10);
web_check_box("listItems",
"Snapshot=t6.inf",
DESCRIPTION,
"Name=listItems",
ACTION,
"Set=ON",
LAST);
//click the request button
web_text_link("Request",
"Snapshot=t7.inf",
DESCRIPTION,
"Text=Request",
ACTION,
"UserAction=Click",
LAST);
lr_think_time(13);
web_list("mainLocationFilter",
"Snapshot=t8.inf",
DESCRIPTION,
"Name=mainLocationFilter",
ACTION,
"Select=Hong Kong Central (*1000000)",
LAST);
lr_think_time(5);
web_edit_field("expirationDate",
"Snapshot=t9.inf",
DESCRIPTION,
"Type=text",
"Name=expirationDate",
ACTION,
"SetValue=2011/08/08",
LAST);
web_reg_find("Text=Transaction Reference Number",
"SaveCount=count3",
LAST);
web_reg_find("Text=Your request has been submitted",
"SaveCount=count4",
LAST);
web_button("INPUT_3",
"Snapshot=t10.inf",
DESCRIPTION,
"Type=submit",
"Tag=INPUT",
"ID=id52",
ACTION,
"UserAction=Click",
LAST);
if (atoi(lr_eval_string("{count3}"))==1&&atoi(lr_eval_string("{count4}"))==1)
{
lr_end_transaction("request", LR_PASS);
lr_output_message("request suss,because %d", atoi(lr_eval_string("{count3}")));
}
else
{
lr_end_transaction("request", LR_FAIL);
lr_error_message("request fail,because %d", atoi(lr_eval_string("{count4}")));
}