##// END OF EJS Templates
run-tests: initial support for running tests with unittest...
Gregory Szorc -
r21426:791bdd65 default
parent child Browse files
Show More
@@ -57,6 +57,7 b' import re'
57 57 import threading
58 58 import killdaemons as killmod
59 59 import Queue as queue
60 import unittest
60 61
61 62 processlock = threading.Lock()
62 63
@@ -187,6 +188,9 b' def getparser():'
187 188 parser.add_option("--tmpdir", type="string",
188 189 help="run tests in the given temporary directory"
189 190 " (implies --keep-tmpdir)")
191 parser.add_option("--unittest", action="store_true",
192 help="run tests with Python's unittest package"
193 " (this is an experimental feature)")
190 194 parser.add_option("-v", "--verbose", action="store_true",
191 195 help="output verbose messages")
192 196 parser.add_option("--view", type="string",
@@ -255,6 +259,13 b' def parseargs(args, parser):'
255 259
256 260 if options.jobs < 1:
257 261 parser.error('--jobs must be positive')
262 if options.unittest:
263 if options.jobs > 1:
264 sys.stderr.write(
265 'warning: --jobs has no effect with --unittest')
266 if options.loop:
267 sys.stderr.write(
268 'warning: --loop has no effect with --unittest')
258 269 if options.interactive and options.debug:
259 270 parser.error("-i/--interactive and -d/--debug are incompatible")
260 271 if options.debug:
@@ -1172,6 +1183,17 b' class TestRunner(object):'
1172 1183 print "running all tests"
1173 1184 tests = orig
1174 1185
1186 if self.options.unittest:
1187 suite = unittest.TestSuite()
1188 for count, testpath in enumerate(tests):
1189 suite.addTest(self._gettest(testpath, count, asunit=True))
1190
1191 verbosity = 1
1192 if self.options.verbose:
1193 verbosity = 2
1194 runner = unittest.TextTestRunner(verbosity=verbosity)
1195 runner.run(suite)
1196 else:
1175 1197 self._executetests(tests)
1176 1198
1177 1199 failed = len(self.results['!'])
@@ -1207,7 +1229,7 b' class TestRunner(object):'
1207 1229 if warned:
1208 1230 return 80
1209 1231
1210 def _gettest(self, test, count):
1232 def _gettest(self, test, count, asunit=False):
1211 1233 """Obtain a Test by looking at its filename.
1212 1234
1213 1235 Returns a Test instance. The Test may not be runnable if it doesn't
@@ -1224,7 +1246,17 b' class TestRunner(object):'
1224 1246 refpath = os.path.join(self.testdir, test + out)
1225 1247 break
1226 1248
1227 return testcls(self, test, count, refpath)
1249 t = testcls(self, test, count, refpath)
1250
1251 if not asunit:
1252 return t
1253
1254 # If we want a unittest compatible object, we wrap our Test.
1255 class MercurialTest(unittest.TestCase):
1256 def runTest(self):
1257 t.run()
1258
1259 return MercurialTest()
1228 1260
1229 1261 def _cleanup(self):
1230 1262 """Clean up state from this test invocation."""
General Comments 0
You need to be logged in to leave comments. Login now