org.apache.tools.ant.taskdefs.optional.junitClass AggregateTransformer
- java.lang.Object
- org.apache.tools.ant.taskdefs.optional.junit.AggregateTransformer
public class AggregateTransformer extends java.lang.ObjectTransform a JUnit xml report. The default transformation generates an html report in either framed or non-framed style. The non-framed style is convenient to have a concise report via mail, the framed report is much more convenient if you want to browse into different packages or testcases since it is a Javadoc like report.
Nested Class Summary
Nested Classes Modifier and Type Class and Description static classAggregateTransformer.Formatdefines acceptable formats.
Field Summary
Fields Modifier and Type Field and Description protected static javax.xml.parsers.DocumentBuilderFactorydbfactoryXML Parser factory accessible to subclassesprotected org.w3c.dom.Documentdocumentthe xml document to processprotected java.lang.Stringformatthe format to use for the report.static java.lang.StringFRAMESname of the frames format.static java.lang.StringNOFRAMESname of the no frames format.protected java.io.FilestyleDirthe style directory.protected TasktaskTaskprotected java.io.FiletoDirthe destination directory, this is the root from where html should be generated
Constructor Summary
Constructors Constructor and Description AggregateTransformer(Task task)constructor creating the transformer from the junitreport task.
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method and Description protected voidcheckOptions()check for invalid optionsprotected voidconfigureForRedirectExtension()If we end up using the JDK's own TraX factory on Java 9+, then set the features and attributes necessary to allow redirect extensions to be used.PathcreateClasspath()Creates a classpath to be used for the internal XSLT task.XSLTProcess.FactorycreateFactory()Creates a factory configuration to be used for the internal XSLT task.XSLTProcess.ParamcreateParam()Create an instance of an XSL parameter for configuration by Ant.protected static javax.xml.parsers.DocumentBuilderFactorygetDocumentBuilderFactory()Get the Document Builder Factoryprotected ResourcegetStylesheet()access the stylesheet to be used as a resource.protected java.lang.StringgetStylesheetSystemId()Get the systemid of the appropriate stylesheet based on its name and styledir.voidsetExtension(java.lang.String ext)set the extension of the output filesvoidsetFormat(AggregateTransformer.Format format)sets the format.voidsetStyledir(java.io.File styledir)set the style directory.voidsetTodir(java.io.File todir)set the destination directory.voidsetXmlDocument(org.w3c.dom.Document doc)sets the input document.protected voidsetXmlfile(java.io.File xmlfile)Set the xml file to be processed.voidtransform()transformation
Field Detail
FRAMES
public static final java.lang.String FRAMESname of the frames format.
- See Also:
- Constant Field Values
NOFRAMES
public static final java.lang.String NOFRAMESname of the no frames format.
- See Also:
- Constant Field Values
task
protected Task taskTask
document
protected org.w3c.dom.Document documentthe xml document to process
styleDir
protected java.io.File styleDirthe style directory. XSLs should be read from here if necessary
toDir
protected java.io.File toDirthe destination directory, this is the root from where html should be generated
format
protected java.lang.String formatthe format to use for the report. Must be FRAMES or NOFRAMES
dbfactory
protected static javax.xml.parsers.DocumentBuilderFactory dbfactoryXML Parser factory accessible to subclasses
Constructor Detail
AggregateTransformer
public AggregateTransformer(Task task)constructor creating the transformer from the junitreport task.
- Parameters:
task- task delegating to this class
Method Detail
getDocumentBuilderFactory
protected static javax.xml.parsers.DocumentBuilderFactory getDocumentBuilderFactory()Get the Document Builder Factory
- Returns:
- the DocumentBuilderFactory instance in use
setFormat
public void setFormat(AggregateTransformer.Format format)sets the format.
- Parameters:
format- Must be FRAMES or NOFRAMES
setXmlDocument
public void setXmlDocument(org.w3c.dom.Document doc)sets the input document.
- Parameters:
doc- input dom tree
setXmlfile
protected void setXmlfile(java.io.File xmlfile) throws BuildExceptionSet the xml file to be processed. This is a helper if you want to set the file directly. Much more for testing purposes.
- Parameters:
xmlfile- xml file to be processed- Throws:
BuildException- if the document cannot be parsed.
setStyledir
public void setStyledir(java.io.File styledir)set the style directory. It is optional and will override the default xsl used.
- Parameters:
styledir- the directory containing the xsl files if the user would like to override with its own style.
setTodir
public void setTodir(java.io.File todir)set the destination directory.
- Parameters:
todir- the destination directory
setExtension
public void setExtension(java.lang.String ext)set the extension of the output files
- Parameters:
ext- extension.
createParam
public XSLTProcess.Param createParam()Create an instance of an XSL parameter for configuration by Ant.
- Returns:
- an instance of the Param class to be configured.
- Since:
- Ant 1.7
createClasspath
public Path createClasspath()Creates a classpath to be used for the internal XSLT task.
- Returns:
- the classpath to be configured
- Since:
- Ant 1.9.5
createFactory
public XSLTProcess.Factory createFactory()Creates a factory configuration to be used for the internal XSLT task.
- Returns:
- the factory description to be configured
- Since:
- Ant 1.9.5
transform
public void transform() throws BuildExceptiontransformation
- Throws:
BuildException- exception if something goes wrong with the transformation.
getStylesheet
protected Resource getStylesheet()access the stylesheet to be used as a resource.
- Returns:
- stylesheet as a resource
checkOptions
protected void checkOptions() throws BuildExceptioncheck for invalid options
- Throws:
BuildException- if something goes wrong.
getStylesheetSystemId
protected java.lang.String getStylesheetSystemId() throws java.io.IOExceptionGet the systemid of the appropriate stylesheet based on its name and styledir. If no styledir is defined it will load it as a java resource in the xsl child package, otherwise it will get it from the given directory.
- Returns:
- system ID of the stylesheet.
- Throws:
java.io.IOException- thrown if the requested stylesheet does not exist.
configureForRedirectExtension
protected void configureForRedirectExtension()If we end up using the JDK's own TraX factory on Java 9+, then set the features and attributes necessary to allow redirect extensions to be used.
- Since:
- Ant 1.9.8