fix #3533: properly escape raw XML object

Using string formatting with the raw escaped object lead to string evaluation
"<py._xmlgen.raw object>"
Format the unescaped string first, then use the XML escape method as a last step.
This commit is contained in:
Vincent Barbaresi 2018-10-16 14:46:38 +02:00
parent c6c326f076
commit f55ded20a9
2 changed files with 21 additions and 3 deletions

View File

@ -221,12 +221,14 @@ class _NodeReporter(object):
else: else:
filename, lineno, skipreason = report.longrepr filename, lineno, skipreason = report.longrepr
if skipreason.startswith("Skipped: "): if skipreason.startswith("Skipped: "):
skipreason = bin_xml_escape(skipreason[9:]) skipreason = skipreason[9:]
details = "%s:%s: %s" % (filename, lineno, skipreason)
self.append( self.append(
Junit.skipped( Junit.skipped(
"%s:%s: %s" % (filename, lineno, skipreason), bin_xml_escape(details),
type="pytest.skip", type="pytest.skip",
message=skipreason, message=bin_xml_escape(skipreason),
) )
) )
self.write_captured_output(report) self.write_captured_output(report)

View File

@ -1222,3 +1222,19 @@ def test_set_suite_name(testdir, suite_name):
assert result.ret == 0 assert result.ret == 0
node = dom.find_first_by_tag("testsuite") node = dom.find_first_by_tag("testsuite")
node.assert_attr(name=expected) node.assert_attr(name=expected)
def test_escaped_skipreason_issue3533(testdir):
testdir.makepyfile(
"""
import pytest
@pytest.mark.skip(reason='1 <> 2')
def test_skip():
pass
"""
)
_, dom = runandparse(testdir)
node = dom.find_first_by_tag("testcase")
snode = node.find_first_by_tag("skipped")
assert "1 <> 2" in snode.text
snode.assert_attr(message="1 <> 2")