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

com.eviware.soapui.impl.wsdl.loadtest.log.LoadTestLogErrorEntry Maven / Gradle / Ivy

The newest version!
/*
 *  soapUI, copyright (C) 2004-2011 smartbear.com 
 *
 *  soapUI is free software; you can redistribute it and/or modify it under the 
 *  terms of version 2.1 of the GNU Lesser General Public License as published by 
 *  the Free Software Foundation.
 *
 *  soapUI is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without 
 *  even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. 
 *  See the GNU Lesser General Public License for more details at gnu.org.
 */

package com.eviware.soapui.impl.wsdl.loadtest.log;

import java.io.IOException;
import java.io.PrintWriter;
import java.util.Date;

import javax.swing.ImageIcon;

import com.eviware.soapui.model.testsuite.TestStepResult;
import com.eviware.soapui.support.action.swing.ActionList;

/**
 * An error entry in the LoadTest Log
 * 
 * @author Ole.Matzura
 */

public class LoadTestLogErrorEntry implements LoadTestLogEntry
{
	private final String error;
	private TestStepResult result;
	private String type;
	private ImageIcon icon;
	private long timestamp;
	private boolean discarded;
	private String targetStepName;
	private final int threadIndex;

	public LoadTestLogErrorEntry( String type, String error, TestStepResult result, ImageIcon icon, int threadIndex )
	{
		this.icon = icon;
		this.type = type;
		this.error = error;
		this.result = result;
		this.threadIndex = threadIndex;
		this.targetStepName = result == null ? null : result.getTestStep().getName();

		timestamp = result == null ? System.currentTimeMillis() : result.getTimeStamp();
	}

	public LoadTestLogErrorEntry( String type, String message, ImageIcon icon, int threadIndex )
	{
		this.type = type;
		this.error = message;
		this.icon = icon;
		this.threadIndex = threadIndex;

		targetStepName = "- Total -";

		timestamp = System.currentTimeMillis();
	}

	public String getMessage()
	{
		if( discarded )
			return error + " [discarded]";
		else
			return error + " [threadIndex=" + threadIndex + "]";
	}

	public TestStepResult getTestStepResult()
	{
		return result;
	}

	public long getTimeStamp()
	{
		return timestamp;
	}

	public String getTargetStepName()
	{
		return targetStepName;
	}

	public ImageIcon getIcon()
	{
		return icon;
	}

	public String getType()
	{
		return type;
	}

	public boolean isError()
	{
		return true;
	}

	public ActionList getActions()
	{
		return result == null ? null : result.getActions();
	}

	public void exportToFile( String fileName ) throws IOException
	{
		PrintWriter writer = new PrintWriter( fileName );

		writer.write( new Date( timestamp ).toString() );
		writer.write( ":" );
		writer.write( targetStepName );
		writer.write( ":" );
		writer.write( error );
		writer.write( ":" );
		writer.print( threadIndex );
		writer.println();
		if( result != null )
		{
			writer.println( "----------------------------------------------------" );
			result.writeTo( writer );
		}
		else if( discarded )
		{
			writer.println( "-> Discarded" );
		}

		writer.close();
	}

	public void discard()
	{
		result = null;
		discarded = true;
	}

	public boolean isDiscarded()
	{
		return discarded;
	}
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy