使用jmeter构造时间戳参数

很久没用jmeter了,这次趁着项目稳定后,用jmeter写了一些创建测试数据的脚本,因为手动创建数据太麻烦了

本次编写脚本,一方面是通过查看后台请求,手动录入脚本,另一方面用到了一些自带的函数来生成时间戳、生成随机数

所以本篇主要说一下这次写脚本的思路以及函数助手中用到的函数

1.整体思路

  • 要想构造数据,首先必须登录获取token,后续操作都依赖这个生成的token;
  • 本次需要构造3种类型的数据,每种数据填写的字段不同,所以编写脚本时,利用【事务控制器】,把不同作用的脚本进行分类,例如登录操作、构造A类型数据、构造B类型数据,这样脚本运行时,结果看起来一目了然;
  • 不同请求需要的headers可能不同,所以把【HTTP信息头管理器】添加在各个【事务控制器】下,只对其下的请求生效(或者再细分添加某个具体请求下);
  • 根据参数实际情况选用【HTTP请求默认值】以及【JSON提取器】、【正则表达式提取器】以及【函数助手】等,帮助实现参数化

2.编写过程中的关键点

(1)响应结果中的中文字符显示成了“???”

编写好第一个脚本后,执行后查看结果,发现中文字符没有正常显示,如下

 解决方法:在请求中,加上内容编码:utf-8

 

(2)添加时间戳 timestamp

有些请求携带的参数中包含时间戳,可以是放在headers中,也可以是放在请求参数中

 在jmeter中,能够通过函数助手来生成时间戳

  • 生成当前时间

依次点击【选项】-【函数助手对话框】,打开函数助手

 

然后选择【__time】函数,它可以生成各种形式的当前时间,展示如下

 点击【帮助】会默认打开浏览器显示该函数的说明文档,谷歌硬核翻译如下

 (1)不填写任何格式,直接点击【生成】,在结果区会展示一个13位的时间戳(毫秒级)

 (2)如果要生成10位数字时间戳(秒级),则需要在格式字符中输入“/1000”

 

  (3)生成特定格式的日期

帮助文档中提供了如下几种

  • YMD = yyyyMMdd
  • HMS = HHmmss
  • YMDHMS = yyyyMMdd-HHmmss

依次来试一下

YMD,等价于yyyyMMdd,填写到格式字符串中,点击【生成】

 HMS ,等价于 HHmmss

 YMDHMS ,等价于 yyyyMMdd-HHmmss

 也可以自己来自定义一下显示格式

 之前说生成时间戳时,变量名是非必填的,下面看下填写变量名后是什么效果

  注意:当点击【生成】后,“拷贝并粘贴函数字符串”后会出现一串变量名,这个可以理解为时间戳变量,把它放到请求参数中,就意味着获取到了当前时间,如下

  •  根据当前时间进行位移(向前or向后移动指定时长)

有些请求会用到过去或将来的 某一个时间,jmeter有一个函数可以满足这个需求【__timeShift】

 谷歌硬核翻译帮助文档如下

 下面来试验一下

(1)显示格式为yyyyMMdd,时间基准20200420,向后推移2天

 (2)显示格式为时间戳(毫秒级),时间基准为当前时间,向后推移10分钟

${__timeShift(,,PT10M,,)}

 (3)显示格式为 yyyy/MM/dd HH:mm:ss,时间基准为 2020/04/17 17:38:00,向后推迟 10分20秒

${__timeShift(yyyy/MM/dd HH:mm:ss,2020/04/17 17:38:00,PT10M20S,,)}

 (4)显示格式为 yyyy/MM/dd HH:mm:ss,时间基准为 2020/04/17 17:38:00,向前推 10分20秒

有2种写法:PT-10M-20S   或  -PT10M20S

 ps.位移时间时,注意“-”添加的位置即可,“+”可以省略

添加时间戳一方面可以用到传时间参数这种情况下,直接丢个时间戳过去;另一方面,例如批量造数据时,不想每个数据的名称都一样,那么就可以用时间戳作名称后缀,如下

 这样生成的数据就是:测试数据-20200417-141443 

(3)生成随机数

一种是利用【__Random】函数(生成的随机数不唯一,可能会重复)

 一种是利用【__UUID】函数(每次都会生成唯一的随机数)

 

OK,本篇重点讲的内容就到这里啦,通篇看下来其实主要是时间戳函数的使用,后续再介绍其他

posted @ 2020-04-17 18:47  我是冰霜  阅读(12579)  评论(0编辑  收藏  举报