在 LoadRunner 脚本中做关联 (Correlation)
(q]`x0@;f ve9^0当录制脚本时,VuGen会拦截client端(浏览器)与server端(网站服务器)之间的对话,并且通通记录下来,产生脚本。在VuGen的Recording Log中,您可以找到浏览器与服务器之间所有的对话,包含通讯内容、日期、时间、浏览器的请求、服务器的响应内容等等。脚本和Recording Log最大的差别在于,脚本只记录了client端要对server端所说的话,而Recording Log则是完整纪录二者的对话。51Testing软件测试网!bA$I
s@
51Testing软件测试网/_B~J+P}e4b
当执行脚本时,您可以把VuGen想象成是一个演员,它伪装成浏览器,然后根据脚本,把当初真的浏览器所说过的话,再对网站伺服器重新说一遍,VuGen企图骗过服务器,让服务器以为它就是当初的浏览器,然后把网站内容传送给VuGen。51Testing软件测试网Flb)Qz
所以纪录在脚本中要跟服务器所说的话,完全与当初录制时所说的一样,是写死的(hard-coded)。这样的作法在遇到有些比较聪明的服务器时,还是会失效。这时就需要透过「关联(correlation)」的做法来让VuGen可以再次成功地骗过服务器。
何谓关联(correlation)?
Y M9M?0u$g0Grih3U fwq0所谓的关联(correlation)就是把脚本中某些写死的(hard-coded)数据,转变成是撷取自服务器所送的、动态的、每次都不一样的数据。
-FC,k?$s.K:H ]051Testing软件测试网]SwUj举一个常见的例子,刚刚提到有些比较聪明的服务器,这些服务器在每个浏览器第一次跟它要数据时,都会在数据中夹带一个唯一的辨识码,接下来就会利用这个辨识码来辨识跟它要数据的是不是同一个浏览器。一般称这个辨识码为Session ID。对于每个新的交易,服务器都会产生新的Session ID给浏览器。这也就是为什么执行脚本会失败的原因,因为VuGen还是用旧的Session ID向服务器要数据,服务器会发现这个Session ID是失效的或是它根本不认识这个Session ID,当然就不会传送正确的网页数据给VuGen了。51Testing软件测试网4l$C kNn"l
51Testing软件测试网0G!e hQ"\s.Oi下面的图示说明了这样的情形:
V};x'T-ew|051Testing软件测试网|Gs2Nw当录制脚本时,浏览器送出网页A的请求,服务器将网页A的内容传送给浏览器,并且夹带了一个ID=123的数据,当浏览器再送出网页B的情求时,这时就要用到ID=123的数据,服务器才会认为这是合法的请求,并且把网页B的内容送回给浏览器。51Testing软件测试网{|+K TdGV0Q
h/^e7q/l0在执行脚本时会发生什么状况?浏览器再送出网页B的请求时,用的还是当初录制的ID=123的数据,而不是用服务器新给的ID=456,整个脚本的执行就会失败。51Testing软件测试网M8N1z$z?a8G;t$lq,I
51Testing软件测试网$K
K!?,]
o i.x4Uo"r
H%|
要对付这种服务器,我们必须想办法找出这个Session ID到底是什么、位于何处,然后把它撷取下来,放到某个参数中,并且取代掉脚本中有用到Session ID的部份,这样就可以成功骗过服务器,正确地完成整个交易了。
4S6g8bWgUJi3V8o0哪些错误代表着我应该做关联(correlation)?
5H;cs U&Im^u3Z0假如脚本需要关联(correlation),在还没做之前是不会执行通过的,也就是说会有错误讯息发生。不过,很不幸地,并没有任何特定的错误讯息是和关联(correlation)有关系的。会出现什么错误讯息,与系统实做的错误处理机制有关。错误讯息有可能会提醒您要重新登入,但是也有可能直接就显示HTTP 404的错误讯息。51Testing软件测试网 C-ArRbk%h7SwNi
要如何做关联(correlation)?
)kkVL)? p{gi$M0关联(correlation)函数
:_#O
WYN%e2F0关联(correlation)会用到下列的函数:
2S*dR1i L8lv,f-k,l,k0• web_reg_save_param:这是最新版,也是最常用来做关联(correlation)的函数。51Testing软件测试网,G%?[y1x
yg
语法:51Testing软件测试网
\6M[W:w-I9J
web_reg_save_param ( “Parameter Name” , < list of Attributes >, LAST );
a{t8Blh]a0• web_create_html_param、web_create_html_param_ex:这二个函数主要是保留作为向前兼容的目的的。建议使用 web_reg_save_param 函数。
%S(A:v}ff3[?r0详细用法请参考使用手册。在VuGen中点选【Help】>【Function reference】>【Contexts】>【Web and Wireless Vuser Functions】>【Correlation Functions】。51Testing软件测试网{1k#K`"YU
如何找出要关联(correlation)数据51Testing软件测试网Cc-s"G+W(~ JD
简单的说,每一次执行时都会变动的值,就有可能需要做关联(correlation)。51Testing软件测试网.vW9f],|#U#a| h+rH
VuGen提供二种方式帮助您找出需要做关联(correlation)的值:
+b;sVu!Q6mC01. 自动关联51Testing软件测试网:IG~!u
b y
2. 手动关联51Testing软件测试网~kuC Y
自动关联
,\Hs/x
w\9cav0VuGen内建自动关联引擎(auto-correlation engine),可以自动找出需要关联的值,并且自动使用关联函数建立关联。51Testing软件测试网r`;N)O`"D
自动关联提供下列二种机制:51Testing软件测试网-v,A.fH9r D
• Rules Correlation:在录制过程中VuGen会根据订定的规则,实时自动找出要关联的值。规则来源有两种:
{j.@:k)})J0o 内建(Built-in Correlation):
[Ao$FoJ5b8k
qqM0VuGen已经针对常用的一些应用系统,如AribaBuyer、BlueMartini、BroadVision、InterStage、mySAP、NetDynamics、Oracle、PeopleSoft、Siebel、SilverJRunner等,内建关联规则,这些应用系统可能会有一种以上的关联规则。您可以在【Recording Options】>【Internet Protocol】>【Correlation】中启用关联规则,则当录制这些应用系统的脚本时,VuGen会在脚本中自动建立关联。51Testing软件测试网b4^_Cm`
您也可以在【Recording Options】>【Internet Protocol】>【Correlation】检视每个关联规则的定义。51Testing软件测试网k?VQX*tg,D;U
o 使用者自订(User-defined Rules Correlation):
%{K-p:k~r0除了内建的关联规则之外,使用者也可以自订关联规则。您可以在【Recording Options】>【Internet Protocol】>【Correlation】建立新的关联规则。
Jd$r]L2y`&p.g^0• Correlation Studio:有别于Rules Correlation,Correlation Studio则是在执行脚本后才会建立关联,也就是说当录制完脚本后,脚本至少须被执行过一次,Correlation Studio才会作用。Correlation Studio会尝试找出录制时与执行时,服务器响应内容的差异部分,藉以找出需要关联的数据,并建立关联。51Testing软件测试网0eq|Z_3i
Rule Correlation
G
K;VzX*f0请依照以下步骤使用Rule Correlation:51Testing软件测试网T
NR8r3gv
1. 启用auto-correlation51Testing软件测试网.p3? HGD#h,l!B
1. 点选VuGen的【Tools】>【Recording Options】,开启【Recording Options】对话窗口,选取【Internet Protocol】>【Correlation】,勾选【Enable correlation during recording】,以启用自动关联。51Testing软件测试网8NrPO6j
2. 假如录制的应用系统属于内建关联规则的系统,如AribaBuyer、BlueMartini、BroadVision、InterStage、mySAP、NetDynamics、Oracle、PeopleSoft、Siebel、SilverJRunner等,请勾选相对应的应用系统。
j!lE$CI03. 或者也可以针对录制的应用系统加入新的关联规则,此即为使用者自订的关联规则。
(Rij:udM|B04. 设定当VuGen侦测到符合关联规则的数据时,要如何处理:51Testing软件测试网-l-[!Ll0r(G
【Issue a pop-up message and let me decide online】:跳出一个讯息对话窗口,询问您是否要建立关联。51Testing软件测试网"AYo9A)Is
【Perform correlation in sceipt】:直接自动建立关联
(hd+QHt02. 录制脚本51Testing软件测试网KjoGSk}/JD
开始录制脚本,在录制过程中,当VuGen侦测到符合关联规则的数据时,会依照设定建立关联,您会在脚本中看到类似以下的脚本,此为BroadVision应用系统建立关联的例子,在脚本批注部分可以看到关联前的数据为何。
\2d-q!bq}0
%Px |m)H;Ga03. 执行脚本验证关联是OK的。51Testing软件测试网#_Er9H#q a~;?
$\;qqR7X9^+EW0Correlation Studio51Testing软件测试网mP{fCj:k,C QJ`8t
当录制的应用系统不属于VuGen预设支持的应用系统时,Rule Correlation可能既无法发挥作用,这时可以利用Correlation Studio来做关联。51Testing软件测试网?+y*[:X%?(R)L
r}oiZX~2e"|0Correlation Studio会尝试找出录制时与执行时,服务器响应内容的差异部分,藉以找出需要关联的数据,并建立关联。
D8Sb*xfWKGf@4p0]n*a[8D2a8{"E0使用Correlation Studio的步骤如下:
'b@ur#R:q[\8v:P%U051Testing软件测试网%r}C7\H6Nn Fj1. 录制脚本并执行
-prX"\^051Testing软件测试网Co-pg'm|*O.u2O2. 执行完毕后,VuGen会跳出下面的【Scan Action for Correlation】窗口,询问您是否要扫描脚本并建立关联,按下【Yes】按钮。51Testing软件测试网c;B;fy4q)S5Z%MHU
51Testing软件测试网ab\#a)G
3. 扫描完后,可以在脚本下方的【Correlation Results】中看到扫描的结果。51Testing软件测试网x3{k6Do}
4\!]DX"g2U^04. 检查一下扫瞄的结果后,选择要做关联的数据,然后按下【Correlate】按钮,一笔一笔做,或是按下【Correlate All】让VuGen一次就对所有的数据建立关联。51Testing软件测试网:M,~
Pt}
注意:由于Correlation Studio会找出所有有变动的数据,但是并不是所有的数据都需要做关联,所以不建议您直接用【Correlate All】。51Testing软件测试网+M5N3g(I3qCV|'wh
`7C$uJK#hMkS05. 一般来说,您必须一直重复步骤1~4直到所有需要做关联的数据都找出来为止。因为有时前面的关联还没做好之前,将无法执行到后面需要做关联的部份。51Testing软件测试网VSpO-~!^1y ^
51Testing软件测试网%iA6G*x!H/C?v有可能有些需要做关联的动态数据,连Correlation Studio都无法侦测出来,这时您就需要自行做手动关联了。51Testing软件测试网R6Qe[!q-s7g2j
x@d1SoIq0手动关联
R"a~wc5s#D051Testing软件测试网T9FV8QKYn手动关联的执行过程大致如下:
vR9fR/~*p:b051Testing软件测试网8tB#K }4{;^g&h~1. 使用相同的业务流程与数据,录制二份脚本51Testing软件测试网gJ!Ia"lfSP
51Testing软件测试网E*Nf(Q.q_2. 使用WinDiff工具协助找出需要关联的数据
_K}X({-?I9Z0,C}F.S'y8K"p Y03. 使用web_reg_save_param函数手动建立关联51Testing软件测试网%Q!GH\AW7I,[
#fY[o-mk04. 将脚本中有用到关联的数据,以参数取代51Testing软件测试网#JS aM}VbY'n)g
51Testing软件测试网"MR1EN7j6Q+Bqea接下来将详细的说明如何执行每个步骤
GCq8S`aN0BUjwt2y%k!C0使用相同的业务流程与数据,录制二份脚本
&T-f|K&^0Mu;W0u0-?0Ka1B.lS+Xeh {;ef01. 先录制一份脚本并存档。
t(]'w {*|}0%~cdWA6_*cu02. 依照相同的操作步骤与数据录制第二份脚本并存盘。注意,所有的步骤和输入的数据一定都要一样,这样才能找出由服务器端产生的动态数据。
]k ]jq W051Testing软件测试网 o$_H4D@ThL有时候会遇到真的无法使用相同的输入数据,那您也要记住您使用的输入数据,到时才能判断是您输入的数据,还是变动的数据。51Testing软件测试网\W7kJ5fn
51Testing软件测试网B:K(L4D,B \gd使用WinDiff工具协助找出需要关联的数据51Testing软件测试网FJ hc` g#T
51Testing软件测试网#oxqKr `Xp]j'] t1. 在第二份脚本中,点选VuGen的【Tools】>【Compare with Vuser…】,并选择第一份脚本。51Testing软件测试网3Y,Pj8Y |:}h6s
em6w'hz3H`02. 接着WinDiff会开启,同时显示二份脚本,并显示有差异的地方。WinDiff会以一整行黄色标示有差异的脚本,并且以红色的字体显示真正差异的文字。(假如没看到红色字体,请点选【Options】>【View】>【Show Inline Differences】)。51Testing软件测试网!@"}5ngog4i/O
8r"W!n}.R03. 逐一检视二份脚本中差异的部份,每一个差异都可能是需要做关联的地方。选取差异的脚本,然后复制。
1j6S j,cF8UH051Testing软件测试网:~2xk9V-G7CP-k在复制时,有时并不需要取整行脚本,可能只会选取脚本中的一部分。
]%]Hw-FY&D(ty0注意:请忽略lr_thik_time的差异部份,因为lr_thik_time是用来模拟每个步骤之间使用者思考延迟的时间。
2f(^-{^UA'I%e0F0
-M;PI:yx`'Od(B04. 接着要在Recording Log(单一protocol)或是Generation Log(多重protocol)中找这个值。将鼠标光标点到Recording Log的第一行开头,按下Ctrl+F,开启【Find】窗口,贴上刚刚复制的脚本,找出在Recording Log第一次出现的位置。51Testing软件测试网j#FOq-NA
Q
l/F"r-gG:ugq0结果会有二种:
o 在Recording Log中找不到要找的数据,这时请先确认您找对了脚本,毕竟现在开启了二个几乎一样的脚本,很容易弄错。
X&C*k/lY8w&fN051Testing软件测试网7h b8l5m] fo 在Recording Log中找到了要找的数据,这时要确认数据是从服务器端传送过来的。首先可以先检查数据的标头,从标头的Receiving response可以知道数据是从服务器端传送到client端的。假如此数据第一次出现是在Sending request中,则表示此数据是由client端产生,不需要做关联,但是有可能需要做参数化(parameterized)。51Testing软件测试网4n'YU,\O/b0o
(ZN?urS0您要找的标头格式如下:51Testing软件测试网Kzs b{H
8~`&TB$XnU0*** [tid=b9 Action1 2] Receiving response from host astra.merc-int.com:80 ( 25/11/2002 12:04:00 )51Testing软件测试网+MF0bUa"J6L*jE K:~
51Testing软件测试网4NL4u6]]7ok5J\
5. 现在您已经找到录制二次都不一样,而且是由服务器所产生的动态数据了,而此数据极有可能需要做关联。
4S7A~YPl0c8c051Testing软件测试网nB
wH.^0B q
b,J
!@ n~)xG9T&L5l0使用web_reg_save_param函数手动建立关联51Testing软件测试网v1q/Cw4|5h
N*^g x9N!?Uz0在找到是由服务器所产生的动态数据之后,接下来要做的就是找出适当的位置,使用web_reg_save_param函数,将这个动态数据撷取到某个参数中。
~-^ SfS051Testing软件测试网\-{F-ErE"?-cb%Ejl1. 要在哪里使用web_reg_save_param函数?51Testing软件测试网r%CT!Goi6?
F(Cn? Q+UbF0在之前的步骤,我们已经在Execution Log找到可能需要关联的动态数据。在Execution Log中选取动态数据前的文字然后复制,我们将会利用这段文字,来帮助我们找出要关联的动态数据。51Testing软件测试网%x#R&uMl&aW#H
,k+i2PAW-Am4[0不过在这之前我们要先找出使用web_reg_save_param函数的正确位置,所以我们要再重新执行一遍脚本,而且这次会开启所有的Log。51Testing软件测试网H*d,`ZHWSV'f
9t1i,~%a9v;t5d01. 在VuGen中点选【Vuser】>【Run-Time Settings】。
n!h1pqZV5J.H;m051Testing软件测试网y7uo7G*p4k`+T Nd2. 点选【General】>【Log】。51Testing软件测试网u2v&T"Xv[f
51Testing软件测试网$rY3yju|-afwO3. 勾选【Enable logging】、【Always sends messages】、【Extended log】,以及【Extended log】下的所有选项。
~'b6UAs)N051Testing软件测试网tw-i2`#N6Zh_4. 按下【OK】就可以执行脚本了。51Testing软件测试网+Jr;Ob-[!\&` IrD
51Testing软件测试网^mQs$K7rfh执行完脚本之后,在Execution Log中搜寻刚刚复制的字符串。找到字符串后,在字符串前面会有A.tion1.c(7),这个7就是到时候要插入web_reg_save_param函数的位置,也就是要插入到脚本的第7行。51Testing软件测试网9PD [$l!p
3P[1^(IlE9j!a'p0在脚本的第7行前插入一行空白行,然后输入51Testing软件测试网)n?%x*i)v#axmt)i^
{ Vi!P1b\"`G0Z0web_reg_save_param(“UserSession”,51Testing软件测试网r`` G
g
“UserSession” 这个 “UserSession” 就是到时要使用的参数名称,建议给个有意义的名字。51Testing软件测试网4|ct)a([*Z*P
注意:到这里整个web_reg_save_param函数还没完成。
4M8x-D9TE~!Q A0
FR:`+m:o02. 找出web_reg_save_param中要用到的边界51Testing软件测试网uV1^R^p
web_reg_save_param函数主要是透过动态数据的前面和后面的固定字符串,来辨识要撷取的动态数据的,所以我们还需要找出动态数据的边界字符串。51Testing软件测试网3PU^l]}~
51Testing软件测试网7j mv,G6t&d.T找出左边界字符串
X7TV7s X(dp/y0%I2US](C.~1_s)n0再回到Execution Log中,选取动态数据前的字符串并且复制它。
)O7l4C sx2A;\l|051Testing软件测试网!R C;OB6K?$~n;e这时会有个问题,到底要选取多少字符串才足以唯一识别要找的动态数据呢?建议是越多越好,但是尽量不要包含到特殊字符。51Testing软件测试网1^} uc0~5bvYYt!u
;op"P9T R;RVL0在这边我们选取「input type=hidden name=userSession value=」字符串。选好之后,还要再确认一次这段字符串真的是可以唯一识别的,所以我们在Execution Log中透过Ctrl+F的搜寻,找找看这段字符串是否可以找到要找的动态数据。假如找不到,web_reg_save_param函数还有个ORD参数可以使用,ORD参数可以设定出现在第几次的字符串才是要找的字符串。51Testing软件测试网VIKp~0E,K
51Testing软件测试网t M\&C)}+`og将这个边界字符串加到未完成的web_reg_save_param函数中:51Testing软件测试网rq[X,F6EK
51Testing软件测试网b^fGi+@web_reg_save_param(“UserSession”, “LB= input type=hidden name=userSession value=”,51Testing软件测试网)A,@4sD$g3xt
3}yR.Y"x$`0找出右边界字符串51Testing软件测试网1]5OYz,[S(_%TP:@_
51Testing软件测试网G(Y9DHq]Eg/zT#z接下来要找出动态数据的右边界字符串,这个字符串就比较好找了,从动态数据的最后一个字符开始,通常就是我们要找的右边界字符串了。51Testing软件测试网xX4J#Y&piy$d"h&a
9~7D
wqa2z0以这个例子来看,就是「>」,所以再把右边界字符串加入,web_reg_save_param函数中,这时web_reg_save_param函数已经快完成了。最后再加上「LAST);」就完成整个web_reg_save_param函数了。51Testing软件测试网)i:\3x2?)Xe,b
r
web_reg_save_param(“UserSession”, “LB= input type=hidden name=userSession value=”, “RB=>”, LAST);51Testing软件测试网qU{4N w[u
{4bA"M4o NW0将脚本中有用到关联的数据,以参数取代
$tX9I,~B? ^c0当使用web_reg_save_param建立参数后,接下来就是用“UserSession”参数去取代脚本中写死的(hard-coded)资料。
e1JS&O/[0A+]9d05b$S1K,H}?#^eD[%q8?0范例:51Testing软件测试网$L%He%r5MA)X(Re
A,J)r z8K:Wi0将51Testing软件测试网Y7vUD+s[^C}8pW
“Name=userSession”, “Value=75893.0884568651DQADHfApHDHfcDtccpfAttcf”, ENDITEM,51Testing软件测试网O ~(T9?a
换成51Testing软件测试网&s1n%n`
N-i3jK[
“Name=userSession”, “Value={UserSession}”, ENDITEM,51Testing软件测试网h7YYp+`/pD
51Testing软件测试网Q8vU$v;P}z c
到这里您已经完成了一个关联了,接下来就是执行脚本,是否能成功运行,假如还是有问题,就要检查看看是否还需要再做另一个关联。