sockt-浅谈接口性能测试脚本编写
平时我们做的都是http请求的接口测试,初次接触socket接口还是有点不知如何下手,其实他如http接口请求区别并不是很大,也是接口的链接-发送数据-断开连接这三大步骤来实现:
以下文章转载自:http://lovesoo.org/how-to-use-loadrunner-to-write-socket-protocol-script.html 因为其介绍的更为形象,便于理解
本文主要介绍使用LoadRunner手工编写Windows Socket协议测试脚本的方法。
通过LoadRunner编写Windows Socket协议测试脚本,总体说来,比较简单。就像把大象放进冰箱一样,总共分三步:
第一步:把冰箱门打开
//建立到服务端的连接
rc =    lrs_create_socket("socket0", "TCP", "LocalHost=0", "RemoteHost=128.64.64.23:8988", LrsLastArg);
if (rc==)
       lr_output_message("Socket  was successfully created ");
else
       lr_output_message("An error occurred while creating the socket, Error Code: %d", rc);
第二步:把大象装进去
lrs_send("socket0", "buf0", LrsLastArg);   //往"socket0"发送"buf0"中的数据lrs_receive("socket0", "buf1", LrsLastArg);//将"socke0"中返回的数据存放到"buf1"中
第三步:把冰箱门带上
/关闭连接
lrs_close_socket("socket0");
整个脚本关键是在第二步,要把这么一头大象装到冰箱里可不是件容易的事情,我们要对传送的数据做一些处理才行。LR会把你发送的数据包内容写到data.ws这个文件中,那么我们在此也同样应该把数据写到data.ws中去。假设我要发送的是“00100312303456”这一串字符,那么我就直接把它写到data.ws中,脚本如下:
;WSRData send buf0 "" //注意要加""
recv buf1
-
运行脚本,可以看到执行成功。在日志信息中可以打印出发送的BUFFER和接收到的BUFFER内容。
接下来,我们要对发送的字符串进行参数化,让脚本每次发送的字符串都不一样,怎么做呢?有两种方法可以实现:
直接参数化。在data.ws中直接进行参数化,要注意的是默认的参数名称符号是尖括号(<>),和HTTP协议的大括号({})不同。脚本如下:
send buf0 "<string>" //string是自定义的参数名
第二种方法则麻烦一点,下面重点做个介绍。
事情是这样的:如果我要发送的数据是很通过简单的方法拼接起来,最简单的例子,如“用户名(假设是123)+密码(假设是456)”,在这种情况下,使用第一种方法就够用了,我可以设置两个参数<username>和<password>,写成下面的方式就可以了。
send buf0
"<username><password>"
但是情况稍微复杂一些,发送的数据格式还需要加上字符串的长度,比如在上面的例子中,需要这样表示:00100312303456。
前四位0010是表示后面发送的字符串总长度是10,后面的03则表示用户名有3位,再后面的123才是真正的用户名,再后面的03456也是同样的道理。而每次发送的用户名长度不同,字符串也就不同,比如用户名如果是1234,那么我的报文就应该是这样“001104123403456”这样一来,我就不能通过简单地拼接的方式来发送了,而需要再对它进行一些处理:
char data[];
char length[]; len = strlen(lr_eval_string("{usermame}")); sprintf(length,"%d",len); strcat(data,length); strcat(data,"{username}"); //然后,再通过lrs_save_param_ex函数把该数据保存到data_param参数中。 lrs_save_param_ex("socket0", "user", data, , strlen(data),NULL, "data_param"); //最后,在data.ws文件中使用data_param参数发送数据包: send buf0 "<data_param>"
下面是一个完整的:
#include "lrs.h" Action()
{
//存放通信返回报文
char * ActualBuffer = "";
int resCnt = -;
int revCode = -;
int rc = ;
//建立连接
rc = lrs_create_socket("socket0", "TCP", "RemoteHost=192.168.1.97:60000", LrsLastArg);
//连接是否成功,成功为0,失败返回1
if (rc != ) return ;
//事务
lr_start_transaction("pos");
lrs_send("socket0", "buf0", LrsLastArg); //往"socket0"发送"buf0"中的数据
// lrs_disable_socket("socket0", DISABLE_SEND);
lr_think_time(0.005); //lr_log_message("url: %s", LrsLastArg);
// lrs_set_receive_option(EndMarker, StringTerminator , "}");//读取直到"}"符号出现
//lrs_set_receive_option(EndMarker, BinaryStringTerminator, "risk_tactic");//读取直到"risk_tactic"符号出现
//lrs_set_recv_timeout(30,0);//建立连接后,只接收数据1秒加10毫秒后停止接收。1单位是秒,10单位是毫秒 // Peek at the incoming data. The data is copied into the buffer but is not removed from the input queue.(lrs_receive only) revCode = lrs_receive("socket0", "buf1", "Flags=MSG_PEEK", LrsLastArg); //将"socke0"中返回的数据存放到"buf1"中
lrs_disable_socket("socket0", DISABLE_SEND);
//lrs_disable_socket("socket0", DISABLE_RECV);
lrs_disable_socket("socket0", DISABLE_SEND_RECV); if(revCode == || revCode == || revCode==){
lrs_get_last_received_buffer("socket0" , &ActualBuffer, &resCnt);//获取最后返回的缓冲区的数据及其长度
lrs_free_buffer(ActualBuffer);
if(resCnt > ){
lr_end_transaction("pos", LR_PASS);
}else{
lr_end_transaction("pos", LR_FAIL);
}
/*
lr_log_message("----------- revCode: %d", revCode);
lr_log_message("----------- ActualBuffer: %s", ActualBuffer);
lr_log_message("----------- resCnt: %d", resCnt);
*/
}else{
// lr_error_message("----------- revCode: %d", revCode);
lr_end_transaction("pos", LR_FAIL);
} lrs_close_socket("socket0"); //关闭socket
//lrs_cleanup(); //lrs_cleanup 终止Windows套接字 DLL 的使用 return ;
}
数据:
;WSRData
send buf0 "{\"*****\":1,\"******\":<trans_type>,\"*******\":\"<channelid>\",\"*****\":\"<trans_code>\",\"afa_serial\":\"1\",\"bank_serial\":\"\",\"card_type\":1,\"media_type\":0,\"msgtype\":\"7856\",\"field2\":\"<field2>\",\"field3\":\"<field3>\",\"field4\":<field4>,\"field7\":\"<NewParam>\"}" recv buf1
-
sockt-浅谈接口性能测试脚本编写的更多相关文章
- Loadrunner Webservice接口性能测试脚本编写优化总结
		本文主要介绍使用Loadrunner Webservice接口性能测试脚本编写及优化总结. 1.Webservice协议脚本编写流程 下面介绍使用Loadrunner 11调用Webservice接口 ... 
- loadrunner 接口性能脚本编写(Get请求和Post请求)
		前段时间接触了一下loadrunner的接口性能测试,然后尝试了一下手动编写脚本,毕竟录制这种东西,不是每次都能通的,而且录制下来的脚本,通常是有很多其他杂七杂八的请求夹杂在中间,没有达到真正的压测接 ... 
- 基于LR的HTTP协议接口性能测试脚本实例
		背景介绍 XXX项目性能测试中新增业务场景:XX设备的在线激活,因为存在多用户同时在线激活,故需进行性能测试以确认后台服务器系统在多用并发时功能是否正常,性能指标是否满足规格要求.用户使用场景为用户通 ... 
- loadrunner http协议性能测试脚本编写
		性能测试其实测的就是接口的性能,不管是用工具录制还是自己写,都是围绕接口的,录制也是把接口录制下来而已,但是录制下来的脚本比较乱,会把很多相关的请求都录下来. 在这里我们手动写HTTP协议的get.p ... 
- 浅谈web服务器的编写之http协议
		本书是介绍怎么编写一个Web服务器,而Web服务器是基于HTTP(HyperText Transfer Protocol)协议实现的,所以要实现一个Web服务器就必须了解HTTP协议,本章主要介绍HT ... 
- C# 浅谈接口的优势
		总结了一下接口的小优势,可以便于新手理解为什么要用接口,用接口有什么好处. 1.接口的定义: 关键字:interface,接口名一般大写I开头,接口中定义方法,但是不实现方法 interface IB ... 
- 浅谈Verilog HDL代码编写风格
		消失了好久,没有写文章,也没有做笔记,因为最近再赶一个比赛,时间很紧,昨天周六终于结束了,所以趁着周末这会儿有时间,写点东西,记录下来.首先我学习FPGA才一年多,我知道自己没有资格谈论一些比较深层次 ... 
- Rommel - C# 浅谈 接口(Interface)的作用
		鉴于网上太多太多的对C# 接口的误解,想来想去还是自己做一个完美的接口 篇章 继承"基类"跟继承"接口"都能实现某些相同的功能,但有些接口能够完成的功能是只用基 ... 
- C# 浅谈 接口(Interface)的作用
		继承"基类"跟继承"接口"都能实现某些相同的功能,但有些接口能够完成的功能是只用基类无法实现的 1.接口用于描述一组类的公共方法/公共属性. 它不实现任何的方法 ... 
随机推荐
- javaScript_BOM浏览器对象模型
			BOM:浏览器对象模型 Browser Object Model 用来访问和操作浏览器窗口,使JavaScript有能力与浏览器对话 通过使用BOM ,可以移动窗口,更改状态栏.执行其他不与页面内容发 ... 
- xlua 原理
			基于版本 104 可以直接在lua访问c#函数原理: CS 是一个table,设置了一个__index函数,如果访问不存在的成员的时候,会走__index函数,调用import_type从C#中找到具 ... 
- JS-语句四
			For 循环: for 循环是创建循环时常会用到的工具. 下面是 for 循环的语法: ; 语句 ; 语句 ) { 被执行的代码 } 其中语句1是初始值:语句2是.条件判断:语句3是状态改变:被执行的 ... 
- UVA 127 链表和栈的使用
			刘汝佳的题目感觉都是比较难以处理的,就像这道题目,一看数据简直觉得头大...加上这个英文我也看的想死 最后看别人博客的题意讲解才知道原来是要移牌. 然后如果熟练的使用stack和手写链表的话,这个题目 ... 
- findbugs报OBL_UNSATISFIED_OBLIGATION_EXCEPTION_EDGE的修改实例
			先看出问题的一段代码 public void encode(String xxxPath, String thumbTmpPath, String imageType) { LOGGER.info(& ... 
- flask前后端数据交互
			1.后端如何得到前端数据1)如果前端提交的方法为POST:后端接收时要写methods=[‘GET’,‘POST’]xx=request.form.get(xx);xx=request.form[’‘ ... 
- Opencv从文件中播放视频
			1.VideoCapture()括号中写视频文件的名字,在播放每一帧的时候,使用cv2.waitKey()设置适当的持续时间,太低会播放的很快,太高会很慢,通常情况下25毫秒就行了. 2.获取相机/视 ... 
- 2019.11.18CTFD搭建记录
			### 0x01 实验室纳新,准备在自己服务器搭建个ctfd给新生们玩玩,忙活了一天orz[大一刚开学就搭建过没这么费力啊..] 现在大二了没想到能折腾一天... 直接说下我踩的坑吧,给后来的人们说说 ... 
- STM32F407的Modbus做为主站与从站通讯
			在调试STM32F407的串口Modbus通讯之前,也使用过Modbus通讯,只不过都是在PLC或则昆仑通态的触摸屏上使用直接调用现成的库里面的模块,驱动就可以,相对于STM32来,使用PLC库里面的 ... 
- Springboot注解--@Controller和@RestController的区别
			1.使用@Controller 注解,在对应的方法上,视图解析器可以解析return 的jsp,html页面,并且跳转到相应页面:若返回json等内容到页面,则需要加@ResponseBody注解 2 ... 
