+ func(*args, **kwargs)
+ except etype as e:
+ return _check(True, 'EXCEPT(%s)' % _code())
+ except:
+ _check(False, 'EXCEPT(%s)' % _code())
+ raise
+ else:
+ return _check(False, 'EXCEPT(%s)' % _code())
+
+ wvstart = WVSTART
+ wvmsg = WVMSG
+ wvpass = WVPASS
+ wvfail = WVFAIL
+ wvpasseq = WVPASSEQ
+ wvpassne = WVPASSNE
+ wvpaslt = WVPASSLT
+ wvpassle = WVPASSLE
+ wvpassgt = WVPASSGT
+ wvpassge = WVPASSGE
+ wvexcept = WVEXCEPT
+
+ def wvfailure_count():
+ return _fails
+
+ def _check_unfinished():
+ if _registered:
+ for func in _registered:
+ print('WARNING: not run: %r' % (func,))
+ WVFAIL('wvtest_main() not called')
+ if _fails:
+ sys.exit(1)
+
+ atexit.register(_check_unfinished)
+
+
+def _run_in_chdir(path, func, *args, **kwargs):
+ oldwd = os.getcwd()
+ oldpath = sys.path
+ try:
+ os.chdir(path)
+ sys.path += [path, os.path.split(path)[0]]
+ return func(*args, **kwargs)
+ finally:
+ os.chdir(oldwd)
+ sys.path = oldpath
+
+
+def _runtest(fname, f):
+ mod = inspect.getmodule(f)
+ rpath = relpath(mod.__file__, os.getcwd()).replace('.pyc', '.py')
+ print()
+ print('Testing "%s" in %s:' % (fname, rpath))
+ sys.stdout.flush()
+ try:
+ _run_in_chdir(os.path.split(mod.__file__)[0], f)
+ except Exception as e:
+ print()
+ print(traceback.format_exc())
+ tb = sys.exc_info()[2]
+ wvtest._result(e, traceback.extract_tb(tb)[1], 'EXCEPTION')
+
+
+def _run_registered_tests():
+ import wvtest as _wvtestmod
+ while _wvtestmod._registered:
+ t = _wvtestmod._registered.pop(0)
+ _runtest(t.__name__, t)
+ print()
+
+
+def wvtest_main(extra_testfiles=tuple()):
+ import wvtest as _wvtestmod
+ _run_registered_tests()
+ for modname in extra_testfiles: