============
xunitparserx
Description
xunitparserx reads a JUnit/XUnit/MSTest XML file and maps it to Python objects.
It tries to use the objects available in the standard unittest
module.
xunitparserx work both for python2 and python3, with addition MSTest trx support
Usage
::
import xunitparserx
ts, tr = xunitparserx.parse(open('/path/to/unit.xml'))
ts
is a TestSuite
class, containing TestCase
classes.
tr
is a TestResult
class.
You can change the classes used (though they probably would not work unless
they inherit from the xunitparserx
ones) by using your own
xunitparserx.Parser
class and changing the *_CLASS
variables.
Some helpful properties are added to the TestCase
class::
for tc in ts:
print('Class %s, method %s' % (tc.classname, tc.methodname))
if tc.good:
print('went well...', 'but did not run.' if tc.skip else '')
else:
print('went wrong.')
For more, please read the source code - it is very minimal.
The classes also inherit from the unittest
__ module so it is actually
a good reference of what you can do with xunitparserx
.
__ http://docs.python.org/library/unittest.html
Changes
-
1.9.10+
- use github action to auto publish to pypi
-
1.9.9
-
1.3.3
-
1.3.0
- Multiple results in a single TestCase are seen as one.
The previous way was never validated by real-life examples.
- Handle system-out / system-err at the testsuite level
Development & Contribution
Pull request is welcome.
- dev branch is used to accept pull request and do integration
- main branch is used to do release, once push, a release process will happen automate
Love My Software: https://www.paypal.me/medlab :)
Release Workflow
- python setup.py sdist
- python -m twine upload dist/*
Auto release status
.. image:: https://github.com/medlab/xunitparserx/workflows/Publish%20Python%20%F0%9F%90%8D%20distributions%20%F0%9F%93%A6%20to%20PyPI%20and%20TestPyPI/badge.svg
:alt: Publish Python 🐍 distributions 📦 to PyPI and TestPyPI
Refs: