LoadRunner 测试 Mysql
准备文件
1. 下载 MySQL LoadRunner libraries。
下载地址:http://files.cnblogs.com/files/xiaoxitest/MySQL_LoadRunner_libraries.zip
2. 可以看到 MySQL LoadRunner libraries 里面有两个文件夹:bin 以及 include。
将 bin 文件夹里的文件拷贝到 LoadRunner 安装路径下的 bin 文件夹下。
将 include 文件夹里的文件全部拷贝到 LoadRunner 安装路径下的 include 文件夹下。
LoadRunner安装路径一般都是 C:\Program Files (x86)\HP\LoadRunner 或者 C:\Program Files \HP\LoadRunner
准备测试用的数据库
新建test数据库
在test数据库下新建表格 people:包含如下3个字段。
id需要勾选自动递增。

简单版
1. 编写 vuser_init文件
//引入mysql lib的h文件
#include "Ptt_Mysql.h" MYSQL *Mconn; vuser_init()
{
#define MYSQLSERVER "xx.xx.xx.xx"//mysql的ip
#define MYSQLUSERNAME "root"//用户名
#define MYSQLPASSWORD "xxxxxx"//密码
#define MYSQLDB "test"//数据库
#define MYSQLPORT "3306"//端口 //引入libmysql的dll
lr_load_dll("libmysql.dll"); //连接mysql
Mconn = lr_mysql_connect(MYSQLSERVER, MYSQLUSERNAME, MYSQLPASSWORD, MYSQLDB, atoi(MYSQLPORT)); return ;
}
Ptt_MySql.h 这个文件是刚刚拷贝到LoadRunner的include文件夹里面的文件之一。
可以打开看到 Ptt_MySql.h 这个文件主要包含3个函数:lr_mysql_connect 、lr_mysql_query、lr_mysql_disconnect。这都是我们后边要用到的,所以拿出来放到 vuser_init() 初始化函数之前 。
然后就是定义连接数据库所需要的东西:IP、用户名、密码等。通过下面的 lr_mysql_connect()函数来连接数据库。
连接数据库前,需要加载 libmysql.dll 文件。
2. 编写action文件
Action()
{ char chQuery[];
int result; //把字符存到chQuery[]中
sprintf(chQuery, "INSERT INTO people (username,password) VALUES('user11','111111')"); //执行sql
result = lr_mysql_query(Mconn, chQuery); if(result == ){
lr_output_message("insert 成功");
}
else{
lr_error_message("insert 失败");
} return ;
}
这里进行的是插入操作。
数据库常见的增删改查,这里只需要把 sprintf里面的字符串替换掉就可以。
3. 编写vuser_end文件
vuser_end()
{
//关闭数据库连接
lr_mysql_disconnect(Mconn);
return ;
}
这里就是关闭数据库连接。
复杂版
1. 编写 vuser_init文件
这里添加了一些文件是否存在的验证,以及多次连接Mysql 的尝试。
#include "Ptt_Mysql.h"
#include "mysql.h"
#include "mysql_com.h"
#include "mysql_time.h"
#include "mysql_version.h"
#include "typelib.h"
#include "my_list.h"
#include "my_alloc.h" #define MYSQLSERVER "localhost"
#define MYSQLUSERNAME "root"
#define MYSQLPASSWORD "xxxxxx"
#define MYSQLDB "test"
#define MYSQLPORT "3306" int statu=;
MYSQL *Mconn;
int conn_fail=, conn_iter=; vuser_init()
{
// Load libmysql.dll
int rc;
rc = lr_load_dll("libmysql.dll");
if (rc != ) {
lr_error_message("Could not load libmysql.dll");
lr_abort();
} lr_start_transaction("mysql_connection"); //Initialise MySQL
if(!(Mconn = mysql_init(NULL)))
{
lr_message("Error -1: Cannot initialize MySQL - %s", mysql_error(Mconn));
statu = ;
lr_end_transaction("mysql_connection", LR_FAIL);
} do{
// Connect to database
if (!mysql_real_connect(Mconn, MYSQLSERVER, MYSQLUSERNAME, MYSQLPASSWORD, MYSQLDB, atoi(MYSQLPORT), NULL, ))
{
conn_fail = -;
conn_iter++;
sleep();
}
else
conn_fail = ;
}
while(conn_fail < && conn_iter < ); if (conn_fail < )
{
lr_message("Error : %s", mysql_error(Mconn));
statu = ;
lr_end_transaction("mysql_connection", LR_FAIL);
return -;
}
else
{
lr_message("MySql - Good Connection");
statu = ;
lr_end_transaction("mysql_connection", LR_PASS);
} return ; }
2. 编写 Action_insert 文件
这里尝试向 people表格插入一条数据。
可以看到这里使用的数据是直接从 参数文件读取的,所以需要事先建立好参数 user 以及 pwd。
Action_insert()
{
if(statu)
{
char chQuery[];
int status=; lr_start_transaction("mysql_insert"); lr_output_message("The parameter user is : %s",lr_eval_string("{user}"));
lr_output_message("The parameter password is : %s",lr_eval_string("{pwd}"));
sprintf(chQuery, "INSERT INTO people (username,password) VALUES('%s','%s')",lr_eval_string("{user}"),lr_eval_string("{pwd}")); status = lr_mysql_query(Mconn, chQuery); if(status!=)
{
lr_end_transaction("mysql_insert",LR_FAIL );
}
else
{
lr_end_transaction("mysql_insert", LR_PASS);
}
}
return ;
}
3. 编写 Action_update 文件
Action_update()
{
if(statu)
{
char chQuery[];
int status=; lr_start_transaction("mysql_update"); lr_output_message("The parameter user is : %s",lr_eval_string("{user}"));
lr_output_message("The parameter password is : %s",lr_eval_string("{pwd}"));
sprintf(chQuery,"UPDATE people SET password = '123456789' WHERE username='%s'",lr_eval_string ("{user}")); status = lr_mysql_query(Mconn, chQuery); if(status!=)
{
lr_end_transaction("mysql_update",LR_FAIL );
}
else
{
lr_end_transaction("mysql_update", LR_PASS);
}
}
return ;
}
4. 编写 Action_select 文件
查询出来的结果保存在多维数组中,可以使用 row[][].cell 来获取数据。
Action_select()
{
if(statu)
{
char chQuery[];
int status=; lr_start_transaction("mysql_select"); lr_output_message("The parameter user is : %s",lr_eval_string("{user}"));
lr_output_message("The parameter password is : %s",lr_eval_string("{pwd}"));
sprintf(chQuery,"SELECT username,password FROM people WHERE username='%s'",lr_eval_string("{user}")); status = lr_mysql_query(Mconn, chQuery); lr_save_string(row[][].cell,"user1");
lr_save_string(row[][].cell,"pw1"); lr_output_message(lr_eval_string("User:{user1}"));
lr_output_message(lr_eval_string("Password:{pw1}")); if(status!=)
{
lr_end_transaction("mysql_select",LR_FAIL );
}
else
{
lr_end_transaction("mysql_select", LR_PASS);
}
}
return ;
}
5. 编写 Action_delete 文件
Action_delete()
{
if(statu)
{
char chQuery[];
int status=; lr_start_transaction("mysql_delete"); lr_output_message("The parameter user is : %s",lr_eval_string("{user}"));
lr_output_message("The parameter password is : %s",lr_eval_string("{pwd}"));
sprintf(chQuery, "DELETE FROM people WHERE username='%s'",lr_eval_string("{user}")); status = lr_mysql_query(Mconn, chQuery); if(status!=)
{
lr_end_transaction("mysql_delete",LR_FAIL );
}
else
{
lr_end_transaction("mysql_delete", LR_PASS);
}
}
return ;
}
6. 编写 vuser_end 文件
vuser_end()
{
lr_mysql_disconnect(Mconn);
return ;
}
LoadRunner 测试 Mysql的更多相关文章
- Jememeter和Loadrunner测试MySQL性能
From:http://blog.csdn.net/testingstar/article/details/60579454 MySQL数据库性能测试的方法 前置条件: 安装系统:windows 7 ...
- 老李分享:loadrunner操作mysql数据库
老李分享:loadrunner操作mysql数据库 在poptest测试开发工程师就业培训的课程中,针对一套商业系统进行性能测试,目标是mysql后台数据库的负载能力,在这里我把测试代码 ...
- Loadrunner测试数据库性能,测试SQL语句的脚本例子
Loadrunner与SQL Server的操作可以通过录制的方式来实现,但本文还是通过直接调用loadrunner本身的function来实现sql语句的操作, 主要用到的是lr_db_connec ...
- LoadRunner测试结果分析03 转载至zhangzhe的新浪博客
LoadRunner测试结果分析之我见 前面分析的Web Resource(网络资源)的测试情况,其主要关注的是服务器性能,而系统本身和环境都有可能存在问题,页面诊断(Web Page Diagnos ...
- LoadRunner测试结果分析02 转载至zhangzhe的新浪博客
LoadRunner测试结果分析之我见 上述测试过程的重点在于事务,而LoadRunner生成的测试结果图并不局限于事务上,其中还有是关于Vusers.Errors.Web Resources.Web ...
- LoadRunner测试结果分析01 转载至zhangzhe的新浪博客
LoadRunner测试结果分析之我见 LoadRunner生成测试结果并不代表着这次测试结果的结束,相反,这次测试结果的重头戏才刚刚开始.如何对测试结果进行分析,关系着这次测试的成功与否.网上关于L ...
- LoadRunner测试场景中添加负载生成器
如何在LoadRunner测试场景中添加负载生成器 本文对如何在LoadRunner的测试场景中添加负载生成器,如何使用负载生成器的方法,总结形成操作指导手册,以指导测试人员指导开展相关工作. 1.什 ...
- LoadRunner测试50人同时登陆下单
LoadRunner测试50人同时登陆下单 一.LoadRunner简介 LoadRunner,是一种预测系统行为和性能的负载测试工具.通过以模拟上千万用户实施并发负载及实时性能监测的方式来确认和查找 ...
- LoadRunner参数化MySQL
准备:安装[msql-ODBC驱动] 一.配置数据源 1.Win7,打开控制面板-系统和安全-管理工具,点击“数据源(ODBC)”. 打开数据源(ODBC),在用户DSN选项卡中点击“添加”按钮,弹出 ...
随机推荐
- Codeforces Beta Round #37 B. Computer Game 暴力 贪心
B. Computer Game 题目连接: http://www.codeforces.com/contest/37/problem/B Description Vasya's elder brot ...
- UOJ 12 猜数 数学题
[UER #1]猜数 这一天,小Y.小D.小C正在愉快地玩耍. 小Y是个数学家,他一拍脑袋冒出了一个神奇的完全平方数 n. 小D是个机灵鬼,很快从小Y嘴里套出了 n 的值.然后在脑内把 n 写成了 a ...
- 你的C/C++程序为什么无法运行?揭秘Segmentation fault (2)
什么让你对C/C++如此恐惧? 本篇将继续上一篇来讨论段错误(Segmentation fault). 上一篇: 你的C/C++程序为什么无法运行?揭秘Segmentation fault(1) 追溯 ...
- MySql_delete同时删除多表相关联记录
sql delete同时删除多表相关联记录 sqlserver 支持级联更新和删除oracle 只支持级联删除 删除包含主键值的行的操作,该值由其它表的现有行中的外键列引用.在级联删除中,还删除其外键 ...
- Linux终端(Xshell等)的编码设置
先简单说说一下遇到的情况吧: 在用类似Xshell的工具连接远端Linux时,运行命令ls时,如果有中文,就会显示有乱码: 网上查资料时,也把相应的连接属性修改为utf-8了(见下图),但是还是不行: ...
- IIS7.5 配置 PHP 5.3.5
本机环境:IIS7.5 windows2008 64位 首先确认IIS中启用了CGI功能: watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQveWVmaWdod ...
- WebView具体介绍
PART_0 侃在前面的话 WebView是Android提供给我们用来载入网页的控件.功能非常强大.我们经常使用的手机淘宝.手机京东的Androidclient里面大量使用到了WebView. ...
- 使用Bootstrap 3开发响应式网站实践05,使用Tab、Modal、Form展示内容,使用Popover、Tooltip展示提示信息
本篇体验用Tab插件显示内容.Html部分为: <div class="row" id="moreInfo"> <div class=&quo ...
- Google In-App Billing 实现(内含Unity 实现经验)
实现内购计费 傻逼目录 Adding the AIDL file Updating Your Manifest Creating a ServiceConnection Making In-app ...
- android NDK 开发环境搭建
基于 Android NDK 的学习之旅-----环境搭建 工欲善其事必先利其器 , 下面介绍下 Eclipse SDK NDK Cygwin CDT 集成开发环境的搭建. 1.Android 开发环 ...