|
What this is
Other links
The source code
// $Header: /home/cvs/jakarta-jmeter/src/components/org/apache/jmeter/assertions/SizeAssertion.java,v 1.14 2004/02/13 01:27:26 sebb Exp $
/*
* Copyright 2001-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.assertions;
import java.io.Serializable;
import java.text.MessageFormat;
import org.apache.jmeter.samplers.SampleResult;
import org.apache.jmeter.testelement.AbstractTestElement;
import org.apache.jmeter.testelement.property.IntegerProperty;
import org.apache.jmeter.testelement.property.LongProperty;
import org.apache.jmeter.util.JMeterUtils;
/**
* Checks if the results of a Sample matches a particular size.
*
* @author Wolfram Rittmeyer
* @version $Revision: 1.14 $, $Date: 2004/02/13 01:27:26 $
*/
public class SizeAssertion
extends AbstractTestElement
implements Serializable, Assertion
{
private String comparatorErrorMessage = "ERROR!";
//* Static int to signify the type of logical comparitor to assert
public final static int EQUAL = 1;
public final static int NOTEQUAL = 2;
public final static int GREATERTHAN = 3;
public final static int LESSTHAN = 4;
public final static int GREATERTHANEQUAL = 5;
public final static int LESSTHANEQUAL = 6;
/** Key for storing assertion-informations in the jmx-file. */
private static final String SIZE_KEY = "SizeAssertion.size";
private static final String OPERATOR_KEY = "SizeAssertion.operator";
byte[] resultData;
/**
* Returns the result of the Assertion. Here it checks wether the
* Sample took to long to be considered successful. If so an AssertionResult
* containing a FailureMessage will be returned. Otherwise the returned
* AssertionResult will reflect the success of the Sample.
*/
public AssertionResult getResult(SampleResult response)
{
AssertionResult result = new AssertionResult();
result.setFailure(false);
if (response.getResponseData() == null)
{
return setResultForNull(result);
}
// is the Sample the correct size?
resultData = response.getResponseData();
long resultSize = resultData.length;
if ((!(compareSize(resultSize)) && (getAllowedSize() > 0)))
{
result.setFailure(true);
Object[] arguments =
{
new Long(resultSize),
comparatorErrorMessage,
new Long(getAllowedSize())};
String message =
MessageFormat.format(
JMeterUtils.getResString("size_assertion_failure"),
arguments);
result.setFailureMessage(message);
}
return result;
}
/**
* Returns the size in bytes to be asserted. A duration of 0 indicates this
* assertion is to be ignored.
*/
public long getAllowedSize()
{
return getPropertyAsLong(SIZE_KEY);
}
/******
* set the Operator
******/
public void setCompOper(int operator)
{
setProperty(new IntegerProperty(OPERATOR_KEY, operator));
}
protected AssertionResult setResultForNull(AssertionResult result)
{
result.setError(false);
result.setFailure(true);
result.setFailureMessage("Response was null");
return result;
}
/**
* Returns the operator to be asserted. EQUAL = 1, NOTEQUAL = 2
* GREATERTHAN = 3,LESSTHAN = 4,GREATERTHANEQUAL = 5,LESSTHANEQUAL = 6
*/
public int getCompOper()
{
return getPropertyAsInt(OPERATOR_KEY);
}
/**
* Set the size that shall be asserted.
*
* @param size - a number of bytes. Is not allowed to be negative. Use
* Long.MAX_VALUE to indicate illegal or empty inputs.
* This will result in not checking the assertion.
*
* @throws IllegalArgumentException If
|
... 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.