mirror of
				https://github.com/python/cpython.git
				synced 2025-10-25 18:54:53 +00:00 
			
		
		
		
	 a21e4ca3c6
			
		
	
	
		a21e4ca3c6
		
	
	
	
	
		
			
			........ r70734 | r.david.murray | 2009-03-30 15:04:00 -0400 (Mon, 30 Mar 2009) | 7 lines Add import_function method to test.test_support, and modify a number of tests that expect to be skipped if imports fail or functions don't exist to use import_function and import_module. The ultimate goal is to change regrtest to not skip automatically on ImportError. Checking in now to make sure the buldbots don't show any errors on platforms I can't direct test on. ........ r70775 | r.david.murray | 2009-03-30 19:05:48 -0400 (Mon, 30 Mar 2009) | 4 lines Change more tests to use import_module for the modules that should cause tests to be skipped. Also rename import_function to the more descriptive get_attribute and add a docstring. ........ r70856 | r.david.murray | 2009-03-31 14:32:17 -0400 (Tue, 31 Mar 2009) | 7 lines A few more test skips via import_module, and change import_module to return the error message produced by importlib, so that if an import in the package whose import is being wrapped is what failed the skip message will contain the name of that module instead of the name of the wrapped module. Also fixed formatting of some previous comments. ........ r70874 | r.david.murray | 2009-03-31 15:33:15 -0400 (Tue, 31 Mar 2009) | 5 lines Improve test_support.import_module docstring, remove deprecated flag from get_attribute since it isn't likely to do anything useful. ........ r70876 | r.david.murray | 2009-03-31 15:49:15 -0400 (Tue, 31 Mar 2009) | 4 lines Remove the regrtest check that turns any ImportError into a skipped test. Hopefully all modules whose imports legitimately result in a skipped test have been properly wrapped by the previous commits. ........ r70877 | r.david.murray | 2009-03-31 15:57:24 -0400 (Tue, 31 Mar 2009) | 2 lines Add NEWS entry for regrtest change. ........
		
			
				
	
	
		
			220 lines
		
	
	
	
		
			5.7 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			220 lines
		
	
	
	
		
			5.7 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| # xml.etree test for cElementTree
 | |
| 
 | |
| import doctest
 | |
| import sys
 | |
| 
 | |
| from test import support
 | |
| 
 | |
| ET = support.import_module('xml.etree.cElementTree')
 | |
| 
 | |
| SAMPLE_XML = """
 | |
| <body>
 | |
|   <tag>text</tag>
 | |
|   <tag />
 | |
|   <section>
 | |
|     <tag>subtext</tag>
 | |
|   </section>
 | |
| </body>
 | |
| """
 | |
| 
 | |
| SAMPLE_XML_NS = """
 | |
| <body xmlns="http://effbot.org/ns">
 | |
|   <tag>text</tag>
 | |
|   <tag />
 | |
|   <section>
 | |
|     <tag>subtext</tag>
 | |
|   </section>
 | |
| </body>
 | |
| """
 | |
| 
 | |
| def sanity():
 | |
|     """
 | |
|     Import sanity.
 | |
| 
 | |
|     >>> from xml.etree import cElementTree
 | |
|     """
 | |
| 
 | |
| def check_method(method):
 | |
|     if not hasattr(method, '__call__'):
 | |
|         print(method, "not callable")
 | |
| 
 | |
| def serialize(ET, elem):
 | |
|     import io
 | |
|     file = io.StringIO()
 | |
|     tree = ET.ElementTree(elem)
 | |
|     tree.write(file)
 | |
|     return file.getvalue()
 | |
| 
 | |
| def summarize(elem):
 | |
|     return elem.tag
 | |
| 
 | |
| def summarize_list(seq):
 | |
|     return list(map(summarize, seq))
 | |
| 
 | |
| def interface():
 | |
|     """
 | |
|     Test element tree interface.
 | |
| 
 | |
|     >>> element = ET.Element("tag", key="value")
 | |
|     >>> tree = ET.ElementTree(element)
 | |
| 
 | |
|     Make sure all standard element methods exist.
 | |
| 
 | |
|     >>> check_method(element.append)
 | |
|     >>> check_method(element.insert)
 | |
|     >>> check_method(element.remove)
 | |
|     >>> check_method(element.getchildren)
 | |
|     >>> check_method(element.find)
 | |
|     >>> check_method(element.findall)
 | |
|     >>> check_method(element.findtext)
 | |
|     >>> check_method(element.clear)
 | |
|     >>> check_method(element.get)
 | |
|     >>> check_method(element.set)
 | |
|     >>> check_method(element.keys)
 | |
|     >>> check_method(element.items)
 | |
|     >>> check_method(element.getiterator)
 | |
| 
 | |
|     Basic method sanity checks.
 | |
| 
 | |
|     >>> serialize(ET, element) # 1
 | |
|     '<tag key="value" />'
 | |
|     >>> subelement = ET.Element("subtag")
 | |
|     >>> element.append(subelement)
 | |
|     >>> serialize(ET, element) #  2
 | |
|     '<tag key="value"><subtag /></tag>'
 | |
|     >>> element.insert(0, subelement)
 | |
|     >>> serialize(ET, element) # 3
 | |
|     '<tag key="value"><subtag /><subtag /></tag>'
 | |
|     >>> element.remove(subelement)
 | |
|     >>> serialize(ET, element) # 4
 | |
|     '<tag key="value"><subtag /></tag>'
 | |
|     >>> element.remove(subelement)
 | |
|     >>> serialize(ET, element) # 5
 | |
|     '<tag key="value" />'
 | |
|     >>> element.remove(subelement)
 | |
|     Traceback (most recent call last):
 | |
|     ValueError: list.remove(x): x not in list
 | |
|     >>> serialize(ET, element) # 6
 | |
|     '<tag key="value" />'
 | |
|     """
 | |
| 
 | |
| def find():
 | |
|     """
 | |
|     Test find methods (including xpath syntax).
 | |
| 
 | |
|     >>> elem = ET.XML(SAMPLE_XML)
 | |
|     >>> elem.find("tag").tag
 | |
|     'tag'
 | |
|     >>> ET.ElementTree(elem).find("tag").tag
 | |
|     'tag'
 | |
|     >>> elem.find("section/tag").tag
 | |
|     'tag'
 | |
|     >>> ET.ElementTree(elem).find("section/tag").tag
 | |
|     'tag'
 | |
|     >>> elem.findtext("tag")
 | |
|     'text'
 | |
|     >>> elem.findtext("tog")
 | |
|     >>> elem.findtext("tog", "default")
 | |
|     'default'
 | |
|     >>> ET.ElementTree(elem).findtext("tag")
 | |
|     'text'
 | |
|     >>> elem.findtext("section/tag")
 | |
|     'subtext'
 | |
|     >>> ET.ElementTree(elem).findtext("section/tag")
 | |
|     'subtext'
 | |
|     >>> summarize_list(elem.findall("tag"))
 | |
|     ['tag', 'tag']
 | |
|     >>> summarize_list(elem.findall("*"))
 | |
|     ['tag', 'tag', 'section']
 | |
|     >>> summarize_list(elem.findall(".//tag"))
 | |
|     ['tag', 'tag', 'tag']
 | |
|     >>> summarize_list(elem.findall("section/tag"))
 | |
|     ['tag']
 | |
|     >>> summarize_list(elem.findall("section//tag"))
 | |
|     ['tag']
 | |
|     >>> summarize_list(elem.findall("section/*"))
 | |
|     ['tag']
 | |
|     >>> summarize_list(elem.findall("section//*"))
 | |
|     ['tag']
 | |
|     >>> summarize_list(elem.findall("section/.//*"))
 | |
|     ['tag']
 | |
|     >>> summarize_list(elem.findall("*/*"))
 | |
|     ['tag']
 | |
|     >>> summarize_list(elem.findall("*//*"))
 | |
|     ['tag']
 | |
|     >>> summarize_list(elem.findall("*/tag"))
 | |
|     ['tag']
 | |
|     >>> summarize_list(elem.findall("*/./tag"))
 | |
|     ['tag']
 | |
|     >>> summarize_list(elem.findall("./tag"))
 | |
|     ['tag', 'tag']
 | |
|     >>> summarize_list(elem.findall(".//tag"))
 | |
|     ['tag', 'tag', 'tag']
 | |
|     >>> summarize_list(elem.findall("././tag"))
 | |
|     ['tag', 'tag']
 | |
|     >>> summarize_list(ET.ElementTree(elem).findall("/tag"))
 | |
|     ['tag', 'tag']
 | |
|     >>> summarize_list(ET.ElementTree(elem).findall("./tag"))
 | |
|     ['tag', 'tag']
 | |
|     >>> elem = ET.XML(SAMPLE_XML_NS)
 | |
|     >>> summarize_list(elem.findall("tag"))
 | |
|     []
 | |
|     >>> summarize_list(elem.findall("{http://effbot.org/ns}tag"))
 | |
|     ['{http://effbot.org/ns}tag', '{http://effbot.org/ns}tag']
 | |
|     >>> summarize_list(elem.findall(".//{http://effbot.org/ns}tag"))
 | |
|     ['{http://effbot.org/ns}tag', '{http://effbot.org/ns}tag', '{http://effbot.org/ns}tag']
 | |
|     """
 | |
| 
 | |
| def parseliteral():
 | |
|     r"""
 | |
| 
 | |
|     >>> element = ET.XML("<html><body>text</body></html>")
 | |
|     >>> ET.ElementTree(element).write(sys.stdout)
 | |
|     <html><body>text</body></html>
 | |
|     >>> element = ET.fromstring("<html><body>text</body></html>")
 | |
|     >>> ET.ElementTree(element).write(sys.stdout)
 | |
|     <html><body>text</body></html>
 | |
|     >>> print(ET.tostring(element))
 | |
|     <html><body>text</body></html>
 | |
|     >>> print(repr(ET.tostring(element, "ascii")))
 | |
|     b"<?xml version='1.0' encoding='ascii'?>\n<html><body>text</body></html>"
 | |
|     >>> _, ids = ET.XMLID("<html><body>text</body></html>")
 | |
|     >>> len(ids)
 | |
|     0
 | |
|     >>> _, ids = ET.XMLID("<html><body id='body'>text</body></html>")
 | |
|     >>> len(ids)
 | |
|     1
 | |
|     >>> ids["body"].tag
 | |
|     'body'
 | |
|     """
 | |
| 
 | |
| def check_encoding(encoding):
 | |
|     """
 | |
|     >>> check_encoding("ascii")
 | |
|     >>> check_encoding("us-ascii")
 | |
|     >>> check_encoding("iso-8859-1")
 | |
|     >>> check_encoding("iso-8859-15")
 | |
|     >>> check_encoding("cp437")
 | |
|     >>> check_encoding("mac-roman")
 | |
|     """
 | |
|     ET.XML(
 | |
|         "<?xml version='1.0' encoding='%s'?><xml />" % encoding
 | |
|         )
 | |
| 
 | |
| def bug_1534630():
 | |
|     """
 | |
|     >>> bob = ET.TreeBuilder()
 | |
|     >>> e = bob.data("data")
 | |
|     >>> e = bob.start("tag", {})
 | |
|     >>> e = bob.end("tag")
 | |
|     >>> e = bob.close()
 | |
|     >>> serialize(ET, e)
 | |
|     '<tag />'
 | |
|     """
 | |
| 
 | |
| def test_main():
 | |
|     from test import test_xml_etree_c
 | |
|     support.run_doctest(test_xml_etree_c, verbosity=True)
 | |
| 
 | |
| if __name__ == '__main__':
 | |
|     test_main()
 |