开发者社区> 余二五> 正文
阿里云
为了无法计算的价值
打开APP
阿里云APP内打开

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,如需转载请自行联系原作者

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
全方位解读服务网格(Service Mesh)的背景和概念
为了解决微服务框架的侵入性问题,我们引入服务网格。
1237 0
PolarDB 并行查询的前世今生
本文会深入介绍PolarDB MySQL在并行查询这一企业级查询加速特性上做的技术探索、形态演进和相关组件的实现原理,所涉及功能随PolarDB MySQL 8.0.2版本上线。
498 0
企业内部应用接入钉钉获取部门及人员信息
企业内部应用接入钉钉,同时通过API获取当前企业下部门及人员信息
1180 0
MySQL模糊查询再也用不着 like+% 了!
我们都知道 InnoDB 在模糊查询数据时使用 "%xx" 会导致索引失效,但有时需求就是如此,类似这样的需求还有很多,例如,搜索引擎需要根基用户数据的关键字进行全文查找,电子商务网站需要根据用户的查询条件,在可能需要在商品的详细介绍中进行查找,这些都不是B+树索引能很好完成的工作。 通过数值比较,范围过滤等就可以完成绝大多数我们需要的查询了。但是,如果希望通过关键字的匹配来进行查询过滤,那么就需要基于相似度的查询,而不是原来的精确数值比较,全文索引就是为这种场景设计的。
25670 0
阿里云云原生一体化数仓正式发布  助力企业数据驱动业务创新
云原生一体化数仓是集阿里云大数据产品MaxCompute、DataWorks、Hologres三种产品能力于一体的一站式大数据处理平台。核心是3个一体化和全链路数据治理能力,包括离线实时一体、湖仓一体、分析服务一体、全链路数据治理。
1605 0
全面公测|Grafana服务:一张图表胜过千行指标&日志
Grafana 帮助运维人员轻松处理各类运维过程中遇到的各类数据可视化与分析难题。目前阿里云 Grafana 服务全面免费公测,帮助企业轻松构建运维数据可视化平台,轻松实现数据驱动运维!
1148 0
一起学Golang系列(五)初次接触Go语言可能遇到的各种坑!
前面介绍了Go语言的基础语法,所谓磨刀不误砍柴工,希望大家还是能熟悉掌握这些基础知识,这样后面真正学起Go来才会得心应手。 作为初学者。Go语言的语法有些和java类似,但也有很多不一样的地方。刚开始都会遇到各种各样的坑。下面就来总结下学习go语言的过程中,遇到的各种坑。
1021 0
设备接入--海康摄像头SDK
springboot-对接海康摄像头,兼容window和Linux环境
1332 0
Flink SQL 在快手的扩展和实践
快手实时计算团队技术专家张静、张芒在 FFA 2021 的分享
1139 0
无影云桌面,企业与个人的应用神器
阿里云无影云桌面( Elastic Desktop Service)的原产品名为弹性云桌面,融合了无影产品技术后更名升级。它可以为您提供易用、安全、高效的云上桌面服务,帮助您快速构建、高效管理桌面办公环境,提供安全、灵活的办公体系。
276290 0
+关注
20377
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
低代码开发师(初级)实战教程
立即下载
阿里巴巴DevOps 最佳实践手册
立即下载
冬季实战营第三期:MySQL数据库进阶实战
立即下载