summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorFred Drake <fdrake@acm.org>2002-09-26 15:52:59 (GMT)
committerFred Drake <fdrake@acm.org>2002-09-26 15:52:59 (GMT)
commit2abf167a1544bbd73cf640b1f61bd762bfd3f0e3 (patch)
treeecef8daed61c203881d613d4fd41bea5eff977d9
parent6a0955610f8a7dd3eb58575f8fbc052b5210699f (diff)
downloadcpython-2abf167a1544bbd73cf640b1f61bd762bfd3f0e3.zip
cpython-2abf167a1544bbd73cf640b1f61bd762bfd3f0e3.tar.gz
cpython-2abf167a1544bbd73cf640b1f61bd762bfd3f0e3.tar.bz2
Backport patches for versions 1.33, 1.35, and 1.36 from the trunk:
revision 1.36: If PyXML is installed, there is no Node.allnodes, so that portion of the test should be skipped if that's the case. revision 1.35: Remove duplicate checks of the Node.allnodes variable. revision 1.33: Follow PyXML: Remove all prints from successful tests. This means we can also drop the output file.
-rw-r--r--Lib/test/test_minidom.py49
1 files changed, 24 insertions, 25 deletions
diff --git a/Lib/test/test_minidom.py b/Lib/test/test_minidom.py
index 4483fc5..7c5d264 100644
--- a/Lib/test/test_minidom.py
+++ b/Lib/test/test_minidom.py
@@ -17,9 +17,7 @@ tstfile = os.path.join(os.path.dirname(base), "test"+os.extsep+"xml")
del base
def confirm(test, testname = "Test"):
- if test:
- print "Passed " + testname
- else:
+ if not test:
print "Failed " + testname
raise Exception
@@ -353,7 +351,6 @@ def _testElementReprAndStrUnicodeNS():
confirm(string1 == string2)
confirm(string1.find("slash:abc") != -1)
dom.unlink()
- confirm(len(Node.allnodes) == 0)
def testAttributeRepr():
dom = Document()
@@ -361,7 +358,6 @@ def testAttributeRepr():
node = el.setAttribute("abc", "def")
confirm(str(node) == repr(node))
dom.unlink()
- confirm(len(Node.allnodes) == 0)
def testTextNodeRepr(): pass
@@ -371,7 +367,6 @@ def testWriteXML():
domstr = dom.toxml()
dom.unlink()
confirm(str == domstr)
- confirm(len(Node.allnodes) == 0)
def testProcessingInstruction(): pass
@@ -389,7 +384,7 @@ def testTooManyDocumentElements():
try:
doc.appendChild(elem)
except HierarchyRequestErr:
- print "Caught expected exception when adding extra document element."
+ pass
else:
print "Failed to catch expected exception when" \
" adding extra document element."
@@ -613,23 +608,33 @@ names.sort()
failed = []
+try:
+ Node.allnodes
+except AttributeError:
+ # We don't actually have the minidom from the standard library,
+ # but are picking up the PyXML version from site-packages.
+ def check_allnodes():
+ pass
+else:
+ def check_allnodes():
+ confirm(len(Node.allnodes) == 0,
+ "assertion: len(Node.allnodes) == 0")
+ if len(Node.allnodes):
+ print "Garbage left over:"
+ if verbose:
+ print Node.allnodes.items()[0:10]
+ else:
+ # Don't print specific nodes if repeatable results
+ # are needed
+ print len(Node.allnodes)
+ Node.allnodes = {}
+
for name in names:
if name.startswith("test"):
func = globals()[name]
try:
func()
- print "Test Succeeded", name
- confirm(len(Node.allnodes) == 0,
- "assertion: len(Node.allnodes) == 0")
- if len(Node.allnodes):
- print "Garbage left over:"
- if verbose:
- print Node.allnodes.items()[0:10]
- else:
- # Don't print specific nodes if repeatable results
- # are needed
- print len(Node.allnodes)
- Node.allnodes = {}
+ check_allnodes()
except:
failed.append(name)
print "Test Failed: ", name
@@ -642,9 +647,3 @@ if failed:
print "\n\n\n**** Check for failures in these tests:"
for name in failed:
print " " + name
- print
-else:
- print "All tests succeeded"
-
-Node.debug = None # Delete debug output collected in a StringIO object
-Node._debug = 0 # And reset debug mode