Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/nblock/python-junit-xml

A Debian package for python-junit-xml
https://github.com/nblock/python-junit-xml

Last synced: 22 days ago
JSON representation

A Debian package for python-junit-xml

Awesome Lists containing this project

README

        

python-junit-xml
================
.. image:: https://travis-ci.org/kyrus/python-junit-xml.png?branch=master

About
-----

A Python module for creating JUnit XML test result documents that can be
read by tools such as Jenkins. If you are ever working with test tool or
test suite written in Python and want to take advantage of Jenkins'
pretty graphs and test reporting capabilities, this module will let you
generate the XML test reports.

*As there is no definitive Jenkins JUnit XSD that I could find, the XML
documents created by this module support a schema based on Google
searches and the Jenkins JUnit XML reader source code. File a bug if
something doesn't work like you expect it to.*

Installation
------------

Install using pip or easy_install:

::

pip install junit-xml
or
easy_install junit-xml

You can also clone the Git repository from Github and install it manually:

::

git clone https://github.com/kyrus/python-junit-xml.git
python setup.py install

Using
-----

Create a test suite, add a test case, and print it to the screen:

.. code-block:: python

from junit_xml import TestSuite, TestCase

test_cases = [TestCase('Test1', 'some.class.name', 123.345, 'I am stdout!', 'I am stderr!')]
ts = TestSuite("my test suite", test_cases)
# pretty printing is on by default but can be disabled using prettyprint=False
print(TestSuite.to_xml_string([ts]))

Produces the following output

.. code-block:: xml






I am stdout!


I am stderr!



Writing XML to a file:

.. code-block:: python

# you can also write the XML to a file and not pretty print it
with open('output.xml', 'w') as f:
TestSuite.to_file(f, [ts], prettyprint=False)

See the docs and unit tests for more examples.

NOTE: Unicode characters identified as "illegal or discouraged" are automatically
stripped from the XML string or file.

Running the tests
-----------------

::

# activate your virtualenv
pip install tox
tox