Class XMLResultAggregator
java.lang.Object
org.apache.tools.ant.ProjectComponent
org.apache.tools.ant.Task
org.apache.tools.ant.taskdefs.optional.junit.XMLResultAggregator
- All Implemented Interfaces:
Cloneable
,XMLConstants
Aggregates all <junit> XML formatter testsuite data under
a specific directory and transforms the results via XSLT.
It is not particularly clean but
should be helpful while I am thinking about another technique.
The main problem is due to the fact that a JVM can be forked for a testcase thus making it impossible to aggregate all testcases since the listener is (obviously) in the forked JVM. A solution could be to write a TestListener that will receive events from the TestRunner via sockets. This is IMHO the simplest way to do it to avoid this file hacking thing.
-
Field Summary
Modifier and TypeFieldDescriptionstatic final String
The default directory:.
.static final String
the default file name:TESTS-TestSuites.xml
the list of all filesets, that should contains the xml to aggregateprotected int
the current generated idprotected File
the directory to write the file toprotected String
the name of the result fileprotected Vector
<AggregateTransformer> Fields inherited from class org.apache.tools.ant.ProjectComponent
description, location, project
Fields inherited from interface org.apache.tools.ant.taskdefs.optional.junit.XMLConstants
ATTR_CLASSNAME, ATTR_ERRORS, ATTR_FAILURES, ATTR_ID, ATTR_MESSAGE, ATTR_NAME, ATTR_PACKAGE, ATTR_SKIPPED, ATTR_TESTS, ATTR_TIME, ATTR_TYPE, ATTR_VALUE, ERROR, FAILURE, HOSTNAME, PROPERTIES, PROPERTY, SYSTEM_ERR, SYSTEM_OUT, TESTCASE, TESTSUITE, TESTSUITES, TIMESTAMP
-
Constructor Summary
-
Method Summary
Modifier and TypeMethodDescriptionvoid
addFileSet
(FileSet fs) Add a new fileset containing the XML results to aggregateprotected void
addTestSuite
(Element root, Element testsuite) Add a new testsuite node to the document.protected Element
Create a DOM tree.Generate a report based on the document created by the merge.void
execute()
Aggregate all testsuites into a single document and write it to the specified directory and file.Get the full destination file where to write the result.protected File[]
getFiles()
Get all.xml
files in the fileset.void
Set the destination directory where the results should be written.void
Set the name of the aggregated results file.protected void
writeDOMTree
(Document doc, File file) Write the DOM tree to a file.Methods inherited from class org.apache.tools.ant.Task
bindToOwner, getOwningTarget, getRuntimeConfigurableWrapper, getTaskName, getTaskType, getWrapper, handleErrorFlush, handleErrorOutput, handleFlush, handleInput, handleOutput, init, isInvalid, log, log, log, log, maybeConfigure, perform, reconfigure, setOwningTarget, setRuntimeConfigurableWrapper, setTaskName, setTaskType
Methods inherited from class org.apache.tools.ant.ProjectComponent
clone, getDescription, getLocation, getProject, setDescription, setLocation, setProject
-
Field Details
-
filesets
-
toFile
the name of the result file -
toDir
the directory to write the file to -
transformers
-
DEFAULT_DIR
The default directory:.
. It is resolved from the project directory- See Also:
-
DEFAULT_FILENAME
-
generatedId
protected int generatedIdthe current generated id
-
-
Constructor Details
-
XMLResultAggregator
public XMLResultAggregator()
-
-
Method Details
-
createReport
Generate a report based on the document created by the merge.- Returns:
- the report
-
setTofile
Set the name of the aggregated results file. It must be relative from thetodir
attribute. If not set it will useDEFAULT_FILENAME
- Parameters:
value
- the name of the file.- See Also:
-
setTodir
Set the destination directory where the results should be written. If not set if will useDEFAULT_DIR
. When given a relative directory it will resolve it from the project directory.- Parameters:
value
- the directory where to write the results, absolute or relative.
-
addFileSet
Add a new fileset containing the XML results to aggregate- Parameters:
fs
- the new fileset of xml results.
-
execute
Aggregate all testsuites into a single document and write it to the specified directory and file.- Overrides:
execute
in classTask
- Throws:
BuildException
- thrown if there is a serious error while writing the document.
-
getDestinationFile
Get the full destination file where to write the result. It is made of thetodir
andtofile
attributes.- Returns:
- the destination file where should be written the result file.
-
getFiles
Get all.xml
files in the fileset.- Returns:
- all files in the fileset that end with a '.xml'.
-
writeDOMTree
Write the DOM tree to a file.- Parameters:
doc
- the XML document to dump to disk.file
- the filename to write the document to. Should obviously be a .xml file.- Throws:
IOException
- thrown if there is an error while writing the content.
-
createDocument
Create a DOM tree. Has 'testsuites' as firstchild and aggregates all testsuite results that exists in the base directory.- Returns:
- the root element of DOM tree that aggregates all testsuites.
-
addTestSuite
Add a new testsuite node to the document. The main difference is that it split the previous fully qualified name into a package and a name.
For example:
org.apache.Whatever
will be split intoorg.apache
andWhatever
.- Parameters:
root
- the root element to which thetestsuite
node should be appended.testsuite
- the element to append to the given root. It will slightly modify the original node to change the name attribute and add a package one.
-