接口测试 jmeter 接口自动化连载 (5) - 函数

小七的自动化课堂 · 2020年03月27日 · 最后由 飞天小子的性能课堂 回复于 2020年03月27日 · 2673 次阅读
  • JMeter 提供了很多函数,如果能够熟练使用,可以为脚本带来很多方便。

  • JMeter 函数是一种特殊值,可用于除测试计划外的任何组件。

  • 函数调用的格式如下所示:
    ${functionName(var1,var2,var3)}
    其中,
    functionName 为函数名,括号内是函数的参数,无参数时可以不用括号,如 ${__UUID}

  • Tips:
    如果参数包含逗号,那么一定要使用 “\” 来转义,否则 JMeter 会把它当作一个参数分隔符

  • 实际使用时,可通过函数助手对话框选择函数,设置参数后,点击生成按钮生成函数字符串。

一、__BeanShell:beanshell 函数


Jmeter 接口自动化交流扣扣群:956186148

1、它有两个参数,第一个参数是要执行的语句,可以是 beanshell 语句或者是文件地址,是必选参数;第二个参数是保存结果的变量名称,非必选参数。
2、Example:

${__BeanShell(123*456)}·:返回 56088

${__BeanShell(source("function.bsh"))}:会执行外部脚本 function.bsh,并返回结果

${__BeanShell(import java.util.*;Properties props = System.getProperties();String osName = props.getProperty("os.name");if(osName.contains("Windows"))return 443;return 8443;)}:判断端口

3、与 beanshell 元件比较:

该函数与 beanshell 元件 (beanshell sampler、beanshell preprocess 等) 作用是一样的,只是 beanshell 函数更常用于一些简单的判断或计算等,可以把少量的脚本放在函数中直接赋值给一个变量,而不用总是添加 beanshell 元件。

Jmeter 接口自动化交流扣扣群:704807680

二、__regexFunction:正则表达式函数

1、该函数使用用户提供的正则表达式来解析前面的服务器响应(或者是某个变量值)。函数会返回一个有模板的字符串,其中携带有可变的值。

2、__regexFunction 还可以被用来保存值,以便供后续使用。在函数的第 6 个参数中,测试人员可以指定一个引用名。在函数执行以后,测试人员可以使用用户定义值的语法来获取同样的值。例如,如果测试人员输入"refName"作为第 6 个参数,那么测试人员可以使用:

${refName}来引用第 2 个参数(Template for the replacement string)的计算结果,这依赖于函数的解析结果。

${refName_g0}来引用函数解析后发现的所有匹配结果。

${refName_g1}来引用函数解析后发现的第一个匹配组合。

${refName_g#}来引用函数解析后发现的第 n 个匹配组合。

${refName_matchNr}来引用函数总共发现的匹配组合数目。

具体参数描述如下:

其实这个函数的作用跟正则表达式提取器的作用是类似的。

三、__counter:计数器函数


1、每次调用计数器函数都会产生一个新值,从 1 开始每次加 1。计数器既可以被配置成针对每个虚拟用户是独立的,也可以被配置成所有虚拟用户公用的。

2、如果每个虚拟用户的计数器是独立增长的,那么通常被用于记录测试计划运行了多少遍。全局计数器通常被用于记录发送了多少次请求。

3、计数器使用一个整数值来记录,允许的最大值为 2,147,483,647。

4、目前计数器函数实例是独立实现的(JMeter 2.1.1 及其以前版本,使用一个固定的线程变量来跟踪每个用户的计数器,因此多个计数器函数会操作同一个值)。全局计数器(FALSE)每个计数器实例都是独立维护的。

5、该函数也有对应的配置元件:计数器,功能类似。

四、__threadNum

函数__threadNum 只是简单地返回当前线程的编号。线程编号不依赖于线程组,这就意味着从函数的角度看来,某个线程组的线程 #1 和另一个线程组的线程 #1 是没有区别的。另外,该函数没有参数。

这一函数不能用在任何配置元件中(如用户定义的变量),原因在于配置元件是由一个独立线程运行的。另外在测试计划(Test Plan)中使用也是没有意义的。所以,很少用。

五、__intSum:整数求和函数

1、函数__intSum 可以被用来计算两个或者更多整数值的合。至少需要两个整数,如果指定变量名则名称中必须包含一个非数字字母,否则它会被当成另一个整数值,而被函数用于计算。

2、当有多个整数时点击添加按钮来增加参数,但是需要注意的是,添加完参数后,点击” 生成” 的函数默认是把手动添加的函数放在后面,这时需要手动调整变量名的位置,把它放到最后,否则会报错。

Jmeter 接口自动化交流扣扣群:704807680

六、__longSum:长整型求和函数

该函数用来计算两个或更多长整型值的和,使用方法跟上面的__intSum 函数一样。

七、__StringFromFile:读取文件中的字符串函数

1、该函数用来从文本文件中读取字符串。支持读取多个文件。

2、使用配置元件 CSV Data Set Config ,也能达到相同的目的,而且方法更简单,但是它目前不支持多个输入文件。

3、每次调用函数,都会从文件中读取下一行。当到达文件末尾时,函数又会从文件开始处重新读取,直到最大循环次数。如果在一个测试脚本中对该函数有多次引用,那么每一次引用都会独立打开文件,即使文件名是相同的(如果函数读取的值,在脚本其他地方也有使用,那么就需要为每一次函数调用指定不同的变量名)。

4、如果在打开或者读取文件时发生错误,那么函数就会返回字符串"ERR"。

示例:
${_StringFromFile(demo.txt,,,)}读取 demo.txt
${_StringFromFile(PIN#'.'DAT,,1,2)} 读取 demo1.txt, demo2.txt
${_StringFromFile(PIN.DAT,,,2)} 读取 demo.txt 两次

5、函数的第三个参数:初始的序列号,如果省略,那么结束序列号就代表文件的循环读取次数。

6、函数的第四个参数:结束序列号,如果省略,那么序列号会无限增长。

7、读取多个文件示例:

需要在文件名中使用序列号:当使用序列号时,文件名需要使用格式字符串 java.text.DecimalFormat。当前的序列号会作为唯一的参数。如果不指明可选的初始序列号,就使用文件名作为起始值。一些有用的格式序列如下:

#:插入数字,不从零开始,不包含空格。

000:插入数字,包含 3 个数字组合,不从零开始。

例如:

pin#'.'dat -> pin1.dat, ... pin9.dat, pin10.dat, ... pin9999.dat

pin000'.'dat -> pin001.dat ... pin099.dat ... pin999.dat ... pin9999.dat `

pin'.'dat# -> pin.dat1, ... pin.dat9 ... pin.dat999``

如果不希望某个格式字符被翻译,需要为它加上单引号。注意上面的"."是格式字符,必须被单引号所包含。

比如现在要同时读取两个文件,分别是 PIN1.DAT, PIN2.DAT:

${_StringFromFile(PIN#'.'DAT,,1,2)}:同时读取 PIN1.DAT, PIN2.DAT。

${_StringFromFile(PIN.DAT,,,2)}:读取 PIN.DAT 两次。

${_StringFromFile(test#'.'txt,,1,2)}:同时读取test1.txt,test2.txt`

八、__machineName

函数__machineName 返回本机的主机名。

九、__javaScript

1、函数__javaScript 可以用来执行 JavaScript 代码片段(非 Java),并返回结果值。

2、JMeter 的_javaScript 函数会调用标准的 JavaScript 解释器,还可以直接调用 jmeter 的内置函数。

3、请记得为文本字符串添加必要的引号。另外,如果表达式中有逗号,请确保对其转义。例如,${__javaScript('${sp}'.slice(7\,99999))},对 7 之后的逗号进行了转义。

十、__Random:随机数函数

函数__Random 会返回指定最大值和最小值之间的随机数。

十一、_RandomString():随机字符串函数


1、Random string length:随机字符的长度

2、Chars to use for random string generation:用来生成随机字符串的字符,可以是纯数字,纯字符,字符字母数字组合

3、Name of variable in which to store the result (optional):随机生成的字符被变量保存

4、${__RandomString(6,abcdefgh1234566,ranstr)},解释:随机生成一个 6 位长度的字符串被 ranstr 保存;

十二、__property

1、函数__property 会返回一个 JMeter 属性的值。如果函数找不到属性值,而又没有提供默认值,则它会返回属性的名称。

2、例如,

${__property(user.dir)}:返回属性 user.dir 的值。

${__property(user.dir,UDIR)}:返回属性 user.dir 的值,并保存在变量 UDIR 中。

${__property(abcd,ABCD,atod)}:返回属性 abcd 的值(如果属性没有定义,返回"atod"),并保存在变量 ABCD 中。

${__property(abcd,,atod)}:返回属性 abcd 的值(如果属性没有定义,返回"atod"),但是并不保存函数的返回值。

十三、_P

Jmeter 接口自动化交流扣扣群:704807680

1、函数_P 是一个简化版的属性函数,目的是使用在命令行中定义的属性。

2、不同于函数_property,本函数没有提供选项用于设置保存属性值的变量。另外,如果没有设置默认值,默认值自动设为 1。

3、例如:定义属性值:

jmeter -Jgroup1.threads=7 -Jhostname1=www.realhost.edu

获取值如下:

${__P(group1.threads)}:返回属性 group1.threads 的值。

${__P(group1.loops)}:返回属性 group1.loops 的值。

${__P(hostname,www.baidu.com)}:返回属性 hostname 的值,如果没有定义该属性则返回值 www.baidu.com。

在上面的例子中,第一个函数调用返回 7,第二个函数调用返回 1,而最后一个函数调用返回 www.baidu.com(除非这些属性在其他地方有定义)。

十四、__log

1、函数__log 会记录一条日志,并返回函数的输入字符串。

2、OUT 和 ERR 的日志级别,将会分别导致输出记录到 System.out 和 System.err 中。在这种情况下,输出总是会被打印(它不依赖于当前的日志设置)。

例如:

${__log(Message)}:写入日志文件,形如"...thread Name : Message"。

${__log(Message,OUT)}:写到控制台窗口。

${__log(${VAR},,,VAR=)}:写入日志文件,形如"...thread Name VAR=value"。

十五、__split:字符串分割函数

1、函数__split 会通过分隔符来拆分传递给它的字符串,并返回原始的字符串。如果分隔符紧挨在一起,那么函数就会以变量值的形式返回"?"。拆分出来的字符串,以变量 ${VAR_1}、{VAR_2}…以此类推的形式加以返回。

2、分隔符默认是逗号,如果你想要多此一举,明确指定使用逗号,需要对逗号转义,如 “\,”

3、例如,在测试计划中定义变量 VAR="a||c|":

${__split(${VAR},VAR),|} :该函数调用会返回 VAR 变量的值,例如"a||c|",并设定 VAR_n=4、VAR_1=a、VAR_2=?、VAR_3=c、VAR_4=?、VAR_5=null 变量的值。

十六、__XPath

1、函数__XPath 读取 XML 文件,并在文件中寻找与指定 XPath 相匹配的地方。每调用函数一次,就会返回下一个匹配项。到达文件末尾后,会从头开始。如果没有匹配的节点,那么函数会返回空字符串,另外,还会向 JMeter 日志文件写一条警告信息。

整个节点列表都会被保存在内存之中。

例如:

${__XPath(/path/to/build.xml, //target/@name)}

这会找到 build.xml 文件中的所有目标节点,并返回下一个 name 属性的内容。

十七、__setProperty

1、函数__setProperty 用于设置 JMeter 属性的值。函数的默认返回值是空字符串,因此该函数可以被用在任何地方,只要对函数本身调用是正确的。

2、通过将函数可选的第 3 个参数设置为"true",函数就会返回属性的原始值。

3、属性对于 JMeter 是全局的,因此可以被用来在线程和线程组之间通信。

十八、__time

1、函数__time 可以通过多种格式返回当前时间。

2、如果省略了格式字符串,那么函数会以毫秒的形式返回当前时间。其他情况下,当前时间会被转成简单日期格式。包含如下形式:

YMD = yyyyMMdd。

HMS = HHmmss。

YMDHMS = yyyyMMdd-HHmmss。

USER1 = JMeter 属性 time.USER1。

USER2 = JMeter 属性 time.USER2。

用户可以通过修改 JMeter 属性文件来改变默认格式,或者自定义格式,例如修改 YMD 格式: time.YMD=yyMMdd。

十九、__V

1、函数__V 可以用于执行变量名表达式,并返回执行结果。它可以被用于执行嵌套函数引用(目前 JMeter 不支持)。

2、例如,如果存在变量 A1、A2 和 N=1,则:

${A1}:能正常工作。

${A${N}}:无法正常工作(嵌套变量引用)。

{__V(A${N})}:可以正常工作。A{N}变为 A1,函数 __V 返回变量值 A1。

二十、__evalVar

1、函数__evalVar 可以用来执行保存在变量中的表达式,并返回执行结果。

如此一来,用户可以从文件中读取一行字符串,并处理字符串中引用的变量。

2、例如,假设变量"query"中包含有"select columnfrom{table}",而 "column"和"table"中分别包含有"name"和"customers",那么 ${__evalVar(query)}将会执行"select name from customers"。

二十一、__eval

1、函数__eval 可以用来执行一个字符串表达式,并返回执行结果。

如此一来,用户就可以对字符串(存储在变量中)中的变量和函数引用做出修改。

2、例如,给定变量 name=Smith、column=age、table=birthdays、SQL=select columnfrom{table} where name='name′,那么通过{__eval(${SQL})},就能执行"select age from birthdays where name='Smith'"。这样一来,就可以与 CSV 数据集相互配合,例如,将 SQL 语句和值都定义在数据文件中。

二十二、__escapeHtml

1、函数__escapeHtml 用于转义字符串中的字符(使用 HTML 实体)。支持 HTML 4.0 实体。

二十三、__unescapeHtml

1、函数__unescapeHtml 用于反转义一个包含 HTML 实体的字符串,将其变为包含实际 Unicode 字符的字符串。支持 HTML 4.0 实体。

2、如果函数不认识某个实体,就会将实体保留下来,并一字不差地插入结果字符串中。例如,">&zzzz;x"会变为">&zzzz;x"。

二十四、__FileToString

1、函数__FileToString 可以被用来读取整个文件。每次对该函数的调用,都会读取整个文件。

2、如果在打开或者读取文件时发生错误,那么函数就会返回字符串"ERR"。
Jmeter 接口自动化交流扣扣群:704807680

如果觉得我的文章对您有用,请随意打赏。您的支持将鼓励我继续创作!
共收到 1 条回复 时间 点赞

棒棒的~写的非常好~

需要 登录 后方可回复, 如果你还没有账号请点击这里 注册