Running an application from QF-Test
NoteThe Setup sequence creation is the recommended tool to set up your SUT for testing. It results in an advanced setup sequence already prepared for later requirements.
This chapter contains some details in case you want to create a setup sequence yourself.
Various methods to start the SUT
With the Quickstart Wizard QF-Test offers a utility to guide you through the steps of creating a start sequence for your SUT. Please refer to chapter 3 for more information about the Quickstart Wizard.
Nevertheless we also want to describe how to create a start sequence for your
application manually. There are basically two ways to start a Java application as an
SUT from QF-Test. The first one is based on the standard java ...
command line
with its two variants for either starting a class or a jar file. The alternative is
running a script or executable file which will then start the Java program. Indirect
methods like launching the SUT through ant
also fall into this category, as
do Java WebStart.
The following examples show some typical setups. To get more detailed information about the required attributes, please follow the respective links to the reference manual. The tutorial also includes a number of examples.
Independent of how the SUT is started, the respective node should typically be followed immediately by a Wait for client to connect node with an identical Client attribute. Again, see the reference manual for further details.
A standalone script or executable file
If your application is started through a script or a binary executable, create a Start SUT client as follows:
data:image/s3,"s3://crabby-images/7bbb6/7bbb619e4c50b020d8b60e1a9eb91960f3e0418b" alt="Starting the SUT from a script or executable"
- Create a Start SUT client node.
- Assign a name to the client in the Client attribute.
-
Set the Executable to the script or executable that starts
your application. If the program is not located in a directory on the
PATH
, the full path is required. - Set the Directory attribute to the working directory for your application.
-
One thing to watch out for in scripts is redirection of the standard output and
error streams (e.g.
>myapp.log
) which you may want to remove so that the output of the SUT reaches QF-Test and is captured in the run log. Similarly, thestart
command in Windows batch files causes the SUT to detach and keeps the output away from QF-Test.
An application launched through Java WebStart
Using the new connection mechanism, an application launched through Java WebStart can be started directly from QF-Test without the need to modify any JNLP files (so do not use »Extras«-»Create WebStart SUT client starter...«). Instead create a Start SUT client node as follows:
data:image/s3,"s3://crabby-images/7151c/7151ca641139aff3078542d4d8e8d158f7c82853" alt="Starting the SUT through Java WebStart"
- Create a Start SUT client node.
- Assign a name to the client in the Client attribute.
-
Set the Executable attribute to the Java WebStart executable which
is typically called
javaws
and located somewhere inside the JDK or JRE. You'll probably have to specify the full path. -
For Java WebStart the Directory attribute typically is of no
consequence except that Java WebStart is looking in that directory for a file named
.javaws
which can contain settings like debug levels. - Create an entry in the Executable parameters for the executable to specify the URL for the application's JNLP descriptor.
An application started with java -jar <archive>
If your application is normally launched through a command of the form java -jar
<archive>
, create a Start Java SUT client node as follows:
data:image/s3,"s3://crabby-images/5483c/5483c7033b25517281658ab4887c35bcea047fe5" alt="Starting the SUT from a jar archive"
- Create a Start Java SUT client node.
- Assign a name to the client in the Client attribute.
-
If necessary, change the Executable attribute. Its default
value
${qftest:java}
is thejava
executable that QF-Test was started with. - Set the Directory attribute to the working directory for your application.
-
Create two entries in the Executable parameters table for the
executable. Set the first to
-jar
and the second to the name of the archive. Unless the archive is located in the Directory selected above, its full path is required.
An application started with java -classpath <classpath> <class>
If your application is normally launched through a command of the form java
-classpath <classpath> <class>
, create a
Start Java SUT client node as follows:
data:image/s3,"s3://crabby-images/f0a8a/f0a8a49d12dc8427c9b3fb5a16760a9f360afc15" alt="Starting the SUT via the main class"
- Create a Start Java SUT client node.
- Assign a name to the client in the Client attribute.
-
If necessary, change the Executable attribute. Its default
value
${qftest:java}
is thejava
executable that QF-Test was started with. - Set the Directory attribute to the working directory for your application.
-
Set the Class name attribute to the fully qualified name of the
application's starter class (the class with the
main()
method), just like forjava
. -
Create two entries in the Executable parameters
table for the executable. Set the first to
-classpath
and the second to the list of jar files and directories that constitute the classpath. The full path is required for jar archives not located in the Directory selected above. This argument can get very long and hard to edit directly in the table. See subsection 2.2.5 about how to pop up a dialog for more convenient editing.
Web46.1.5
A web application in a browser
Like Swing, JavaFX or SWT clients, a web-based SUT - i.e. a browser - is started as a separate process from within QF-Test. In order to gain access to the internals of the browser and the web page shown with its Document Object Model (DOM), QF-Test embeds a standard browser like Chrome in a special wrapper application. The technology for embedding and accessing those standard browsers enables efficient access to the DOM beyond the browsers' standard interfaces and a unified interface that hides browser differences and enables QF-Test - and thus you - to focus on test automation with a single set of tests for all supported browsers on multiple platforms.
A Start web engine node can be used to launch a browser.
data:image/s3,"s3://crabby-images/c3128/c3128d83498d4936077f2513eeda904cab1fc64b" alt="Launch the browser process"
Browser windows can be opened via a Open browser window node in an already running process.
data:image/s3,"s3://crabby-images/132c5/132c5b7369f8c6e77e83773fb5b97aa322f061cd" alt="Open the web site in the browser"
Note When setting up the startup sequence with the Setup sequence creation or defining your own Directory of browser installation attribute, try pointing QF-Test to a current Firefox installation. On Linux, the standard browser for your distribution may be installed in various places.
Opening a PDF Document
4.2+ QF-Test allows to verify PDF documents. Therefore, a client is started as separate process within QF-Test. In order to gain access to the internals of the PDF document and its components QF-Test analyzes the document in its own viewer.
data:image/s3,"s3://crabby-images/8dd9d/8dd9d0d0983af8ed3fc9ae12fc40bd66869717f4" alt="Opening a PDF Document"
A Start PDF client node can be used to launch the viewer and to open the PDF document.
More information can be found in chapter 18.