A user on the JMeter mailing list posted his solution using the HTML link parser[1] to spider a site. The spidering consists of clicking a link at random from the links parsed from the last accessed page.
The test looks like
data:image/s3,"s3://crabby-images/74671/74671673625f2c7b377ab9862637bac7f4d130ba" alt=""
The Initial Request is used by the HTML Link Parser to get the initial set of urls from which one will be chosen.
The While controllers condition is simply true , since we want it to loop forever.
The Spider HTTP Sampler has a path of .*.
The If Controller has a condition ${__javaScript(!${JMeterThread.last_sample_ok})}
This simply checks if the last sample fetched failed (by .* or because it fetched a CGI/PDF which cant be parsed for links and if so reexecutes the Initial Request.)
There are numerous tweaks you can implement , you might not execute the initial request, it might be one at random that you pick , or the last successful request. You might choose to check the request being made to restrict the paths.
Note that this clicks a link at random from a set of links acquired from the previously clicked page. This cannot ensure that a link is not repeated and cannot ensure that all links are fetched.
[1] http://jakarta.apache.org/jmeter/usermanual/component_reference.html#HTML_Link_Parser
1 comment:
Also, the HTML Link parser is unable to distinguish between GET links and POST links. What the parser really needs is an option to ignore POST/form requests. It's nearly unusable as-is.
Post a Comment