LoadRunner动态连接库函数的调用

简介:

选自:《精通软件性能测试与LoadRunner实战》11月份出版

在很多情况下在使用LoadRunner进行性能测试的时候,仅仅凭借系统提供的函数可能无法完成测试任务,此时需要借助自行编写或者第三方提供的动态链接库提供的函数来完成测试任务。例如:一个进销存管理软件,为了提高数据的安全性,系统采用第三方提供的动态连接库(DLL)文件对用户名和用户密码等关键数据进行了3DES加密,为了将明文的用户名和用户密码变为符合3DES密文字符串需要将用户名和密码进行加密,此时就必须在LoadRunner中调用动态链接库文件提供的函数来完成性能测试工作。
在这里结合实例来举一个用Delphi 7编写的简单例子,编写了一个mul函数。函数原型如下:function mul(ainteger;binteger)integer;函数提供两个整数参数,如果第一个参数值大于或者等于100,则函数返回值为-1,否则将第一个参数值和第二个参数值的乘积作为函数的返回值,而后将源代码编译成myfunc.dll文件。
library myfunc;
 
uses
  SysUtils,
  Classes;
 
{$R *.res}
 
function mul(ainteger;binteger)integer;stdcall;
begin
  if (a>=100) then  result=-1;
  result=a*b;
end;
 
exports
   mul;
begin
end.
LoadRunner不仅可以调用自行编写或者第三方提供的动态连接库函数,而且可以调用系统提供的动态连接库函数。在下面的LoadRunner脚本文件中举了两个例子,一个是调用系统函数user32.dll中的MessageBoxA,另一个是调用刚才编写的myfunc.dll中的mul函数。
相应脚本代码:
#include "web_api.h"
 
Action()
{
    int x=10;
    int y=20;
    int z;
       //系统的函数库
       lr_load_dll("user32.dll");
    MessageBoxA(NULL, "测试消息主体!", "系统提示", 0);
       //我自己用delphi编写的函数库
       lr_load_dll("myfunc.dll");
    z=mul(x,y);
    lr_output_message("%d",z);
       return 0;
}
 
运行结果如下:
    首先,系统弹出一个提示框,而后在回放日志中将输出参数及其运行结果,详细信息请参见图317
 
317:动态连接库脚本运行结果
上面演示了一个动态连接库函数调用的例子,在实际测试活动中,大家需要针对不同项目的特点,灵活应用LoadRunner,提高测试效率和质量。
【重要提示】
1.        User.dll动态连接库存放于Windows系统System32目录下。
2.        Myfunc.dll动态连接库可以存放于脚本存放目录下。
3.        如果您想查看一个动态链接库文件中包含的函数,可以使用InspectExe软件,安装InspectExe以后,选择一个动态连接库文件,右键选择“属性”,请参见图318
318user32.dll包含的函数列表




本文转自 fish_yy 51CTO博客,原文链接:http://blog.51cto.com/tester2test/211609,如需转载请自行联系原作者

目录
相关文章
|
测试技术
loadrunner使用socket协议来实现客户端对服务器产生压力实例。(通过发送心跳包,达到连接多个客户端的目的)
#include "lrs.h" vuser_init(){ char *ip; int handler; //编写获取LR分配的Vuser IP函数,将IP保存在ip变量中。 ip=lr_get_vuser_ip(); if(ip) lr_vuser_status_message("the ip address is %s:",ip); else lr_vuser_status_message("IP spooler disabled"); //输出获取到lr分配的ip值。
1071 0
|
Java Linux Shell
Loadrunner通过SSH模拟故障连接
Loadrunner通过Java Vuser和SSH进行Linux连接操作(可以进行Shell调用),利用Shell脚本来关闭和启动指定网卡服务,达到模拟系统故障连接。
1063 0
|
分布式计算 Java 测试技术
通过Loadrunner连接操作Hadoop HDFS
本文以Loadrunner的Java_Vuser脚本为例,来做一次HDFS的文件操作测试,由于LoadRunner 11只支持JDK1.6,所以Hadoop选择的Jar包也只能用Hadoop2.6.0,但是这不影响连接高版本的hadoop-HDFS(本次测试就实现了连接操作hadoop2.7下HDFS)。
867 0
|
分布式计算 Java 测试技术
Loadrunner通过ssh连接linux进行hadoop基准测试
Loadrunner通过ssh连接调用hadoop的测试Jar包进行基准测试,似乎有点讨巧,而且好像实际意义也不是特别大,但是通过这个方法的展示,能够看到Loadrunner的生命力有多大,而且在linux系统测试和开源技术的测试中,也是能够有用武之地,所以本文算是来个抛砖引玉吧。
1449 0
|
测试技术
loadrunner 面向目标的场景load Generator 连接 失败
添加连接的时候,名称用localhost  或 ip
734 0
|
网络协议 测试技术 Windows
Loadrunner 脚本开发-利用loadrunner开发Windows Sockets协议脚本
Loadrunner 脚本开发-利用loadrunner开发Windows Sockets协议脚本
128 0
|
Java 测试技术 Android开发
Loadrunner脚本开发-基于HTTP协议的流媒体视频在线播放服务器性能测试
Loadrunner脚本开发-基于HTTP协议的流媒体视频在线播放服务器性能测试
79 0
|
测试技术
Loadrunner 脚本录制-通过代理录制脚本
Loadrunner 脚本录制-通过代理录制脚本
125 0
|
SQL 关系型数据库 MySQL
Loadrunner脚本优化-参数化之关联MySQL数据库获取数据
Loadrunner脚本优化-参数化之关联MySQL数据库获取数据
68 0