Commit f38ba3ce by David Ormsbee

Merge pull request #1012 from MITx/bugfix/victor/xml-loading

Fix a bug with pointer-tag detection on load
parents 7595ab4a 55a0cada
...@@ -176,6 +176,33 @@ class ImportTestCase(unittest.TestCase): ...@@ -176,6 +176,33 @@ class ImportTestCase(unittest.TestCase):
self.assertEqual(chapter_xml.tag, 'chapter') self.assertEqual(chapter_xml.tag, 'chapter')
self.assertFalse('graceperiod' in chapter_xml.attrib) self.assertFalse('graceperiod' in chapter_xml.attrib)
def test_is_pointer_tag(self):
"""
Check that is_pointer_tag works properly.
"""
yes = ["""<html url_name="blah"/>""",
"""<html url_name="blah"></html>""",
"""<html url_name="blah"> </html>""",
"""<problem url_name="blah"/>""",
"""<course org="HogwartsX" course="Mathemagics" url_name="3.14159"/>"""]
no = ["""<html url_name="blah" also="this"/>""",
"""<html url_name="blah">some text</html>""",
"""<problem url_name="blah"><sub>tree</sub></problem>""",
"""<course org="HogwartsX" course="Mathemagics" url_name="3.14159">
<chapter>3</chapter>
</course>
"""]
for xml_str in yes:
print "should be True for {0}".format(xml_str)
self.assertTrue(is_pointer_tag(etree.fromstring(xml_str)))
for xml_str in no:
print "should be False for {0}".format(xml_str)
self.assertFalse(is_pointer_tag(etree.fromstring(xml_str)))
def test_metadata_inherit(self): def test_metadata_inherit(self):
"""Make sure that metadata is inherited properly""" """Make sure that metadata is inherited properly"""
...@@ -311,3 +338,5 @@ class ImportTestCase(unittest.TestCase): ...@@ -311,3 +338,5 @@ class ImportTestCase(unittest.TestCase):
system = self.get_system(False) system = self.get_system(False)
self.assertRaises(etree.XMLSyntaxError, system.process_xml, bad_xml) self.assertRaises(etree.XMLSyntaxError, system.process_xml, bad_xml)
...@@ -25,7 +25,7 @@ def name_to_pathname(name): ...@@ -25,7 +25,7 @@ def name_to_pathname(name):
def is_pointer_tag(xml_obj): def is_pointer_tag(xml_obj):
""" """
Check if xml_obj is a pointer tag: <blah url_name="something" />. Check if xml_obj is a pointer tag: <blah url_name="something" />.
No children, one attribute named url_name. No children, one attribute named url_name, no text.
Special case for course roots: the pointer is Special case for course roots: the pointer is
<course url_name="something" org="myorg" course="course"> <course url_name="something" org="myorg" course="course">
...@@ -40,7 +40,10 @@ def is_pointer_tag(xml_obj): ...@@ -40,7 +40,10 @@ def is_pointer_tag(xml_obj):
expected_attr = set(['url_name', 'course', 'org']) expected_attr = set(['url_name', 'course', 'org'])
actual_attr = set(xml_obj.attrib.keys()) actual_attr = set(xml_obj.attrib.keys())
return len(xml_obj) == 0 and actual_attr == expected_attr
has_text = xml_obj.text is not None and len(xml_obj.text.strip()) > 0
return len(xml_obj) == 0 and actual_attr == expected_attr and not has_text
def get_metadata_from_xml(xml_object, remove=True): def get_metadata_from_xml(xml_object, remove=True):
meta = xml_object.find('meta') meta = xml_object.find('meta')
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment