|
What this is
Other links
The source code
// $Header: /home/cvs/jakarta-jmeter/src/functions/org/apache/jmeter/functions/LogFunction.java,v 1.3 2004/03/30 18:07:07 sebb Exp $
/*
* Copyright 2004 The Apache Software Foundation.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*
*/
package org.apache.jmeter.functions;
import java.io.Serializable;
import java.util.Collection;
import java.util.LinkedList;
import java.util.List;
import org.apache.jmeter.engine.util.CompoundVariable;
import org.apache.jmeter.samplers.SampleResult;
import org.apache.jmeter.samplers.Sampler;
import org.apache.jorphan.logging.LoggingManager;
import org.apache.log.Logger;
import org.apache.log.Priority;
/**
* Function to log a message
*
* Parameters:
* - string
* - log level (optional; defaults to INFO; or DEBUG if unrecognised)
* - throwable message (optional)
*
* Returns:
* - the input string
*
* @version $Revision: 1.3 $ Updated: $Date: 2004/03/30 18:07:07 $
*/
public class LogFunction extends AbstractFunction implements Serializable
{
private static Logger log = LoggingManager.getLoggerForClass();
private static final List desc = new LinkedList();
private static final String KEY = "__log";
// Number of parameters expected - used to reject invalid calls
private static final int MIN_PARAMETER_COUNT = 1;
private static final int MAX_PARAMETER_COUNT = 3;
static {
desc.add("String to be logged");
desc.add("Log level (default INFO)");
desc.add("Throwable text (optional)");
}
private static final String DEFAULT_PRIORITY = "INFO"; //$NON-NLS-1$
private Object[] values;
public LogFunction()
{
}
public Object clone()
{
return new LogFunction();
}
public synchronized String execute(
SampleResult previousResult,
Sampler currentSampler)
throws InvalidVariableException
{
String stringToLog = ((CompoundVariable) values[0]).execute();
String priorityString;
if (values.length > 1){ // We have a default
priorityString= ((CompoundVariable) values[1]).execute();
if (priorityString.length()==0) priorityString= DEFAULT_PRIORITY;
} else {
priorityString = DEFAULT_PRIORITY;
}
Throwable t=null;
if (values.length > 2){ // Throwable wanted
t = new Throwable(((CompoundVariable) values[2]).execute());
}
// N.B. if the string is not recognised, DEBUG is assumed
Priority p = Priority.getPriorityForName(priorityString);
log.log(p,stringToLog,t);
return stringToLog;
}
public void setParameters(Collection parameters)
throws InvalidVariableException
{
values = parameters.toArray();
if ((values.length < MIN_PARAMETER_COUNT)
|| (values.length > MAX_PARAMETER_COUNT))
{
throw new InvalidVariableException(
"Parameter Count not between "
+ MIN_PARAMETER_COUNT
+ " & "
+ MAX_PARAMETER_COUNT);
}
}
public String getReferenceKey()
{
return KEY;
}
public List getArgumentDesc()
{
return desc;
}
}
|
| ... this post is sponsored by my books ... | |
#1 New Release! |
FP Best Seller |
Copyright 1998-2024 Alvin Alexander, alvinalexander.com
All Rights Reserved.
A percentage of advertising revenue from
pages under the /java/jwarehouse
URI on this website is
paid back to open source projects.