Слушатель графика Jmeter для SampleResult.subResult - PullRequest
0 голосов
/ 25 ноября 2011

Я ищу прослушиватель jmeter graph, который выведет подрезультаты объекта SamplerRequest.Я еще не нашел и очень хочу его получить.

Ответы [ 2 ]

1 голос
/ 21 ноября 2014

Старый вопрос, я знаю.

К сожалению, похоже, что нет прослушивателей графа JMeter, которые бы отображали результаты промежуточных результатов, прикрепленных к SampleResult. Просто столкнувшись с той же проблемой, я решил написать свою.

Шаги:

  1. Скомпилируйте приведенный ниже класс как банку.
  2. Поместите банку в папку lib / ext jMeter.
  3. Откройте план тестирования, перейдите по меню, чтобы добавить прослушиватель как обычно, выберите «График распределенных ответов SubResult»
  4. Запустите план тестирования.

Классы:

В приведенном ниже классе будет представлен график распределения времени отклика, который будет отображать только вспомогательные результаты.

public class SubResultDistributedResponseTimeListener extends DistributionGraphVisualizer {

private static final Logger LOG = LoggingManager.getLoggerForClass();

@Override
public void add(final SampleResult res) {
    final List<SampleResult> subResults = Arrays.asList(res.getSubResults());
    final SubResultDistributedResponseTimeListener inst = this;

    JMeterUtils.runSafe(new Runnable() {
        public void run() {
            for (SampleResult r : subResults) {
                long time = r.getEndTime() - r.getStartTime();
                LOG.info("Adding result; start: " + r.getStartTime() + " end: " + r.getEndTime() + " duration: " + time);
                SamplingStatCalculator model = inst.getCustomModel();
                if (model != null) {
                    model.addSample(r);
                    inst.updateGui(model.getCurrentSample());
                }
            }
        }
    });

}

// we need this because DistributionGraphVisualizer has a private field 'model' which
// deals with updating the screen. Watch out for SecurityManager problems with 
// accessing private fields.
public SamplingStatCalculator getCustomModel() {
    try {
        Field f = DistributionGraphVisualizer.class.getDeclaredField("model");
        f.setAccessible(true);
        return (SamplingStatCalculator) f.get(this);
    } catch (NoSuchFieldException e) {
        e.printStackTrace();
    } catch (SecurityException e) {
        e.printStackTrace();
    }  catch (IllegalArgumentException e) {
        e.printStackTrace();
    } catch (IllegalAccessException e) {
        e.printStackTrace();
    }
    return null;
}

@Override
public String getName() {
    return "SubResult Distributed Response Graph";
}

@Override
public String getStaticLabel() {
    return this.getName();
}

@Override
public String getLabelResource() { // add this Listeners name to the right click context menu.
    return this.getName();
}

NB, ужасно уродливый блок catch был из-за того, что мне пришлось скомпилировать в Java 1.5.

Я предоставлю читателю возможность расширять возможности слушателей графов, если они того пожелают.

0 голосов
/ 11 декабря 2011

Единственная опция, которую я знаю, это График хитов в секунду , он отображает результаты и подрезультаты, но только из контроллеров транзакций, а не из встроенных ресурсов. Вы можете попросить авторов реализовать новый график ...

...