TAP::Harness::JUnit.3pm

Langue: en

Autres versions - même langue

Version: 2009-02-26 (fedora - 06/07/09)

Section: 3 (Bibliothèques de fonctions)

NAME

TAP::Harness::JUnit - Generate JUnit compatible output from TAP results

SYNOPSIS

     use TAP::Harness::JUnit;
     my $harness = TAP::Harness::JUnit->new({
         xmlfile => 'output.xml',
         ...
     });
     $harness->runtests(@tests);
 
 

DESCRIPTION

The only difference between this module and TAP::Harness is that this adds optional 'xmlfile' argument, that causes the output to be formatted into XML in format similar to one that is produced by JUnit testing framework.

METHODS

This modules inherits all functions from TAP::Harness.

new

These options are added (compared to TAP::Harness):

xmlfile
Name of the file XML output will be saved to. In case this argument is ommited, default of ``junit_output.xml'' is used and a warning is issued.

SEE ALSO

JUnit XML schema was obtained from <http://jra1mw.cvs.cern.ch:8180/cgi-bin/jra1mw.cgi/org.glite.testing.unit/config/JUnitXSchema.xsd?view=markup>.

ACKNOWLEDGEMENTS

This module was partly inspired by Michael Peters' TAP::Harness::Archive.

Following people (in no specific order) have reported problems or contributed fixes to TAP::Harness::JUnit:

David Ritter
Jeff Lavallee
Andreas Pohl

BUGS

Test return value is ignored. This is actually not a bug, TAP::Parser doesn't present the fact and TAP specification does not require that anyway.

Note that this may be a problem when running Test::More tests with "no_plan", since it will add a plan matching the number of tests actually run even in case the test dies. No not do that --- always write a plan! In case it's not possible, pass "merge" argument when creating a TAP::Harness::JUnit instance, and the harness will detect such failures by matching certain comments.

Test durations are always set to 0 seconds.

The comments that are above the "ok" or "not ok" are considered the output of the test. This, though being more logical, is against TAP specification.

XML::Simple is used to generate the output. It is suboptimal and involves some hacks.

During testing, the resulting files are not tested against the schema, which would be a good thing to do.

AUTHOR

Lubomir Rintel (Good Data) "<lubo.rintel@gooddata.com>"

Source code for TAP::Harness::JUnit is kept in a public GIT repository. Visit <http://repo.or.cz/w/TAP-Harness-JUnit.git> to get it.

Copyright 2008, 2009 Good Data, All rights reserved.

This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.