51Testing软件测试论坛

标题: LR中点鼠标做关联(winsock协议)-Zee [打印本页]

作者: Zee    时间: 2007-6-25 21:26
标题: LR中点鼠标做关联(winsock协议)-Zee
今天写一下winsock的关联操作。
以前看过一个文档。在英文版的讲winsock的,其中讲到关联。大致操作是:
1,录制。
2,回放。这里是失败。
3,到data.ws里找需要关联的数据。
4,按F7,打开EBCDIC translation对话框。
5,查找数据的位置及偏移量。
6,到脚本中写函数用:lrs_save_param, lrs_save_param_ex, lrs_save_searched_string,这三个函数。

Notes:winsock的关联函数要写到需要关联的代码行的下面。

说明一下这几个函数:
Lrs_save_param:
int lrs_save_param ( char *s_desc,char *buf_desc, char *param_name, int offset, int param_len);
这个函数保存buffer中的数据到一个参数里。这个函数是用来在脚本中做关联的。
前两个参数是为了指定特定的参数。
在指定活动的socket和buffer之后,需要指定一个参数来保存数据。指定偏移量来显示buffer中数据的偏移量和数据的长度。
保存了参数之后,可以在脚本和数据文件使用它,代替所有需要替代的值。替换时要用选项中的定义的符号来引用。
注意:要从buffer中保存一个编码过的数据到参数中,要用lrs_save_param_ex函数。


lrs_save_param_ex
int lrs_save_param_ex ( char *s_desc, char *type, char *buff, int offset, int length, char *encoding, char *param );
这个函数保存一个buffer或者一个buffer的某一部分到参数中。这个变量指定buffer中某种类型的数据被保存:用户buffer,录制的buffer,或者上一个接收到的buffer.推荐使用在用户数据中。

[这里还没写完。还有另一个函数解释。]




下面说不用这么麻烦的操作的,直接点几下就可以了。

1         录制脚本
这个没什么说的吧。选择协议winsock,这要是也不懂,我建议你去看十遍手册。
我这里录制到的脚本如下:
       lrs_create_socket("socket0", "TCP", "LocalHost=0", "RemoteHost=192.168.1.114:5560", LrsLastArg);
       lrs_send("socket0", "buf0", LrsLastArg);
       lrs_receive("socket0", "buf1", LrsLastArg);
       lrs_create_socket("socket1", "TCP", "LocalHost=0", "RemoteHost=192.168.1.114:5560", LrsLastArg);
       lrs_send("socket1", "buf2", LrsLastArg);
       lrs_receive("socket1", "buf3", LrsLastArg);


相应的data.ws如下:
;WSRData 2 1

send buf0 50
       "OPERTYPE(LOGIN)ACCOUNTNAME(admin)PASSWORD(admin)"

recv buf1 155
       "DATALEN{{155}}000000USERID{{90}}USERNAME{{DMS"
       "\xcf\xb5\xcd\xb3"
       "WEB"
       "\xb2\xe9\xd1\xaf\xd5\xca\xbb\xa7"
       "}}USERDESCRIBE{{"
       "\xba\xfe\xd6\xdd\xb5\xe7\xc1\xa6\xbe\xd6"
       "\\DMS"
       "\xcf\xb5\xcd\xb3"
       "WEB"
       "\xb2\xe9\xd1\xaf\xd5\xca\xbb\xa7"
       "}}DEPARTNAME{{"
       "\xce\xb4\xd6\xaa"
       "}}ADMIN{{0}}CLIENTSESSIONID{{2}}"

send buf2 53
       "CLIENTSESSIONID(2)OPERTYPE(INITDEPARTLIST)"

recv buf3 683
       "DATALEN{{683}}000000XMLDATA{{<?xml version=\"1.0\" encoding=\"GB2312\"?>\n"
       "<!DOCTYPE DepartList>\n"
       "<DepartList>\n"
       ………………………………………………………………………………………………
这里就省略了些数据。反正也看着也晕乎乎的。


这里说明一下,我这里是用GIS系统,需要sessionID关联的。我这上面的代码很简单,在buf1中有一个sessionID,在buf2中send时就用到了它。
2         回放一下
在不关联时回放是一定会有问题的。我回放的结果是:
Virtual User Script started
Starting action vuser_init.
Ending action vuser_init.
Running Vuser...
Starting iteration 1.
Starting action Action.
Action.c(4): lrs_create_socket(socket0, TCP, ...)
Action.c(6): lrs_send(socket0, buf0)
Action.c(8): lrs_receive(socket0, buf1)
Action.c(11): lrs_create_socket(socket1, TCP, ...)
Action.c(13): lrs_send(socket1, buf2)
Action.c(15): lrs_receive(socket1, buf3)
Action.c(15): Mismatch (expected 683 bytes, 42 bytes actually received)
Action.c(17): lrs_create_socket(socket2, TCP, ...)
Action.c(19): lrs_send(socket2, buf4)
Action.c(21): lrs_receive(socket2, buf5)
Action.c(21): Mismatch (expected 34143 bytes, 42 bytes actually received)
Action.c(23): lrs_create_socket(socket3, TCP, ...)
Action.c(25): lrs_send(socket3, buf6)
Action.c(27): lrs_receive(socket3, buf7)
Action.c(27): Mismatch (expected 100 bytes, 42 bytes actually received)
Action.c(29): lrs_create_socket(socket4, TCP, ...)
Action.c(31): lrs_send(socket4, buf8)
Action.c(33): lrs_receive(socket4, buf9)
Action.c(33): Mismatch (expected 134 bytes, 42 bytes actually received)
Action.c(35): lrs_send(socket4, buf10)
Action.c(38): lrs_receive(socket4, buf11)
Action.c(38): Mismatch (expected 17520 bytes, 42 bytes actually received)
Action.c(41): lrs_create_socket(socket5, TCP, ...)
Action.c(43): lrs_send(socket5, buf12)
Action.c(45): lrs_receive(socket5, buf13)
Ending action Action.
Ending iteration 1.
Ending Vuser...
Starting action vuser_end.
Ending action vuser_end.
Vuser Terminated.


主要来看一下蓝色的部分,因为没有关联,服务器是返回了42字节的数据,但是和录制时的数据是不同的。所以会mismatch。这里可以在LOG把Mismatch的值打印出来,不过太长了,我就不打印了。^@^。
3         转到树视图做关联
选择buf1看到数据:
DATALEN{{155}}000000USERID{{90}}USERNAME{{DMS\xcf\xb5\xcd\xb3WEB\xb2\xe9\xd1\xaf\xd5\xca\xbb\xa7}}USERDESCRIBE{{\xba\xfe\xd6\xdd\xb5\xe7\xc1\xa6\xbe\xd6\\DMS\xcf\xb5\xcd\xb3WEB\xb2\xe9\xd1\xaf\xd5\xca\xbb\xa7}}DEPARTNAME{{\xce\xb4\xd6\xaa}}ADMIN{{0}}CLIENTSESSIONID{{2}}


选择CLIENTSESSIONID{{2}}中的2.右击后选择:create parameter。在弹出窗口中。看到默认的是用lrs_save_param,这个函数只能关联固定长度的数据。如果是固定的话,到这里点击一下OK,就关联成功了。LR会自动生成语句并且提示检查其他的需要关联的地方。弹出一个窗口提示。
而我这里的sessionID是动态的值。所以需要选择:extract parameter data using boundaries复选框。这时生成的语句是这样的:
lrs_save_searched_string( "socket0", LRS_LAST_RECEIVED, "Parameter3", NULL, NULL, -1, 152, 1 );


左右边界是NULL空的,这里点击left的浏览,弹出选择左边界的窗口,用鼠标选择:SESSIONID{{,点击Done。
再点击right的浏览,选择}}。
就确定了左右边界了。
这里的语句如下:
lrs_save_searched_string("socket0",LRS_LAST_RECEIVED,"Parameter4","LB/BIN=SESSIONID{{", "RB/BIN=}}", 1, 0, -1);


一路小跑点OK。
弹出提示是否替换所有符合左右边界的值。
点击yes。LR会自动搜索所有需要关联的地方并替换。
再转到脚本视图,看到脚本如下:
lrs_create_socket("socket0", "TCP", "LocalHost=0", "RemoteHost=192.168.1.114:5560", LrsLastArg);
       lrs_send("socket0", "buf0", LrsLastArg);
       lrs_receive("socket0", "buf1", LrsLastArg);   
   lrs_save_searched_string("socket0", LRS_LAST_RECEIVED, "Parameter1", "LB/BIN=SESSIONID{{", "RB/BIN=}}", 1, 0, -1);
lr_output_message("小样还抓不到你!你不就是: %s嘛!",lr_eval_string("{Parameter1}"));   
  
lrs_create_socket("socket1", "TCP", "LocalHost=0", "RemoteHost=192.168.1.114:5560", LrsLastArg);
       lrs_send("socket1", "buf2", LrsLastArg);
       lrs_receive("socket1", "buf3", LrsLastArg);


看蓝色部分。后面一句输出是我加上去的。
这样就关联成功了。
4         再次回放
看到LOG如下:
Virtual User Script started
Starting action vuser_init.
Ending action vuser_init.
Running Vuser...
Starting iteration 1.
Starting action Action.
Action.c(4): lrs_create_socket(socket0, TCP, ...)
Action.c(6): lrs_send(socket0, buf0)
Action.c(8): lrs_receive(socket0, buf1)
Action.c(10): lrs_save_searched_string(socket0, get_last_received_buffer, Parameter1, LB/BIN=SESSIONID{{, RB/BIN=}}, 1, 0, -1)
Action.c(12): 小样还抓不到你!你不就是: 8嘛!
Action.c(14): lrs_create_socket(socket1, TCP, ...)
Action.c(16): lrs_send(socket1, buf2)
Action.c(18): lrs_receive(socket1, buf3)
Action.c(20): lrs_create_socket(socket2, TCP, ...)
Action.c(22): lrs_send(socket2, buf4)
Action.c(24): lrs_receive(socket2, buf5)
Action.c(26): lrs_create_socket(socket3, TCP, ...)
Action.c(28): lrs_send(socket3, buf6)
Action.c(30): lrs_receive(socket3, buf7)
Action.c(32): lrs_create_socket(socket4, TCP, ...)
Action.c(34): lrs_send(socket4, buf8)
Action.c(36): lrs_receive(socket4, buf9)
Action.c(38): lrs_send(socket4, buf10)
Action.c(41): lrs_receive(socket4, buf11)
Action.c(44): lrs_create_socket(socket5, TCP, ...)
Action.c(46): lrs_send(socket5, buf12)
Action.c(48): lrs_receive(socket5, buf13)
Ending action Action.
Ending iteration 1.
Ending Vuser...
Starting action vuser_end.
Ending action vuser_end.
Vuser Terminated.


看,输出了:
Action.c(12): 小样还抓不到你!你不就是: 8嘛!



完。

[ 本帖最后由 Zee 于 2007-6-29 20:26 编辑 ]
作者: ldneliza    时间: 2007-6-25 22:09
沙发一个~
作者: Athenst    时间: 2007-6-25 23:23
板凳一个~
作者: rickyzhu    时间: 2007-6-26 09:38
沙发板凳都被你们占了,我只能作地板了。


顶,我等你这篇文章几个月了,:)
作者: suoyi    时间: 2007-6-26 10:00
高手~~
作者: fish_yy    时间: 2007-6-26 10:45
厉害,佩服!:)
作者: oscarli    时间: 2007-6-26 11:10
sdlkfj2牛
作者: hehemeimei    时间: 2007-6-26 11:40
谢谢Zee版主的无私奉献,希望在以后的工作中能用到。
作者: cedar    时间: 2007-6-26 12:02
支持个
作者: dawee    时间: 2007-6-26 16:12
原帖由 Zee 于 2007-6-25 21:26 发表
今天写一下winsock的关联操作。
以前看过一个文档。在英文版的讲winsock的,其中讲到关联。大致操作是:
1,录制。
2,回放。这里是失败。
3,到data.ws里找需要关联的数据。
4,按F7,打开EBCDIC translation对 ...


关于Winsock协议,到目前为止的工作中还没有遇到过,所以暂时 收藏 起来
作者: Zee    时间: 2007-6-29 18:00
呵呵,这几天没上线,谢谢各位鼓励。sdlkfj6 sdlkfj6
作者: yaqi    时间: 2007-7-26 16:04
看得出胡里胡涂的,不过还是要说谢谢!
作者: sam132333    时间: 2007-8-10 12:20
我连WEB都没搞懂,哭死~~~
作者: aishary    时间: 2007-10-10 18:16
winsocket,我还没接触过,了解一下!
作者: wuyu702    时间: 2008-7-18 10:46
受益匪浅阿 谢谢
作者: 走火    时间: 2008-9-2 17:05
谢谢Zee,受教了~
作者: dragon-pk    时间: 2008-9-3 10:17
zee
我这里有个问题,就是第三步那里转到树视图做关联

为什么我的data.ws转换不到树视图,只能是scipt模式?
作者: wistaria    时间: 2008-11-12 13:59
万分感谢!这一个问题琢磨好久了!
作者: liuqi6773    时间: 2008-11-12 14:48
看不懂,希望以后在工作中能够遇到类似的问题,到时候交流一下,thanks
作者: wistaria    时间: 2008-11-12 15:20
按照楼主说得关联成功,第一次回放成功,
连续进行第二次回放时提示错误,
说是保存参数到变量错误,是什么原因呢?
难道是我哪里做得不对?
有人能赐教吗?
作者: lilna    时间: 2008-11-12 17:10
为什么我做了关联后仍然是Mismatch呢   
作者: lilna    时间: 2008-11-12 17:27
请问楼主是否开了个群 可以加我吗
作者: 云层    时间: 2008-11-12 22:49
留作纪念,很少用winsock
作者: wistaria    时间: 2008-11-13 17:12
原帖由 wistaria 于 2008-11-12 15:20 发表
按照楼主说得关联成功,第一次回放成功,
连续进行第二次回放时提示错误,
说是保存参数到变量错误,是什么原因呢?
难道是我哪里做得不对?
有人能赐教吗?

有人看到吗?可不可以帮忙解决一下呀!重新录制关联了多次,都是相同的错误!
作者: Elaine126    时间: 2008-12-17 17:29
标题: 回复 1# 的帖子
:-),太强了。
::ye::: 谢谢呵~
作者: honghuo1981    时间: 2009-10-13 11:25
谢谢,工作中现在正用到这些东东,谢谢!!!!!!!!!!!
作者: weihuijing123    时间: 2009-10-14 15:06
楼主太强了 先赞一个
收藏着 备用 呵呵
作者: linyucc    时间: 2010-8-25 12:15

版主就是版主!
牛啊!
学了不少
作者: jioajioa    时间: 2010-9-10 10:12
关注,感谢版主,版主真是个大好人
作者: bluetearxie    时间: 2012-2-28 11:43
楼主辛苦了 谢谢指教~~




欢迎光临 51Testing软件测试论坛 (http://bbs.51testing.com/) Powered by Discuz! X3.2