Hi Immo,
the desired test script example would exactly look like a normal WebTest
except the header and footer as mentioned e.g.
<invoke url="..." />
<clickLink label="..." />
<verifyText text="..." />
...
Several such test script pieces will be assembled to the whole test.
The complete WebTest is then wrapped by a JMeter testplan.
Hope that makes things clearer?
Hi Stefan,
That's really tremendous work; thanks for undertaking it. Will you be producing
some example test scripts that exploit these new features? These would make it
easier to understand how to get the best out of your efforts.
I'm not actually using WebTest or JMeter at this moment, but a project that may
be about to start will have such requirements.
Best regards,
Immo
-----Original Message-----
From: [email protected] [mailto:[email protected]] On
Behalf Of Stefan Frenzel
Sent: 22 July 2009 19:28
To: [email protected]
Subject: [Webtest] WebTest properties and JMeter integration
Hello list,
I've begun integrating WebTest in JMeter. It works. However, there are a
few limitations e.g. static and dynamic properties (see below). But
first I want to introduce you in the procedure getting my WebTest
integrated.
An user can write or capture (WebTestRecorder) several pieces/modules of
a WebTest in XML format (XML entities) without taking care of the
Ant/WebTest overhead (<project>, <target>, <webtest> etc.). Then he or
she can start JMeter, add a WebTestSampler, add/order/enable those
modules and run the test according to JMeter's ThreadGroup parameters.
(WebTest configurations (<config>) can be defined in a property file as
well as in a JMeter WebTestDefaultConfiguration testelement.)
How does it work behind the scenes? First of all, the XML entity inputs
must be assembled (String concatenation) and the Ant/WebTest "overhead"
as mentioned above must be added.
Then we have to initialize an Ant Project object, give it a
ProjectHelper reference and let it parse our XML string. Because Ant
uses SaX parsing we need to overwrite its ElementHandler's
onStartElement() and onEndElement() methods in order to create and link
WebTests objects. For example if onStartElement() gets a <invoke> tag,
we have to create an InvokePage object (via Class.newInstance()) and add
it to the WebtestTask object and so on.
After that the WebtestTask object is passed to the WebTestSampler. But
unfortunately the WebtestTask object isn't thread-safe and cannot be
reused several times (because of destroyed contexts, etc.) from the
WebTestSampler sample() method called by each JMeterThread. To solve
this issue I added a clone() method to WebtestTask which ensures that
each JMeterThread uses a deep copy of WebtestTask to execute(). That's it.
What do you think about this? In my opinion it's dirty, but I don't know
how to do it alternatively. Any ideas?
My problem is that many WebTests need static (Ant) or dynamic (WebTest)
properties which are created by <property>, <storeProperty> or something
else. I saw that in the internals of WebTest there is a
WebTestPropertyHelper which extends Ant'S PropertyHelper. Also it seems
like this WebTestPropertyHelper is added to the Project as a reference.
However, the replaceProperties() methods are never called when executing
the execute() method at WebtestTask (which delegates to the execute()
methods of its steps). The result is that no properties get evaluated
and the steps which follow have something like "${}" or "#{}" in their
attribute values.
Do you have any suggestions which can solve this problem? What about
RuntimeConfigurable and maybeConfigure()?
Thank you in advance.
Greets, Stefan.
_______________________________________________
WebTest mailing list
[email protected]
http://lists.canoo.com/mailman/listinfo/webtest
_______________________________________________
WebTest mailing list
[email protected]
http://lists.canoo.com/mailman/listinfo/webtest
_______________________________________________
WebTest mailing list
[email protected]
http://lists.canoo.com/mailman/listinfo/webtest