美文网首页
JMeter-CSV Data Set二次开发

JMeter-CSV Data Set二次开发

作者: MechelleWang | 来源:发表于2019-10-27 19:10 被阅读0次

    CSV Data Set


    CSV数据集配置用于从文件中读取行,并按指定分隔符它们拆分为变量。CSV非常适合处理大量的变量,同时测试之前创建数据可以避免cpu和内存生成大量的随机测试数据。
    首先简单介绍CSV中一些配置:


    CSV配置

    JMeter允许值被引用,如果启用“allow quoted data”(允许引用数据),则值可以用双引号括起来。如果要在带引号的字段中包含双引号,需要使用两个双引号。例如:

    1,"2,3","4""5" =>
    1
    2,3
    4"5

    CSV文件中可以具有定义列名的标题行。如果要启用此功能,需要将Variable Names字段留空,同时填写分隔符。
    默认情况下,整个测试计划中CSV文件只打开一次,每个线程根据执行顺序不同将读取文件中不同的行。第一次迭代时解析文件名和相关配置。
    如果希望每个线程都有自己的值集,则需要创建一组文件,每个线程使用一个。例如test1.csv、test2.csv、…、testn.csv。使用文件名test${__threadNum}.csv并将CSV模式设置为Current thread
    recycle如果设为true,则到达文件结尾时,将从文件第一行重新读取。
    如果recycle设为false,stop thread设为false,那么当到达文件结尾时,所有变量都设置为<eof>。但可以通过设置JMeter属性csvdataset.eofstring来更改此值。
    如果recycle选项为false,stop thread为true,则到达EOF将导致线程停止。

    • Parameters
    Attribute Description Required
    Name 名称 NO
    Filename 要读取的文件的名称。相对文件名是根据测试计划的路径解析的,对于分布式测试,CSV文件必须存储在服务器主机系统中与JMeter服务器启动位置相对应的正确目录中。使用绝对文件名时,除非远程服务器具有相同的目录结构,否则绝对文件名不太可能在远程模式下工作。如果同一物理文件以两种不同的方式引用(例如csvdata.txt和./csvdata.txt),则这些文件将被视为不同的文件。如果操作系统不区分大小写,则csvData.TXT也会被作为新的文件处理。 YES
    File Encoding 文件编码方式 NO
    Variable Names 变量名列表。名称需要用分隔符隔开,可以用双引号引起来。CSV中也可以使用首行定义变量名,如果变量名字段为空,则读取文件的首行并将其解释为变量名列表。 NO
    Use first line as Variable Names 仅当变量名不为空时,可以忽略CSV文件的第一行;如果变量名为空,则文件第一行必须包含变量名。 NO
    Delimiter 分隔符 YES
    Allow quoted data? CSV文件中是否允许使用引用值,如果设为true,则可以使用双引号将值括起来。 YES
    Recycle on EOF? 当到达EOF是否从头读取文件。 YES
    Stop thread on EOF? 如果同时Recycle为false,则该字段表示在EOF时是否应该停止线程。 YES
    Sharing mode 1)All threads(默认设置),文件在所有线程之间共享;2)Current thread group,该文件只用于当前线程组;3)Current thread,该文件只用于当前线程;4)Identifier,具有相同标识符的所有线程共享同一文件。例如,如果有4个线程组,可以使用公共id在多个线程组之间共享文件,或者可以使用同一个线程号在不同线程组中的相同线程号之间共享文件。 YES

    CSV Data Set二次开发-实现按指定列读取子


    CSV配置有一些局限,比如每次只能从文件首行读取变量,对于文件量比较小还可以接受,但有些时候CSV文件中可能有几万条数据,则每次都从首行读会出现很多重复的测试数据。再比如(目前碰到的一个需求)有一个数据集,每次测试需要从数据集中随机选取一定数量的数据组成新的测试数据,如下,

    原数据集11,22,3a,4b,ccc,每次测试计划从中选取子集,比如11;22,3a;22,ccc等。

    一种方式是将数据集手动按排列组合方式罗列出所有子集的情况构造成CSV文件,这种提前处理是一种思路,但比较耗时而且数据集变化,CSV文件需要重新生成,而且没有必要罗列出所有子集,只需在测试计划迭代时随机选取一个子集就够了。
    CSV Data Set相关配置位于org.apache.jmeter.config包中。
    首先修改CSVDataSetBeanInfo,增加相关变量,


    CSVDataSetBeanInfo1

    然后为变量新增属性,


    CSVDataSetBeanInfo2
    CSVDataSetBeanInfo3
    修改CSVDataSetResources.properties配置文件,
    CSVDataSetResources.properties
    更改JMeter GUI模式下的提示,
    JMeter-CSVDataSet

    最后修改CSVDataSet这个类,实现自定义的逻辑,
    首先增加相关成员变量,并提供setter、getter方法,


    CSVDataSet1
    CSVDataSet实现了接口LoopIterationListener,接口中提供了iterationStart,每一次迭代都会执行该方法,并从CSV中读取一行数据,
    CSVDataSet#iterationStart1
    • 1:获取CSV GUI传入的分隔符,当输入“\t”则分隔符传入“\t”,如果不填,默认为“,”。
    • 2:获取CSV GUI传入的模式配置,alias为CSV文件的别名,通过alias命名方式可以判断CSV的模式,share_all表示该CSV文件对整个测试计划有效,share_group表示只对当前线程组有效,share_thread表示只对当前线程有效。


      CSVDataSet#iterationStart2
    • 3:获取变量名,如果不为空,直接从输入中切割并获取变量名,注意由于分隔符可能存在转义字符,比如“|”等,所以使用JOrphanUtils#split方法分隔字符串;如果为空,则从CSV文件首行读取变量名。
      CSVDataSet#iterationStart3
    • 4:是否使用引用数据,如果使用引用数据,则被引用的数据不可拆分,lineValues表示从CSV文件中读取的一行数据。
    • 5:该部分是自定义,对lineValues二次读,写了一个hashingSplit方法,主要用于从一行数据和指定的列的数据集中随机选取一定数量的数据组成新的测试数据。
    • 6:当读取到EOF,则给变量名赋“<EOF>”。

    参考:
    https://blog.csdn.net/lin443514407lin/article/details/54667248

    相关文章

      网友评论

          本文标题:JMeter-CSV Data Set二次开发

          本文链接:https://www.haomeiwen.com/subject/sihmvctx.html