博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
[13] JMeter-详解JMeter参数化之CSV Data Set Config
阅读量:2167 次
发布时间:2019-05-01

本文共 2528 字,大约阅读时间需要 8 分钟。

相关扩展文章:

今天大家一起来学习一下参数化的一个重要工具,我们在写脚本时,经常要用到参数化,而实现参数化最常用的方法之一就是使用CSV Data Set Config元件,使用方便,功能强大。

 

简单的使用方法估计大家都会,或者说很容易就会了,但是,如果说是比较复杂的配置,估计就有很多人会被绕晕了(我刚开始也经常晕~),今天咱们就详细看看,怎么才能不晕!哈哈

 

首先来看一眼长啥样,相信大家都比较熟悉

 

该元件的作用:

   从文件中读取变量值,用于变量的参数化,可设置多种读取方式。

 

各填写项说明:

1、名称、注释:元件的名称及注释,可自定义

2、Config the CSV Data Source:配置数据源

1)Filename:csv文件的名称

  • 注意:这里要包括文件的路径,在4.0版本中可以点击右侧的浏览按钮选择文件,会自动带上文件的绝对路径;
  • 另外,当csv文件在jmeter的bin目录或脚本目录时,只需给出文件名即可;
  • 使用相对路径时,jmeter默认先去bin目录下查找,然后去脚本目录下查找;

2)File encoding:csv文件编码

  • 默认使用当前操作系统的编码格式;
  • 如果文件中包含中文乱码时,可尝试utf-8、gbk等;

3)Variable Names(comma-delimited):

  • csv文件中各列的名字(有多列时,用英文逗号隔开列名);
  • 名字顺序要与内容对应,这个变量名称是在其他处被引用的,所以为必填项。

4)Delimiter(use “\t” for tab):csv文件中的分隔符(用”\t”代替tab键)

  • 一般情况下,分隔符为英文逗号,保持默认就行

5)Allow quoted data?:是否允许数据内容加引号

6)Recycle on EOF?:

  • 到了文件尾是否循环,True—继续从文件第一行开始读取,False—不再循环;
  • 此项与下一项的设置为互斥关系,即true-false,或false-true;

7)Stop thread on EOF?:

  • 到了文件尾是否停止线程,True—停止,False—不停止;
  • 注意:当Recycle on EOF设置为True时,此项设置无效。

8)Sharing mode:共享模式

  • All threads –所有线程,此元件作用范围内的所有线程共享csv数据,每个线程依次读取csv数据,互不重复;
  • Current thread group—当前线程组,在此元件作用范围内,以线程组为单位,每个线程组内的线程共享csv数据,依次读取数据,互不重复;
  • Current thread—当前线程,在此元件作用范围内,每次循环中所有线程取值一样;

 

下面重点分析一下Allow quoted data和Sharing mode:

 

1、Allow quoted data?是否允许带双引号的数据

  • 此项实际是控制csv文件中的双引号是否为有效字符;
  • 如果数据带有双引号且此项设置TRUE,则会自动去掉数据中的引号使能够正常读取数据,且即使引号之间的内容包含有分隔符时,仍作为一个整体而不进行分隔;
  • 如果数据带有引号且此项设置为FALSE,则读取数据报错;
  • 如果希望双引号字段中间再包含双引号,则需要加两个双引号来代表单个双引号。(啊啊啊,太拗口了!!!)
  • 如下图所示,此项设置为true时,"2,3"-->2,3;"4""5"-->4"5

 

2、Sharing mode:共享模式

(1)All threads针对所有线程组的所有线程,每个线程取值不一样,依次取csv文件中的下一行。

  • 假如说有线程1到线程n (n>1),线程1取了一次值后,线程2取值时,取到的是csv文件中的下一行,即与线程1取的不是同一行。
  • 不管是单个线程组还是多个线程组,每个线程都是依次取下一行。
  • 需要注意的是,当一个线程组中有多个请求时,对于每个线程来说,在一次循环中每个请求的取值是一样的。

   下面举例说明:

          A、设置线程组1、2、3分别为1并发、1次循环,且各线程组按顺序执行:

 

     B、设置线程组1、2、3分别为1并发、2次循环,且各线程组按顺序执行:

   

 C、设置线程组1、2、3分别为2并发、1次循环,且各线程组按顺序执行:

 

     大家可以仔细比较一下上图和上上图的区别,乍一看貌似是一样的,但是实际却是不同的线程,怎么区分不同线程呢?

    可以使用一个函数来判断:

     ${__BeanShell(ctx.getThread().getThreadName().toString())}

    这个函数可以输出类似这样的内容:“线程组1 1-2“,前面是当前线程组的名称-线程组1,后面是线程组id,然后是线程id,现在再比较上面两图中,发现是线程id不一样。

    总体来说就是,在All Threads模式下,并发数和循环数都会读取不同的csv数据,但是同一线程组内的多个sampler总是取相同的值。

 

(2)Current thread group:当前线程组

    取值情况是:以线程组为单位,每个线程组内的线程都会从第1行开始取值并依次往下进行取值。

    举例如下:

    A、设置线程组1、2均为2并发、1循环:

 

   (3)Current thread:当前线程

       取值情况是:每个线程都会从第1行开始取值并依次往下进行取值,在同一次循环中所有的线程取值一样。

      举例如下:

          A、设置线程组1、2均为2并发、1循环:

 

   上面两个图看起来好像是一样的呀?再仔细看一下,后面的test参数取值是不同的。

为什么不同呢?本来想认真的解释一番,但是组织了很久的语言,还是感觉没说清楚。

 

这一块的逻辑是“只可意会,不可言传”,必须要靠自己亲自实验,慢慢体会才行。

 

最后,给大家一个小作业:

如何通过设置Sharing moder的方法来实现多个sampler中的参数可以依次不重复的取同一个csv文件中的值?

end

----------

本文首发于本人原创公众号【媛测】(原名-玩转jmeter),专注分享性能、自动化测试等相关知识,寻找志同道合之士共同成长!扫码关注后分别回复jmeter、python、linux,领取个人总结资料。

你可能感兴趣的文章
【LEETCODE】36-Valid Sudoku
查看>>
【LEETCODE】205-Isomorphic Strings
查看>>
【LEETCODE】204-Count Primes
查看>>
【LEETCODE】228-Summary Ranges
查看>>
【LEETCODE】27-Remove Element
查看>>
【LEETCODE】66-Plus One
查看>>
【LEETCODE】26-Remove Duplicates from Sorted Array
查看>>
【LEETCODE】118-Pascal's Triangle
查看>>
【LEETCODE】119-Pascal's Triangle II
查看>>
【LEETCODE】88-Merge Sorted Array
查看>>
【LEETCODE】19-Remove Nth Node From End of List
查看>>
【LEETCODE】125-Valid Palindrome
查看>>
【LEETCODE】28-Implement strStr()
查看>>
【LEETCODE】6-ZigZag Conversion
查看>>
【LEETCODE】8-String to Integer (atoi)
查看>>
【LEETCODE】14-Longest Common Prefix
查看>>
【LEETCODE】38-Count and Say
查看>>
【LEETCODE】278-First Bad Version
查看>>
【LEETCODE】303-Range Sum Query - Immutable
查看>>
【LEETCODE】21-Merge Two Sorted Lists
查看>>