欢迎光临散文网 会员登陆 & 注册

【实战】Jmeter连接mongoDB数据库

2023-09-07 21:05 作者:华测教育  | 我要投稿


作为一名测试人员,做接口测试难免要进行基础数据校验。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”),导致正则表达式取不出想要的数据,这就需要根据实际情况调整正则表达式的写法,这个需要大家注意一下。

最后:这些资料,对于【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴上万个测试工程师们走过最艰难的路程,希望也能帮助到你!

包括,测试人技术进阶路径图,50多天的视频教程、16个项目实例,30多个测试工具,37份测试文档,70个软件测试相关问题,40篇测试经验级文章分享,还有软件测试面试小程序,求职简历的优化模板。

加油吧,如果你需要提升技术储备,那就行动,在路上总比在起点观望的要好。一切的迷茫都是因为想得太多而做的太少!

你可以在公众号:伤心的辣条 ! 自行领取一份216页软件测试工程师面试宝典文档资料【免费的】。以及相对应的视频学习教程免费分享!,其中包括了有基础知识、Linux必备、Shell、互联网程序原理、Mysql数据库、抓包工具专题、接口测试工具、测试进阶-Python编程、Web自动化测试、APP自动化测试、接口自动化测试、测试高级持续集成、测试架构开发测试框架、性能测试、安全测试等。

现在我邀请你进入我们的软件测试学习交流群:【746506216】,备注“入群”, 大家可以一起探讨交流软件测试,共同学习软件测试技术、面试等软件测试方方面面,还会有免费直播课,收获更多测试技巧,我们一起进阶Python自动化测试/测试开发,走向高薪之路。

【实战】Jmeter连接mongoDB数据库的评论 (共 条)

分享到微博请遵守国家法律