3 from xml.dom.minidom import Document
6 def __init__(self, casePath, description, caseType):
7 self.casePath = casePath
8 self.description = description
9 self.caseType = caseType
12 def findAllMatches(haystack, needle):
16 ndx = haystack.find(needle, ndx+1)
22 def createAncestors(casePath):
24 for dotNdx in findAllMatches(casePath, "."):
25 ancestorPath = casePath[:dotNdx]
26 if ancestorPath not in caseNameHash:
27 case = TestCase(ancestorPath, "Test Group", "TestGroup")
28 parentCase.children.append(case)
29 caseNameHash[ancestorPath] = case
31 parentCase = caseNameHash[ancestorPath]
34 def exportCase (doc, parent, testCase):
35 #print testCase.name, testCase.caseType
36 element = doc.createElement("TestCase")
37 element.setAttribute("Name", testCase.casePath.rsplit(".", 2)[-1])
38 element.setAttribute("Description", testCase.description)
39 element.setAttribute("CaseType", testCase.caseType)
40 parent.appendChild(element)
41 for child in testCase.children:
42 exportCase(doc, element, child)
46 packageName = sys.argv[1]
48 rootCase = TestCase(packageName, packageName, "TestPackage" )
49 caseNameHash = { packageName:rootCase }
50 caseRE = re.compile(r"^\s*([a-zA-Z0-9_\.\-]+) '([^']*)' (\w+)\s*$".replace(" ", r"\s+"))
52 lines = open(packageName + ".cases").readlines()
56 if line.startswith(packageName + "."):
57 m = caseRE.match(line)
60 description = m.group(2)
62 parent = createAncestors(casePath)
63 parent.children.append(TestCase(casePath, description, caseType))
66 # Create XML document.
68 element = doc.createElement("TestCaseList")
69 doc.appendChild(element)
70 for testCase in rootCase.children:
71 exportCase(doc, element, testCase)
74 xml = doc.toprettyxml(indent=" ")
75 open(packageName + "-cases.xml", "wt").write(xml)
77 print "%d cases converted." % numMatches