Jmeter Graph Listener для SampleResult.subResult

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


person wonchi    schedule 25.11.2011    source источник
comment
Что это за объект SamplerRequest? Никогда не слышал о... Не могли бы вы дать ссылку?   -  person Andrey Pokhilko    schedule 26.11.2011
comment
Извините, я хотел сказать SampleResult, а не «SamplerRequest».   -  person wonchi    schedule 29.11.2011
comment
Еще вопрос - что на выходе? Компонент View Results Tree Jmeter хорошо показывает промежуточные результаты...   -  person Andrey Pokhilko    schedule 02.12.2011
comment
Я хочу отобразить промежуточные результаты. Я хорошо вижу результат в дереве ViewResults, но не могу отобразить промежуточные результаты в виде графика. Сводка, совокупность и другие слушатели, кажется, отображают статистику только для корневого элемента, а не для уверенных результатов. К вашему сведению .. Я новичок в jmeter.   -  person wonchi    schedule 07.12.2011


Ответы (2)


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

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

Шаги:

  1. Скомпилируйте приведенный ниже класс как банку.
  2. Поместите банку в папку lib/ext jMeter.
  3. Откройте свой план тестирования, перейдите в меню, чтобы добавить прослушиватель, как обычно, выбрав «График распределенного ответа подрезультата».
  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.

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

person Dave    schedule 21.11.2014

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

person Andrey Pokhilko    schedule 11.12.2011