All Downloads are FREE. Search and download functionalities are using the official Maven repository.

net.grinder.engine.process.ThreadDataLogger Maven / Gradle / Ivy

The newest version!
// Copyright (C) 2011 Philip Aston
// All rights reserved.
//
// This file is part of The Grinder software distribution. Refer to
// the file LICENSE which is part of The Grinder distribution for
// licensing details. The Grinder distribution is available on the
// Internet at http://grinder.sourceforge.net/
//
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
// FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
// COPYRIGHT HOLDERS OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
// INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
// (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
// SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
// HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
// STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
// ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
// OF THE POSSIBILITY OF SUCH DAMAGE.

package net.grinder.engine.process;

import net.grinder.common.Test;
import net.grinder.statistics.ExpressionView;
import net.grinder.statistics.StatisticExpression;
import net.grinder.statistics.StatisticsSet;

import org.slf4j.Logger;


/**
 * Writes lines to the data log on behalf of a particular thread.
 *
 * @author Philip Aston
 */
class ThreadDataLogger {
  private static final String SEPARATOR = ", ";

  private final Logger m_dataLog;
  private final ExpressionView[] m_expressionViews;
  private final int m_threadNumber;

  private final StringBuilder m_buffer = new StringBuilder();
  private final int m_bufferAfterThreadIDIndex;

  private int m_bufferAfterRunNumberIndex = -1;
  private int m_lastRunNumber = -1;

  public ThreadDataLogger(Logger dataLog,
                          ExpressionView[] expressionViews,
                          int threadNumber) {
    m_dataLog = dataLog;
    m_expressionViews = expressionViews;
    m_threadNumber = threadNumber;

    m_buffer.append(threadNumber);
    m_buffer.append(SEPARATOR);
    m_bufferAfterThreadIDIndex = m_buffer.length();
  }

  public void report(int runNumber,
                     Test test,
                     long timeSinceExecutionStart,
                     StatisticsSet statistics) {

    if (runNumber == m_lastRunNumber && m_lastRunNumber != -1) {
      m_buffer.setLength(m_bufferAfterRunNumberIndex);
    }
    else {
      m_lastRunNumber = runNumber;

      m_buffer.setLength(m_bufferAfterThreadIDIndex);
      m_buffer.append(runNumber);
      m_buffer.append(SEPARATOR);
      m_bufferAfterRunNumberIndex = m_buffer.length();
    }

    m_buffer.append(test.getNumber());

    m_buffer.append(SEPARATOR);
    m_buffer.append(timeSinceExecutionStart);

    for (ExpressionView expressionView : m_expressionViews) {
      m_buffer.append(SEPARATOR);

      final StatisticExpression expression = expressionView.getExpression();

      if (expression.isDouble()) {
        m_buffer.append(expression.getDoubleValue(statistics));
      }
      else {
        m_buffer.append(expression.getLongValue(statistics));
      }
    }

    m_dataLog.info(m_buffer.toString(),
                   new DataLogArguments(m_threadNumber,
                                        runNumber,
                                        test,
                                        timeSinceExecutionStart,
                                        statistics));
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy