39
39
for child in element.childNodes:
40
40
if child.nodeType == child.CDATA_SECTION_NODE:
42
if child.nodeType == child.TEXT_NODE:
42
elif child.nodeType == child.TEXT_NODE:
47
return unicode(data.strip())
49
def add_var(store, var_type, var_name=u"", var_value=u"", arg_no=0):
50
"""Given an var node, parse it into a storm object."""
51
new_var = TestSuiteVar()
52
new_var.var_name = unicode(var_name)
53
new_var.var_value = unicode(var_value)
54
new_var.var_type = unicode(var_type)
55
new_var.arg_no = arg_no
47
59
def add_test_suite(suite_node, suite_num, store):
48
60
"""Given a test suite element, get all the cases it contains."""
51
63
for case_node in suite_node.getElementsByTagName('function'):
53
65
cases.append(add_test_case(case_node, case_num, store))
68
# stdin - Stdin for the suite - Unique - Text inside element
69
# file - File to add to the filespace - Name - List
70
# var - Variable for the suite - Name/Value - List
71
# arg - Argument to functions - Name/Value - ORDERED List
72
# exception - Allowed exception name - Name - List
73
# function - An actual test case
77
file_nodes = suite_node.getElementsByTagName('file')
78
for file_node in file_nodes:
79
suite_vars.append(add_var(store, 'file', file_node.getAttribute('name')))
82
var_nodes = suite_node.getElementsByTagName('var')
83
for var_node in var_nodes:
84
var_name = var_node.getAttribute('name')
85
var_value = var_node.getAttribute('value')
86
suite_vars.append(add_var(store, 'var', var_name, var_value))
88
# Args need to be numbered as they are found, as this order matters
90
for arg_node in suite_node.getElementsByTagName('arg'):
91
suite_vars.append(add_var(store, 'arg', arg_node.getAttribute('name'),
92
arg_node.getAttribute('value'), arg_num))
95
# Add allowed exceptions
96
exception_nodes = suite_node.getElementsByTagName('exception')
97
for exception_node in exception_nodes:
98
name = exception_node.getAttribute('name')
99
suite_vars.append(add_var(store, 'exception', name))
101
# Can only have 0-1 stdin elements
102
stdin = suite_node.getElementsByTagName('stdin')
104
raise XMLMalformedError('Too many stdin tags found.')
106
stdin = getTextData(stdin[0])
54
110
new_suite = TestSuite()
55
new_suite.description = suite_node.getAttribute('name')
111
new_suite.description = unicode(suite_node.getAttribute('name'))
56
112
new_suite.seq_no = suite_num
113
new_suite.function = unicode(suite_node.getAttribute('function'))
114
new_suite.stdin = unicode(stdin)
57
115
for testcase in cases:
58
116
new_suite.test_cases.add(testcase)
117
for var in suite_vars:
118
new_suite.variables.add(var)
59
119
store.add(new_suite)
122
def add_part(store, element_type, test_type, data, filename=u""):
123
new_part = TestCasePart()
124
new_part.element_type = element_type
125
new_part.test_type = test_type
127
new_part.filename = unicode(filename)
63
131
def add_test_case(case_node, case_num, store):
64
"""Given a test case, generate its data"""
65
# First perform basic error checks
66
if not case_node.tagName == 'function':
67
raise XMLMalformedError(case_node.tagName + ' node')
68
case_data = case_node.getElementsByTagName('code')
70
case_data = case_node.getElementsByTagName('stdout')
72
raise XMLMalformedError()
73
case_data = case_data[0]
132
"""Given a test case node, parse it int a storm object."""
135
# A function is allowed to contain the following elements
142
allowed_parts = ['stdout', 'stderr', 'result', 'exception', 'file', 'code']
144
for child_node in case_node.childNodes:
145
if child_node.nodeType != child_node.ELEMENT_NODE:
148
if child_node.tagName == 'file':
150
test_type = child_node.getAttribute('type')
151
data = getTextData(child_node)
152
filename = child_node.getAttribute('name')
154
raise XMLMalformedException('file tag must have names')
155
parts.append(add_part(store, element_type, test_type, data,
158
elif child_node.tagName in allowed_parts:
159
part_type = child_node.tagName
160
test_type = child_node.getAttribute('type')
161
data = getTextData(child_node)
162
parts.append(add_part(store, part_type, test_type, data))
74
164
#Now create the object to hold the data
75
165
new_test_case = TestCase()
76
new_test_case.passmsg = case_node.getAttribute('pass')
77
new_test_case.failmsg = case_node.getAttribute('fail')
78
new_test_case.init = case_node.getAttribute('default')
79
new_test_case.code_type = case_data.getAttribute('type')
80
new_test_case.code = getTextData(case_data)
81
new_test_case.testtype = case_data.tagName
166
new_test_case.passmsg = unicode(case_node.getAttribute(u'pass'))
167
new_test_case.failmsg = unicode(case_node.getAttribute(u'fail'))
168
new_test_case.test_default = unicode(case_node.getAttribute(u'default'))
82
169
new_test_case.seq_no = case_num
83
170
store.add(new_test_case)
172
new_test_case.parts.add(part)
84
173
return new_test_case
86
175
xmlfile = sys.argv[1]