⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 logfunction.java

📁 测试工具
💻 JAVA
字号:
/*
 * Licensed to the Apache Software Foundation (ASF) under one or more
 * contributor license agreements.  See the NOTICE file distributed with
 * this work for additional information regarding copyright ownership.
 * The ASF licenses this file to You 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
 * 
 */
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"; //$NON-NLS-1$

	// 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() throws CloneNotSupportedException {
		return super.clone();
	}

	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());
		}

		logDetails(log, stringToLog, priorityString, t);

		return stringToLog;

	}

	// Common output function
	private static void printDetails(java.io.PrintStream ps, String s, Throwable t) {
		String tn = Thread.currentThread().getName();
		if (t != null) {
			ps.print("Log: " + tn + " : " + s + " ");
			t.printStackTrace(ps);
		} else {
			ps.println("Log: " + tn + " : " + s);
		}
	}

	// Routine to perform the output (also used by __logn() function)
	static void logDetails(Logger l, String s, String prio, Throwable t) {
		if (prio.equalsIgnoreCase("OUT")) //$NON-NLS-1
		{
			printDetails(System.out, s, t);
		} else if (prio.equalsIgnoreCase("ERR")) //$NON-NLS-1
		{
			printDetails(System.err, s, t);
		} else {
			// N.B. if the string is not recognised, DEBUG is assumed
			Priority p = Priority.getPriorityForName(prio);
			if (log.isPriorityEnabled(p)) {// Thread method is potentially
											// expensive
				String tn = Thread.currentThread().getName();
				log.log(p, tn + " " + s, t);
			}
		}

	}

	public synchronized 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;
	}

}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -