mirror of
https://github.com/django/django.git
synced 2025-10-24 14:16:09 +00:00
Fixed #30497 -- Ignored document type in assertXMLEqual()/assertXMLNotEqual().
This commit is contained in:
committed by
Mariusz Felisiak
parent
4fb9e7b057
commit
753b67c58d
@@ -537,7 +537,8 @@ def compare_xml(want, got):
|
||||
"""
|
||||
Try to do a 'xml-comparison' of want and got. Plain string comparison
|
||||
doesn't always work because, for example, attribute ordering should not be
|
||||
important. Ignore comment nodes and leading and trailing whitespace.
|
||||
important. Ignore comment nodes, document type node, and leading and
|
||||
trailing whitespaces.
|
||||
|
||||
Based on https://github.com/lxml/lxml/blob/master/src/lxml/doctestcompare.py
|
||||
"""
|
||||
@@ -575,7 +576,7 @@ def compare_xml(want, got):
|
||||
|
||||
def first_node(document):
|
||||
for node in document.childNodes:
|
||||
if node.nodeType != Node.COMMENT_NODE:
|
||||
if node.nodeType not in (Node.COMMENT_NODE, Node.DOCUMENT_TYPE_NODE):
|
||||
return node
|
||||
|
||||
want = want.strip().replace('\\n', '\n')
|
||||
|
@@ -1645,8 +1645,8 @@ your test suite.
|
||||
syntax differences. When invalid XML is passed in any parameter, an
|
||||
``AssertionError`` is always raised, even if both string are identical.
|
||||
|
||||
XML declaration and comments are ignored. Only the root element and its
|
||||
children are compared.
|
||||
XML declaration, document type, and comments are ignored. Only the root
|
||||
element and its children are compared.
|
||||
|
||||
Output in case of error can be customized with the ``msg`` argument.
|
||||
|
||||
|
@@ -920,6 +920,11 @@ class XMLEqualTests(SimpleTestCase):
|
||||
xml2 = "<elem>foo</elem> <elem>bar</elem>"
|
||||
self.assertXMLNotEqual(xml1, xml2)
|
||||
|
||||
def test_doctype_root(self):
|
||||
xml1 = '<?xml version="1.0"?><!DOCTYPE root SYSTEM "example1.dtd"><root />'
|
||||
xml2 = '<?xml version="1.0"?><!DOCTYPE root SYSTEM "example2.dtd"><root />'
|
||||
self.assertXMLEqual(xml1, xml2)
|
||||
|
||||
|
||||
class SkippingExtraTests(TestCase):
|
||||
fixtures = ['should_not_be_loaded.json']
|
||||
|
Reference in New Issue
Block a user