【实战】Jmeter连接mongoDB数据库

2470 篇文章 33 订阅
1381 篇文章 7 订阅

作为一名测试人员,做接口测试难免要进行基础数据校验。Jmeter本身对mysql支持的非常好,但是对mongoDB、cassandra等数据库要怎么连接并校验数据呢?本文以mongodb为例进行说明。

一、如果你有Java基础,可以编写java代码访问mongo

首先,下载mongo-java-driver-2.13.2.jar,或者更高版本。将驱动包放在 lib目录下或者lib\ext目录下即可。

其次,右键测试计划,定义一些用户参数。

图片

这里主要是定义mongodb的基本信息,大家可以根据实际情况填写。

然后,就是我们的重点部分:添加JSR223Sampler,编写Java脚本。

图片

代码如下:

importcom.mongodb.*
importcom.gmongo.GMongoClient
importcom.mongodb.MongoCredential
importcom.mongodb.ServerAddress
importjava.text.DateFormat
importjava.text.SimpleDateFormat
 
MongoCredentialcredentials = MongoCredential.createCredential('${mongoname}','${mongoauth}' ,'${mongopwd}'as char[])
GMongoClientclient = new GMongoClient(newServerAddress('${mongoip}',${mongoport}),[credentials])
//连接数据库
defdb=client.getDB("${dbname}")
 
SimpleDateFormat df = new SimpleDateFormat("yyyy-MM-dd00:00:00")
 
 
def coll=db.getCollection('表名').aggregate([[$match:[type:"1",areaType:"1",areaCode:"****",statisticsDate:"20190825",faultType:"0",faultCode:"0",machineModel:"2"]],
[ $group :["_id" :'$areaName', "onlineNO" : [$sum : '$onlineNo'],"faultNo":[$sum : '$faultNo']]]])
def RpData=""
coll.results().each
{
    RpData =RpData+it.toString()+"\r\n"
}
 
SampleResult.setResponseData(RpData)

运行结果如下:

图片

二、如果测试人员java基础不好,或者只会用python编写脚本怎么办呢?

我们可以使用jmeter的OS Process Sampler完成这个任务。

首先,添加OS ProcessSampler,并配置好参数。

图片

其次,编写python脚本(脚本名称和路径要和上图配置的一致),在脚本中实现连接数据库的功能。

脚本如下:

#coding=utf-8
from pymongoimport MongoClient
from sys importargv
from datetimeimport datetime

#建立MongoDB数据库连接
client =MongoClient("mongodb://用户名:密码@ip:port")
time=argv[1]
#time='20190313'
year=int(time[:4])
if time[4]==0:
    mon=int(time[5])
else:   
    mon=int(time[4:6])
day=int(time[6:])
#连接所用集合,也就是我们通常所说的表,test为表名
 
result = db.test.find_one({"WorkTime":{"$gt":0},'ReportTime':datetime(year,mon, day, 16, 0)},{ "LoginID":1,"WorkTimeLine": 1})
print (result)

response中就会打印出loginid和worktimeline的值。

图片

再利用正则提取器取出想要的数据,进行数据校验即可。

图片

P.S.

第一种方法网上的教程不少,也是比较方便的方法,如果测试人员有一定的Java基础,还是推荐用这种方法。

第二种方法是针对Java编程有困难的测试人员,利用python脚本也可以实现数据校验的任务,但是在实际的测试中可能会出现编码等问题(比如打印字符串格式的数据时,结果中有字母“u”),导致正则表达式取不出想要的数据,这就需要根据实际情况调整正则表达式的写法,这个需要大家注意一下。

最后: 下方这份完整的软件测试视频教程已经整理上传完成,需要的朋友们可以自行领取 【保100%免费】
在这里插入图片描述

软件测试面试文档

我们学习必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有字节大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。
在这里插入图片描述
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值