data:image/s3,"s3://crabby-images/17525/1752507e2d6f7f89e23906675eb2b642bb456d42" alt=""
data:image/s3,"s3://crabby-images/11025/1102519e0b779f9593940f1467e8d9f7b32d787e" alt="News"
data:image/s3,"s3://crabby-images/00667/00667add47ae3ec046a80bee2d82347243f60d08" alt="Features"
data:image/s3,"s3://crabby-images/69851/698519136f7e04aaf7bfeaab61af4ab6ae6e6725" alt="Changes"
data:image/s3,"s3://crabby-images/05894/0589400321e4d078aebd839dc46304c30900842b" alt="Todo"
data:image/s3,"s3://crabby-images/74dfe/74dfe2d4921bc634330e2f689a39353b00ead980" alt="Contributors"
data:image/s3,"s3://crabby-images/45540/455408563b56568b45d3bd1cdcb61e4192d237c8" alt=""
data:image/s3,"s3://crabby-images/98e1c/98e1c29701af22aad905eade0fa8d14a101dbc9e" alt="Downloads"
data:image/s3,"s3://crabby-images/45540/455408563b56568b45d3bd1cdcb61e4192d237c8" alt=""
data:image/s3,"s3://crabby-images/19794/19794c1568dd2d4f90530162111157bf1dbb032b" alt="Installation"
data:image/s3,"s3://crabby-images/f5509/f55096ac3eeee36d6c52547e6e85afe73ec00c32" alt="Configuration"
data:image/s3,"s3://crabby-images/5e126/5e12650271f8ed4db7da162e8ba2a47b6766632c" alt="Using"
data:image/s3,"s3://crabby-images/15504/15504fe55e66924ab4ecaf8d0085d87235e695a5" alt="Servlet Sample"
data:image/s3,"s3://crabby-images/3b85c/3b85cbb4d9acb4ec2524088bffac0aaac853f1ab" alt="FAQ"
data:image/s3,"s3://crabby-images/45540/455408563b56568b45d3bd1cdcb61e4192d237c8" alt=""
data:image/s3,"s3://crabby-images/2e767/2e767db42149d3bfac1e03be6f8429eb2b82c50e" alt="Architecture"
data:image/s3,"s3://crabby-images/45540/455408563b56568b45d3bd1cdcb61e4192d237c8" alt=""
data:image/s3,"s3://crabby-images/bb7f5/bb7f51656d17c4f88f0f2e0808690faa53e2fee6" alt="Ant integration"
data:image/s3,"s3://crabby-images/44059/440597e465a255e8c93f49daebd738564358478f" alt="Servlet Engines"
data:image/s3,"s3://crabby-images/45540/455408563b56568b45d3bd1cdcb61e4192d237c8" alt=""
data:image/s3,"s3://crabby-images/9d4c8/9d4c806f71c90033f719cc89ca1d31538679d659" alt="API Reference"
data:image/s3,"s3://crabby-images/45540/455408563b56568b45d3bd1cdcb61e4192d237c8" alt=""
data:image/s3,"s3://crabby-images/f9490/f949036b40b79851b25cac9ca89841438caec1f1" alt="Support"
data:image/s3,"s3://crabby-images/2e155/2e155115450191190505d3d0685ea12f2d8c723d" alt="Statistics"
data:image/s3,"s3://crabby-images/2e541/2e541a31db6ece51a1c17e65abe0001359185f16" alt=""
|
data:image/s3,"s3://crabby-images/392e2/392e2ed1cd67007532185d34ec3425dfbed3abc9" alt="J2EEUnit Architecture"
The process is as follows for each XXX test method of your
TestYYY test class :
-
JUnit calls your the
TestYYY.runTest() method (inherited
from ServletTestCase ). This later looks for a
beginXXX(ServletTestRequest) method. If one is found,
it executes it. This is executed on the client side (i.e. not in a
server engine). The ServletTestRequest
parameter passed to the beginXXX() method is used
to set the HTTP headers, the HTTP parameters, ... that will be
sent in step 2 to the Redirector proxy.
-
The
TestYYY.runTest() method then opens an HTTP
connection to the Redirector proxy. All the parameters set up
in the beginXXX() method are put in the HTTP request
(HTTP headers, HTTP parameters, ...)
-
The Redirector proxy acts as a proxy for your
TestYYY
test class, but on the server side. It means that TestYYY
is instantiated twice : once on the client side and once on the
server side. The client side instance is used for executing the
beginXXX() and endXXX() methods (see
steps 1 and 8) and the server side instance is used for executing
the testXXX() methods (see step 4). The Redirector
proxy does the following :
-
creates an instance of
TestYYY using reflection. It
sets by reflection the J2EEUnit implicit objects (see the section
below on Servlet Redriector Proxy and JSP Redirector Proxy for a
list of available objects).
-
creates instances of J2EEUnit wrappers for some server objects
(
HttpServletRequest , ServletConfig ,
ServletContext , ...). This is to be able to
to override some methods in order to return simulated values.
For example, the J2EEUnit framework can simulate an URI (i.e.
act as if this URI was called instead of the Redirector proxy
URI). Thus, the getServerName() , getServerPort() ,
getRequestURI() , ... methods return values based
on the simulated URI (if there is any defined by the user).
-
creates an HTTP Session if the user has expressed the wish
(using the
ServletTestRequest.setAutomaticSession(boolean)
code in the beingXXX() method. By default a session
is always created) and it fills by reflection the
session implicit object.
-
The
TestYYY.setUp() , TestYYY.testXXX() and
tearDown() methods are executed (in that order). They
are called by the Redirector proxy using reflection.
-
Your
TestYYY.testXXX() method calls your server
side code, executing the test and using the JUnit asserts to assert
the result (assert() , assertEquals() ,
fail() , ...)
-
If the test fails, your
TestYYY.testXXX() methods
throws exceptions to the Redirector proxy.
-
If an exception has been raised, the Redirector proxy returns the
information about the exception (it's name, class, stack trace) back
to the client side. It will then be printed by JUnit in it's Test
Runner console.
-
If no exception occurred, the
TestYYY.runTest()
method looks for an endXXX(HttpURLConnection) method
and executes it if found. At this stage, you have the opportunity
to check returned HTTP headers, Cookies and the servlet output
stream in the endXXX() method, again using JUnit asserts
and helper utility classes provided by J2EEUnit (see the sample
application).
J2EEUnit provides 2 implementation for the Redirector Proxy :
-
A Servlet Redirector. This redirector is a servlet that
should be used for unit testing servlet methods. It provides the
following implicit objects :
request ,
response , session and config .
-
A JSP Redirector. This redirector is a JSP page that
should be used for unit testing server code that need access to
the following objects :
pageContext and
out . These objects are provided in addition to all the
objects provided by the Servlet Redirector. It can be useful for
testing simple JSP custom Tag libraries.
data:image/s3,"s3://crabby-images/9f0de/9f0de0b398047bd911ec2d81db524cd140a6d219" alt="Note" |
Testing custom JSP Tag libraries is still in beta. I am still not sure
of the usefulness of this ... I think unit testing tag libraries is
much less relevant than doing functional tests, but this is an open
subject ...
|
data:image/s3,"s3://crabby-images/10bee/10bee9849b97f7979acb83b3a5a97ab7ac8f9321" alt="Servlet Redirector Architecture"
The client side opens 2 HTTP connections to the Servlet redirector.
Once to execute the tests and retrieve the servlet output stream and
a second time to get the test result. This is to be able to get
the exception data (message, stack trace, ...) if the test failed.
The test results are stored in a servlet-context-wide scope variable
which is retrieved on the second HTTP connection.
|
data:image/s3,"s3://crabby-images/3c09f/3c09f30feb520b3c5b60a05a3efc575f49715a4b" alt="JSP Redirector Architecture"
The client side opens 2 HTTP connections. Once to the Redirector
JSP to execute the tests and retrieve the JSP output stream and
a second time to the Servlet Redirector to get the test result.
This is to be able to get the exception data (message,
stack trace, ...) if the test failed.
The test results are stored in a servlet-context-wide scope variable
which is retrieved on the second HTTP connection.
|
|
|
|
|