1

我正在 JMeter 中创建一个测试位置,该位置访问随机数量的页面(从 2 到 10),其 URL 将从 CSV 数据集中获取。我已经创建了 CSV 数据集和工作正常的采样器,除了每个线程只从数据集中读取一行,这不是我需要的 - 我希望在采样器完成后读取一个新行(或之前,我没有大惊小怪)。

我看到这个问题非常相似,解决方案是使用原始数据源预处理器,它确实有效,但需要对相关文件进行艰苦的修改(在每行之前添加块大小),这有点痛苦当文件长约 500 行时。

有没有办法可以将 CSV 数据集设置为在读取时前进到下一行,或者使用一些后置或预处理器,例如 beanshell,来做到这一点?我见过有人说CSVRead可以做到这一点,但说访问是每个线程的,这对我没有好处。

作为旁注 - 最终我想要做的就是访问文件中的随机行,该行被传递给 HTTP 采样器,如果有更简单或更好的方法来做到这一点,我愿意接受建议。

4

1 回答 1

2

您可以使用从BeanShell Sampler / BeanShell PostProcessor / BeanShell PreProcessor执行的这个 beanshell (= java) 代码。

以下代码将从您的文件中读取所有行,然后选择单个随机数:

import java.text.*;
import java.io.*;
import java.util.*;

String [] params = Parameters.split(",");
String csvTest = params[0];
String csvDir = params[0];

ArrayList strList = new ArrayList();     

try {
    File file = new File(System.getProperty("user.dir") + File.separator + csvDir + File.separator + csvTest);

    if (!file.exists()) {
        throw new Exception ("ERROR: file " + csvTest + " not found in " + csvDir + " directory.");
    }

    BufferedReader bufRdr = new BufferedReader(new FileReader(file));
    String line = null;

    while((line = bufRdr.readLine()) != null) {
        strList.add(line);
    }

    bufRdr.close();            

    Random rnd = new java.util.Random();
    vars.put("csvUrl",strList.get(rnd.nextInt(strList.size())));
}
catch (Exception ex) {
    IsSuccess = false; 
    log.error(ex.getMessage());
    System.err.println(ex.getMessage());
}
catch (Throwable thex) {
    System.err.println(thex.getMessage());
}

然后您可以通过变量访问提取的 URL(本例中为 ${csvUrl})。

从性能的角度来看,我只是怀疑在每次迭代中读取完整文件(如果你必须在循环中执行)是一个很好的解决方案。

于 2012-04-17T17:52:11.583 回答