fix xml generation for skipped collections of tests

--HG--
branch : trunk
This commit is contained in:
holger krekel 2009-12-31 11:50:01 +01:00
parent 9fa6ca885a
commit eb4249322e
2 changed files with 24 additions and 2 deletions

View File

@ -76,6 +76,15 @@ class LogXML(object):
self._closetestcase() self._closetestcase()
self.errors += 1 self.errors += 1
def append_collect_skipped(self, report):
self._opentestcase_collectfailure(report)
s = py.xml.escape(str(report.longrepr))
#msg = str(report.longrepr.reprtraceback.extraline)
self.test_logs.append(
'<skipped message="collection skipped">%s</skipped>' % (s))
self._closetestcase()
self.skipped += 1
def append_error(self, report): def append_error(self, report):
self._opentestcase(report) self._opentestcase(report)
s = py.xml.escape(str(report.longrepr)) s = py.xml.escape(str(report.longrepr))
@ -130,7 +139,7 @@ class LogXML(object):
logfile = open(self.logfile, 'w', 1) # line buffered logfile = open(self.logfile, 'w', 1) # line buffered
suite_stop_time = time.time() suite_stop_time = time.time()
suite_time_delta = suite_stop_time - self.suite_start_time suite_time_delta = suite_stop_time - self.suite_start_time
numtests = self.passed + self.skipped + self.failed numtests = self.passed + self.failed
logfile.write('<testsuite ') logfile.write('<testsuite ')
logfile.write('name="" ') logfile.write('name="" ')
logfile.write('errors="%i" ' % self.errors) logfile.write('errors="%i" ' % self.errors)

View File

@ -28,7 +28,7 @@ class TestPython:
result, dom = runandparse(testdir) result, dom = runandparse(testdir)
assert result.ret assert result.ret
node = dom.getElementsByTagName("testsuite")[0] node = dom.getElementsByTagName("testsuite")[0]
assert_attr(node, errors=0, failures=1, skips=1, tests=3) assert_attr(node, errors=0, failures=1, skips=1, tests=2)
def test_setup_error(self, testdir): def test_setup_error(self, testdir):
testdir.makepyfile(""" testdir.makepyfile("""
@ -90,6 +90,19 @@ class TestPython:
assert_attr(fnode, message="collection failure") assert_attr(fnode, message="collection failure")
assert "invalid syntax" in fnode.toxml() assert "invalid syntax" in fnode.toxml()
def test_collect_skipped(self, testdir):
testdir.makepyfile("import py ; py.test.skip('xyz')")
result, dom = runandparse(testdir)
assert not result.ret
node = dom.getElementsByTagName("testsuite")[0]
assert_attr(node, skips=1, tests=0)
tnode = node.getElementsByTagName("testcase")[0]
assert_attr(tnode,
#classname="test_collect_error",
name="test_collect_skipped")
fnode = tnode.getElementsByTagName("skipped")[0]
assert_attr(fnode, message="collection skipped")
class TestNonPython: class TestNonPython:
def test_summing_simple(self, testdir): def test_summing_simple(self, testdir):
testdir.makeconftest(""" testdir.makeconftest("""