Class HTTPSamplerBase
- All Implemented Interfaces:
Serializable
,Cloneable
,ConfigMergabilityIndicator
,Replaceable
,Searchable
,HTTPConstantsInterface
,Sampler
,org.apache.jmeter.testelement.TestElement
,TestIterationListener
,TestStateListener
,ThreadListener
- Direct Known Subclasses:
AjpSampler
,HTTPSampler
,HTTPSamplerProxy
- See Also:
-
Nested Class Summary
Nested classes/interfaces inherited from interface org.apache.jmeter.testelement.TestElement
org.apache.jmeter.testelement.TestElement.Companion
-
Field Summary
Modifier and TypeFieldDescriptionstatic final String
static final String
static final String
static final String
static final boolean
static final String
static final String
static final String
static final int
static final String
static final String
This is the encoding used for the content, i.e.static final String
static final String
static final String
static final String
static final String
static final String
static final String
static final String
static final String
static final String
static final String
static final String
static final String
IP source to use - does not apply to Java HTTP implementation currentlystatic final String
static final String
protected static final int
protected static final int
static final String
static final String
static final String
protected static final String
protected static final String
static final String
static final String
static final String
static final boolean
static final String
static final String
static final String
static final String
static final String
static final String
static final String
static final String
static final int
static final int
A number to indicate that the port has not been set.static final String
static final String
static final int
If the port is not present in a URL, getPort() returns -1static final String
static final String
Fields inherited from interface org.apache.jmeter.protocol.http.util.HTTPConstantsInterface
APPLICATION_X_WWW_FORM_URLENCODED, CACHE_CONTROL, CONNECT, CONNECTION_CLOSE, COPY, DATE, DEFAULT_HTTP_PORT, DEFAULT_HTTP_PORT_STRING, DEFAULT_HTTPS_PORT, DEFAULT_HTTPS_PORT_STRING, DELETE, ENCODING_BROTLI, ENCODING_DEFLATE, ENCODING_GZIP, ETAG, EXPIRES, GET, HEAD, HEADER_AUTHORIZATION, HEADER_CONNECTION, HEADER_CONTENT_DISPOSITION, HEADER_CONTENT_ENCODING, HEADER_CONTENT_LENGTH, HEADER_CONTENT_TYPE, HEADER_COOKIE, HEADER_COOKIE_IN_REQUEST, HEADER_HOST, HEADER_LOCAL_ADDRESS, HEADER_LOCATION, HEADER_SET_COOKIE, HTTP_1_1, IF_MODIFIED_SINCE, IF_NONE_MATCH, KEEP_ALIVE, LAST_MODIFIED, LOCK, MKCALENDAR, MKCOL, MOVE, MULTIPART_FORM_DATA, OPTIONS, PATCH, POST, PROPFIND, PROPPATCH, PROTOCOL_HTTP, PROTOCOL_HTTPS, PUT, REPORT, SC_MOVED_PERMANENTLY, SC_MOVED_TEMPORARILY, SC_PERMANENT_REDIRECT, SC_SEE_OTHER, SC_TEMPORARY_REDIRECT, SEARCH, TRACE, TRANSFER_ENCODING, UNLOCK, VARY
Fields inherited from interface org.apache.jmeter.testelement.TestElement
COMMENTS, Companion, ENABLED, GUI_CLASS, NAME, TEST_CLASS
-
Constructor Summary
-
Method Summary
Modifier and TypeMethodDescriptionvoid
addArgument
(String name, String value) void
addArgument
(String name, String value, String metadata) void
addEncodedArgument
(String name, String value) Add an argument which has already been encodedvoid
addEncodedArgument
(String name, String value, String metaData) void
addEncodedArgument
(String name, String value, String metaData, String contentEncoding) Creates an HTTPArgument and adds it to the current setgetArguments()
of arguments.void
addNonEncodedArgument
(String name, String value, String metadata) void
addNonEncodedArgument
(String name, String value, String metadata, String contentType) void
addTestElement
(org.apache.jmeter.testelement.TestElement el) boolean
applies
(ConfigTestElement configElement) Does configElement apply to Samplervoid
protected HTTPSampleResult
downloadPageResources
(HTTPSampleResult pRes, HTTPSampleResult container, int frameDepth) Download the resources of an HTML page.protected static String
encodeBackSlashes
(String value) protected String
encodeSpaces
(String path) protected HTTPSampleResult
errorResult
(Throwable e, HTTPSampleResult res) Populates the provided HTTPSampleResult with details from the Exception.protected HTTPSampleResult
followRedirects
(HTTPSampleResult res, int frameDepth) Iteratively download the redirect targets of a redirect response.boolean
Get the pool size for concurrent thread pool to get embedded resources.int
static int
getDefaultPort
(String protocol, int port) Get the port number for a URL, applying defaults if necessary.boolean
boolean
boolean
Deprecated.Get the regular expression URLs must match.boolean
int
Get the collection of files as a list.get IP source to use - does not apply to Java HTTP implementation currentlyint
get IP/address source type to useDeprecated.since 3.2 always returns falsegetPath()
int
getPort()
Get the port; apply the default for the protocol if necessary.int
Get the port number from the port string, allowing for trailing blanks.boolean
org.apache.jmeter.testelement.schema.PropertiesAccessor<? extends HTTPSamplerBase,
? extends org.apache.jmeter.protocol.http.sampler.HTTPSamplerBaseSchema> getProps()
Gets the protocol, with default.int
Gets the QueryString attribute of the UrlConfig object, using UTF-8 to encode the URLgetQueryString
(String contentEncoding) Gets the QueryString attribute of the UrlConfig object, using the specified encoding to encode the parameter values put into the URLint
org.apache.jmeter.protocol.http.sampler.HTTPSamplerBaseSchema
boolean
Determine if the file should be sent as the entire Content body, i.e.boolean
Determine if none of the parameters have a name, and if that is the case, it means that the parameter values should be sent as the entity bodystatic String[]
getUrl()
Get the URL, built from its component parts.boolean
boolean
Determine if we should use multipart/form-data or application/x-www-form-urlencoded for the postboolean
Determine if we should use multipart/form-data or application/x-www-form-urlencoded for the poststatic String[]
boolean
boolean
Return if used a concurrent thread pool to get embedded resources.boolean
boolean
Deprecated.since 3.2 always returns falseboolean
Tell whether the default port for the specified protocol is usedstatic boolean
static boolean
protected boolean
isSuccessCode
(int code) Determine if the HTTP status code is successful or not i.e.void
parseArguments
(String queryString) void
parseArguments
(String queryString, String contentEncoding) This method allows a proxy server to send over the raw text from a browser's output stream to be parsed and stored correctly into the UrlConfig object.byte[]
readResponse
(SampleResult sampleResult, InputStream in, long length) Read response from the input stream, converting to MD5 digest if the useMD5 property is set.int
Replace by replaceBy in path and body (arguments) propertiesprotected HTTPSampleResult
resultProcessing
(boolean pAreFollowingRedirect, int frameDepth, HTTPSampleResult pRes) Follow redirects and download page resources if appropriate.sample()
Perform a sample, and return the resultsprotected abstract HTTPSampleResult
Samples the URL passed in and stores the result inHTTPSampleResult
, following redirects and downloading page resources as appropriate.Do a sampling and return its results.final void
setArguments
(Arguments value) void
setAuthManager
(AuthManager value) void
setAutoRedirects
(boolean value) void
setCacheManager
(CacheManager value) void
setConcurrentDwn
(boolean concurrentDwn) void
setConcurrentPool
(String poolSize) void
setConnectTimeout
(String value) void
setContentEncoding
(String charsetName) Sets the value of the encoding to be used for the content.void
setCookieManager
(CookieManager value) void
setDNSResolver
(DNSCacheManager cacheManager) void
setDoBrowserCompatibleMultipart
(boolean value) void
void
setDoMultipart
(boolean value) void
setDoMultipartPost
(boolean value) Deprecated.void
setEmbeddedUrlExcludeRE
(String regex) void
setEmbeddedUrlRE
(String regex) void
setFollowRedirects
(boolean value) void
setHeaderManager
(HeaderManager value) void
setHTTPFiles
(HTTPFileArg[] files) Saves the list of files.void
setImageParser
(boolean parseImages) void
setImplementation
(String value) void
setIpSource
(String value) set IP source to use - does not apply to Java HTTP implementation currentlyvoid
setIpSourceType
(int value) set IP/address source type to usevoid
setKeystoreConfig
(KeystoreConfig value) void
setMD5
(boolean value) void
void
setMonitor
(boolean truth) void
setMonitor
(String value) void
Sets the Path attribute of the UrlConfig object Also calls parseArguments to extract and store any query argumentsvoid
Sets the PATH property; if the request is a GET or DELETE (and the path does not start with http[s]://) it also callsparseArguments(String, String)
to extract and store any query arguments.void
setPort
(int value) void
setPostBodyRaw
(boolean value) void
setProtocol
(String value) void
setProxyHost
(String host) void
setProxyPass
(String pass) void
setProxyPortInt
(String port) void
setProxyScheme
(String schema) void
setProxyUser
(String user) void
setResponseTimeout
(String value) void
setUseKeepAlive
(boolean value) void
Called once for all threads after the end of a test.void
Called once for all threads after the end of a test.void
Each time through a Thread Group's test script, an iteration event is fired for each thread.void
Called just before the start of the test from the main engine thread.void
testStarted
(String host) Called just before the start of the test from the main engine thread.void
Called for each thread after all samples have been processed.void
Called for each thread before starting sampling.toString()
boolean
useMD5()
Methods inherited from class org.apache.jmeter.testelement.AbstractTestElement
addPropertiesValues, addProperty, addProperty, canRemove, clear, clearTemporary, clone, emptyTemporary, equals, getComment, getName, getProperty, getPropertyAsBoolean, getPropertyAsBoolean, getPropertyAsDouble, getPropertyAsFloat, getPropertyAsInt, getPropertyAsInt, getPropertyAsLong, getPropertyAsLong, getPropertyAsString, getPropertyAsString, getPropertyOrNull, getSearchableTokens, getThreadContext, getThreadName, hashCode, isEnabled, isRunningVersion, isTemporary, logProperties, mergeIn, propertyIterator, recoverRunningVersion, removeProperty, setComment, setEnabled, setName, setProperty, setProperty, setProperty, setProperty, setProperty, setProperty, setProperty, setProperty, setProperty, setRunningVersion, setTemporary, setThreadContext, setThreadName, traverse, traverseCollection, traverseMap, traverseProperty
Methods inherited from class java.lang.Object
finalize, getClass, notify, notifyAll, wait, wait, wait
Methods inherited from interface org.apache.jmeter.testelement.TestElement
canRemove, clear, clone, get, get, get, get, get, get, get, get, get, getComment, getName, getOrCreate, getOrCreate, getOrNull, getOrNull, getOrNull, getProperty, getPropertyAsBoolean, getPropertyAsBoolean, getPropertyAsDouble, getPropertyAsFloat, getPropertyAsInt, getPropertyAsInt, getPropertyAsLong, getPropertyAsLong, getPropertyAsString, getPropertyAsString, getPropertyOrNull, getPropertyOrNull, getString, getThreadContext, getThreadName, isEnabled, isRunningVersion, isTemporary, propertyIterator, recoverRunningVersion, removed, removeProperty, removeProperty, set, set, set, set, set, set, set, set, set, setComment, setEnabled, setName, setProperty, setProperty, setProperty, setProperty, setProperty, setProperty, setProperty, setProperty, setProperty, setRunningVersion, setTemporary, setThreadContext, setThreadName, traverse
-
Field Details
-
ARGUMENTS
- See Also:
-
AUTH_MANAGER
- See Also:
-
COOKIE_MANAGER
- See Also:
-
KEYSTORE_CONFIG
- See Also:
-
SAMPLE_TIMEOUT
- See Also:
-
CACHE_MANAGER
- See Also:
-
HEADER_MANAGER
- See Also:
-
DNS_CACHE_MANAGER
- See Also:
-
DOMAIN
- See Also:
-
PORT
- See Also:
-
PROXYSCHEME
- See Also:
-
PROXYHOST
- See Also:
-
PROXYPORT
- See Also:
-
PROXYUSER
- See Also:
-
PROXYPASS
- See Also:
-
CONNECT_TIMEOUT
- See Also:
-
RESPONSE_TIMEOUT
- See Also:
-
METHOD
- See Also:
-
CONTENT_ENCODING
This is the encoding used for the content, i.e. the charset name, not the header "Content-Encoding"- See Also:
-
IMPLEMENTATION
- See Also:
-
PATH
- See Also:
-
FOLLOW_REDIRECTS
-
AUTO_REDIRECTS
- See Also:
-
PROTOCOL
- See Also:
-
URL
- See Also:
-
IP_SOURCE
IP source to use - does not apply to Java HTTP implementation currently- See Also:
-
IP_SOURCE_TYPE
- See Also:
-
USE_KEEPALIVE
- See Also:
-
DO_MULTIPART_POST
- See Also:
-
BROWSER_COMPATIBLE_MULTIPART
- See Also:
-
CONCURRENT_DWN
- See Also:
-
CONCURRENT_POOL
- See Also:
-
CONCURRENT_POOL_SIZE
public static final int CONCURRENT_POOL_SIZE- See Also:
-
BROWSER_COMPATIBLE_MULTIPART_MODE_DEFAULT
public static final boolean BROWSER_COMPATIBLE_MULTIPART_MODE_DEFAULT- See Also:
-
SOURCE_TYPE_DEFAULT
public static final int SOURCE_TYPE_DEFAULT -
DEFAULT_METHOD
- See Also:
-
CONTENT_TYPE
- See Also:
-
IMAGE_PARSER
- See Also:
-
EMBEDDED_URL_RE
- See Also:
-
EMBEDDED_URL_EXCLUDE_RE
- See Also:
-
MONITOR
- See Also:
-
MD5
- See Also:
-
UNSPECIFIED_PORT
public static final int UNSPECIFIED_PORTA number to indicate that the port has not been set.- See Also:
-
UNSPECIFIED_PORT_AS_STRING
- See Also:
-
URL_UNSPECIFIED_PORT
public static final int URL_UNSPECIFIED_PORTIf the port is not present in a URL, getPort() returns -1- See Also:
-
URL_UNSPECIFIED_PORT_AS_STRING
- See Also:
-
NON_HTTP_RESPONSE_CODE
- See Also:
-
NON_HTTP_RESPONSE_MESSAGE
- See Also:
-
POST_BODY_RAW
- See Also:
-
POST_BODY_RAW_DEFAULT
public static final boolean POST_BODY_RAW_DEFAULT- See Also:
-
MAX_REDIRECTS
protected static final int MAX_REDIRECTS -
MAX_FRAME_DEPTH
protected static final int MAX_FRAME_DEPTH
-
-
Constructor Details
-
HTTPSamplerBase
protected HTTPSamplerBase()
-
-
Method Details
-
getSchema
public org.apache.jmeter.protocol.http.sampler.HTTPSamplerBaseSchema getSchema()- Specified by:
getSchema
in interfaceorg.apache.jmeter.testelement.TestElement
-
getProps
public org.apache.jmeter.testelement.schema.PropertiesAccessor<? extends HTTPSamplerBase,? extends org.apache.jmeter.protocol.http.sampler.HTTPSamplerBaseSchema> getProps()- Specified by:
getProps
in interfaceorg.apache.jmeter.testelement.TestElement
-
getSourceTypeList
-
getSendFileAsPostBody
public boolean getSendFileAsPostBody()Determine if the file should be sent as the entire Content body, i.e. without any additional wrapping.- Returns:
- true if specified file is to be sent as the body, i.e. there is a single file entry which has a non-empty path and an empty Parameter name.
-
getSendParameterValuesAsPostBody
public boolean getSendParameterValuesAsPostBody()Determine if none of the parameters have a name, and if that is the case, it means that the parameter values should be sent as the entity body- Returns:
true
if there are parameters and none of these have a name specified, orgetPostBodyRaw()
returnstrue
-
getUseMultipartForPost
public boolean getUseMultipartForPost()Determine if we should use multipart/form-data or application/x-www-form-urlencoded for the post- Returns:
- true if multipart/form-data should be used and method is POST
-
getUseMultipart
public boolean getUseMultipart()Determine if we should use multipart/form-data or application/x-www-form-urlencoded for the post- Returns:
- true if multipart/form-data should be used and method is POST
-
setProtocol
-
getProtocol
Gets the protocol, with default.- Returns:
- the protocol
-
setPath
Sets the Path attribute of the UrlConfig object Also calls parseArguments to extract and store any query arguments- Parameters:
path
- The new Path value
-
setPath
Sets the PATH property; if the request is a GET or DELETE (and the path does not start with http[s]://) it also callsparseArguments(String, String)
to extract and store any query arguments.- Parameters:
path
- The new Path valuecontentEncoding
- The encoding used for the querystring parameter values
-
getPath
-
setFollowRedirects
public void setFollowRedirects(boolean value) -
getFollowRedirects
public boolean getFollowRedirects() -
setAutoRedirects
public void setAutoRedirects(boolean value) -
getAutoRedirects
public boolean getAutoRedirects() -
setMethod
-
getMethod
-
setContentEncoding
Sets the value of the encoding to be used for the content.- Parameters:
charsetName
- the name of the encoding to be used
-
getContentEncoding
- Returns:
- the encoding of the content, i.e. its charset name
-
setUseKeepAlive
public void setUseKeepAlive(boolean value) -
getUseKeepAlive
public boolean getUseKeepAlive() -
setDoMultipartPost
Deprecated.- Parameters:
value
- flag whether multiparts should be used
-
getDoMultipartPost
Deprecated.usegetDoMultipart()
- Returns:
- flag whether multiparts should be used
-
setDoMultipart
public void setDoMultipart(boolean value) -
getDoMultipart
public boolean getDoMultipart() -
setDoBrowserCompatibleMultipart
public void setDoBrowserCompatibleMultipart(boolean value) -
getDoBrowserCompatibleMultipart
public boolean getDoBrowserCompatibleMultipart() -
setMonitor
-
setMonitor
public void setMonitor(boolean truth) -
getMonitor
Deprecated.since 3.2 always returns false- Returns:
- boolean
-
isMonitor
Deprecated.since 3.2 always returns false- Returns:
- boolean
-
setImplementation
-
getImplementation
-
useMD5
public boolean useMD5() -
setMD5
public void setMD5(boolean value) -
addEncodedArgument
Add an argument which has already been encoded- Parameters:
name
- name of the argumentvalue
- value of the argument
-
addEncodedArgument
Creates an HTTPArgument and adds it to the current setgetArguments()
of arguments.- Parameters:
name
- - the parameter namevalue
- - the parameter valuemetaData
- - normally just '='contentEncoding
- - the encoding, may be null
-
addEncodedArgument
-
addNonEncodedArgument
-
addNonEncodedArgument
-
addArgument
-
addArgument
-
hasArguments
public boolean hasArguments() -
addTestElement
public void addTestElement(org.apache.jmeter.testelement.TestElement el) Description copied from class:AbstractTestElement
- Specified by:
addTestElement
in interfaceorg.apache.jmeter.testelement.TestElement
- Overrides:
addTestElement
in classAbstractTestElement
-
clearTestElementChildren
public void clearTestElementChildren()Default implementation - does nothing
Clears the Header Manager property so subsequent loops don't keep merging more elements
- Specified by:
clearTestElementChildren
in interfaceorg.apache.jmeter.testelement.TestElement
- Overrides:
clearTestElementChildren
in classAbstractTestElement
-
setPort
public void setPort(int value) -
getDefaultPort
Get the port number for a URL, applying defaults if necessary. (Called by CookieManager.)- Parameters:
protocol
- fromURL.getProtocol()
port
- number fromURL.getPort()
- Returns:
- the default port for the protocol
-
getPortIfSpecified
public int getPortIfSpecified()Get the port number from the port string, allowing for trailing blanks.- Returns:
- port number or UNSPECIFIED_PORT (== 0)
-
isProtocolDefaultPort
public boolean isProtocolDefaultPort()Tell whether the default port for the specified protocol is used- Returns:
- true if the default port number for the protocol is used, false otherwise
-
getPort
public int getPort()Get the port; apply the default for the protocol if necessary.- Returns:
- the port number, with default applied if required.
-
setDomain
-
getDomain
-
setConnectTimeout
-
getConnectTimeout
public int getConnectTimeout() -
setResponseTimeout
-
getResponseTimeout
public int getResponseTimeout() -
getProxyScheme
-
setProxyScheme
-
getProxyHost
-
setProxyHost
-
getProxyPortInt
public int getProxyPortInt() -
setProxyPortInt
-
getProxyUser
-
setProxyUser
-
getProxyPass
-
setProxyPass
-
setArguments
-
getArguments
-
setPostBodyRaw
public void setPostBodyRaw(boolean value) - Parameters:
value
- Boolean that indicates body will be sent as is
-
getPostBodyRaw
public boolean getPostBodyRaw()- Returns:
- boolean that indicates body will be sent as is
-
setAuthManager
-
getAuthManager
-
setHeaderManager
-
getHeaderManager
-
setCookieManager
-
getCookieManager
-
setKeystoreConfig
-
getKeystoreConfig
-
setCacheManager
-
getCacheManager
-
getDNSResolver
-
setDNSResolver
-
isImageParser
public boolean isImageParser() -
setImageParser
public void setImageParser(boolean parseImages) -
getEmbeddedUrlRE
Get the regular expression URLs must match.- Returns:
- regular expression (or empty) string
-
setEmbeddedUrlRE
-
getEmbededUrlExcludeRE
- Returns:
- the regular (as String) expression that embedded URLs must not match
-
setEmbeddedUrlExcludeRE
-
errorResult
Populates the provided HTTPSampleResult with details from the Exception. Does not create a new instance, so should not be used directly to add a subsample.- Parameters:
e
- Exception representing the error.res
- SampleResult to be modified- Returns:
- the modified sampling result containing details of the Exception.
-
getUrl
Get the URL, built from its component parts.As a special case, if the path starts with "http[s]://", then the path is assumed to be the entire URL.
- Returns:
- The URL to be requested by this sampler.
- Throws:
MalformedURLException
- if url is malformed
-
getQueryString
Gets the QueryString attribute of the UrlConfig object, using UTF-8 to encode the URL- Returns:
- the QueryString value
-
getQueryString
Gets the QueryString attribute of the UrlConfig object, using the specified encoding to encode the parameter values put into the URL- Parameters:
contentEncoding
- the encoding to use for encoding parameter values- Returns:
- the QueryString value
-
parseArguments
This method allows a proxy server to send over the raw text from a browser's output stream to be parsed and stored correctly into the UrlConfig object. For each name found, addArgument() is called- Parameters:
queryString
- - the query string, might be the post body of a http post request.contentEncoding
- - the content encoding of the query string; if non-null then it is used to decode the
-
parseArguments
-
toString
-
sample
Do a sampling and return its results. -
sample
Perform a sample, and return the results- Returns:
- results of the sampling
-
sample
protected abstract HTTPSampleResult sample(URL u, String method, boolean areFollowingRedirect, int depth) Samples the URL passed in and stores the result inHTTPSampleResult
, following redirects and downloading page resources as appropriate.When getting a redirect target, redirects are not followed and resources are not downloaded. The caller will take care of this.
- Parameters:
u
- URL to samplemethod
- HTTP method: GET, POST,...areFollowingRedirect
- whether we're getting a redirect targetdepth
- Depth of this target in the frame structure. Used only to prevent infinite recursion.- Returns:
- results of the sampling, can be null if u is in CacheManager
-
downloadPageResources
protected HTTPSampleResult downloadPageResources(HTTPSampleResult pRes, HTTPSampleResult container, int frameDepth) Download the resources of an HTML page.- Parameters:
pRes
- result of the initial request - must contain an HTML responsecontainer
- for storing the results, if anyframeDepth
- Depth of this target in the frame structure. Used only to prevent infinite recursion.- Returns:
- res if no resources exist, otherwise the "Container" result with one subsample per request issued
-
encodeSpaces
-
testEnded
public void testEnded()Called once for all threads after the end of a test. This will use the same element instances as at the start of the test.
N.B. testStarted() and testEnded() are called from different threads.
- Specified by:
testEnded
in interfaceTestStateListener
- See Also:
-
testEnded
Called once for all threads after the end of a test. This will use the same element instances as at the start of the test.
N.B. testStarted() and testEnded() are called from different threads.
- Specified by:
testEnded
in interfaceTestStateListener
- Parameters:
host
- name of host- See Also:
-
testStarted
public void testStarted()Called just before the start of the test from the main engine thread. This is before the test elements are cloned. Note that not all the test variables will have been set up at this point.
N.B. testStarted() and testEnded() are called from different threads.
- Specified by:
testStarted
in interfaceTestStateListener
- See Also:
-
testStarted
Called just before the start of the test from the main engine thread. This is before the test elements are cloned. Note that not all the test variables will have been set up at this point.
N.B. testStarted() and testEnded() are called from different threads.
- Specified by:
testStarted
in interfaceTestStateListener
- Parameters:
host
- name of host- See Also:
-
followRedirects
Iteratively download the redirect targets of a redirect response.The returned result will contain one subsample for each request issued, including the original one that was passed in. It will be an HTTPSampleResult that should mostly look as if the final destination of the redirect chain had been obtained in a single shot.
- Parameters:
res
- result of the initial request - must be a redirect responseframeDepth
- Depth of this target in the frame structure. Used only to prevent infinite recursion.- Returns:
- "Container" result with one subsample per request issued
-
resultProcessing
protected HTTPSampleResult resultProcessing(boolean pAreFollowingRedirect, int frameDepth, HTTPSampleResult pRes) Follow redirects and download page resources if appropriate. this works, but the container stuff here is what's doing it. followRedirects() is actually doing the work to make sure we have only one container to make this work more naturally, I think this method - sample() - needs to take an HTTPSamplerResult container parameter instead of a boolean:areFollowingRedirect.- Parameters:
pAreFollowingRedirect
- flag whether we are getting a redirect targetframeDepth
- Depth of this target in the frame structure. Used only to prevent infinite recursion.pRes
- sample result to process- Returns:
- the sample result
-
isSuccessCode
protected boolean isSuccessCode(int code) Determine if the HTTP status code is successful or not i.e. in range 200 to 399 inclusive- Parameters:
code
- status code to check- Returns:
- whether in range 200-399 or not
-
encodeBackSlashes
-
getHTTPFiles
Get the collection of files as a list. The list is built up from the filename/filefield/mimetype properties, plus any additional entries saved in the FILE_ARGS property. If there are no valid file entries, then an empty list is returned.- Returns:
- an array of file arguments (never null)
-
getHTTPFileCount
public int getHTTPFileCount() -
setHTTPFiles
Saves the list of files. The first file is saved in the Filename/field/mimetype properties. Any additional files are saved in the FILE_ARGS array.- Parameters:
files
- list of files to save
-
getValidMethodsAsArray
-
isSecure
-
isSecure
-
threadStarted
public void threadStarted()Description copied from interface:ThreadListener
Called for each thread before starting sampling. WARNING: this is called before any Config test elements are processed, so any properties they define will not have been merged in yet. See org.apache.jmeter.threads.JMeterThread#threadStarted()- Specified by:
threadStarted
in interfaceThreadListener
-
threadFinished
public void threadFinished()Description copied from interface:ThreadListener
Called for each thread after all samples have been processed. See org.apache.jmeter.threads.JMeterThread#threadFinished(org.apache.jmeter.engine.event.LoopIterationListener)- Specified by:
threadFinished
in interfaceThreadListener
-
testIterationStart
Description copied from interface:TestIterationListener
Each time through a Thread Group's test script, an iteration event is fired for each thread. This will be after the test elements have been cloned, so in general the instance will not be the same as the ones the start/end methods call.- Specified by:
testIterationStart
in interfaceTestIterationListener
- Parameters:
event
- the iteration event
-
readResponse
public byte[] readResponse(SampleResult sampleResult, InputStream in, long length) throws IOException Read response from the input stream, converting to MD5 digest if the useMD5 property is set.For the MD5 case, the result byte count is set to the size of the original response.
Closes the inputStream
- Parameters:
sampleResult
- sample to store information about the response intoin
- input stream from which to read the responselength
- expected input length or zero- Returns:
- the response or the MD5 of the response
- Throws:
IOException
- if reading the result fails
-
setIpSource
set IP source to use - does not apply to Java HTTP implementation currently- Parameters:
value
- IP source to use
-
getIpSource
get IP source to use - does not apply to Java HTTP implementation currently- Returns:
- IP source to use
-
setIpSourceType
public void setIpSourceType(int value) set IP/address source type to use- Parameters:
value
- type of the IP/address source
-
getIpSourceType
public int getIpSourceType()get IP/address source type to use- Returns:
- address source type
-
isConcurrentDwn
public boolean isConcurrentDwn()Return if used a concurrent thread pool to get embedded resources.- Returns:
- true if used
-
setConcurrentDwn
public void setConcurrentDwn(boolean concurrentDwn) -
getConcurrentPool
Get the pool size for concurrent thread pool to get embedded resources.- Returns:
- the pool size
-
setConcurrentPool
-
applies
Description copied from class:AbstractSampler
Does configElement apply to Sampler- Specified by:
applies
in interfaceConfigMergabilityIndicator
- Overrides:
applies
in classAbstractSampler
- Parameters:
configElement
-ConfigTestElement
- Returns:
- boolean
- See Also:
-
replace
Replace by replaceBy in path and body (arguments) properties- Specified by:
replace
in interfaceReplaceable
- Parameters:
regex
- Regular expression to search forreplaceBy
- Text used as replacementcaseSensitive
- flag, whether search should be done case sensitive- Returns:
- number of replacements
- Throws:
Exception
- when something fails while replacing
-
getDoMultipart()