forked from laurentb/xunitparser
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtest.py
134 lines (101 loc) · 4.03 KB
/
test.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
import os
from unittest import TestCase
from xunitparser import parse
class X(object):
def setUp(self):
with open(os.path.join('tests', self.FILENAME)) as f:
# the lib already does some sanity checks;
# passing this is already a good test in itself
self.ts, self.tr = parse(f)
def test_results(self):
""" check some expected results """
for test in self.ts:
if test.basename == 'ArteTest':
assert test.good
assert test.skipped
assert test.time is not None
if test.basename == 'YouTubeTest':
assert test.good
assert not test.skipped
if test.basename == 'PastebinTest':
assert not test.skipped
if test.methodname == 'test_post':
assert test.bad
assert 'backend.pastebin_loggedin' in test.message
assert 'python2.7' in test.trace
assert 'exceptions.AssertionError' in test.alltext
assert 'exceptions.AssertionError' not in test.message
assert 'backend.pastebin_loggedin' in test.alltext
assert 'python2.7' in test.alltext
if test.methodname == '003-passed-test':
assert "testcase system output" in test.stdall
assert "testcase error output" in test.stdall
assert "testcase system output" in test.stdout
assert "testcase error output" in test.stderr
assert "testsuite system output" in self.ts.stdout
assert "testsuite error output" in self.ts.stderr
def test_hashes(self):
""" assert hashes are unique """
assert len(list(hash(t) for t in self.ts)) == len(set(hash(t) for t in self.ts))
def test_testresult(self):
if self.FILENAME in ('test1.xml', 'test2.xml', 'test3.xml', 'test4.xml'):
assert len(self.tr.failures)
else:
assert not len(self.tr.failures)
for f in self.tr.failures:
if 'pastebin.test.PastebinTest' in repr(f[0]):
assert 'backend.pastebin_loggedin' in f[1]
def test_classname(self):
for test in self.ts:
assert test.classname
class Test1(X, TestCase):
FILENAME = 'test1.xml'
def test_notime(self):
assert self.tr.time is None
def test_name(self):
assert self.ts.name == 'nosetests'
def test_numbers(self):
assert self.tr.testsRun == 104
class Test2(X, TestCase):
FILENAME = 'test2.xml'
def test_time(self):
assert self.tr.time is not None
assert str(self.tr.time).startswith('0:00:05.')
class Test3(X, TestCase):
FILENAME = 'test3.xml'
def test_msg(self):
for f in self.tr.failures:
if len(f[1]):
assert 'foo.py' in f[1]
assert 'foo.py' in f[0].trace
assert 'AssertionError' == f[0].typename
assert 'AssertionError' in f[1]
assert 'None' not in f[1]
assert f[0].message is None
class Test4(X, TestCase):
FILENAME = 'test4.xml'
def test_props(self):
assert self.ts.properties['assert-passed'] == '1'
def test_name_has_been_parsed_within_testsuites(self):
assert self.ts.name == 'base_test_1'
def test_testsuite_package_has_been_parsed(self):
assert self.ts.package == 'testdb'
class Test5(X, TestCase):
FILENAME = 'test5.xml'
def test_message(self):
found = False
for test in self.ts:
if test.bad:
assert test.errored
assert 'The step timed out' in test.message
assert 'PathToMyProject' in test.trace
found = True
assert found
class Test6(X, TestCase):
FILENAME = 'test6.xml'
class Test7(X, TestCase):
FILENAME = 'test7.xml'
class Test8(X, TestCase):
FILENAME = 'test8.xml'
def test_bad_suite_time(self):
assert self.tr.time is None