diff options
author | Antoine Pitrou <solipsis@pitrou.net> | 2011-02-26 16:49:08 (GMT) |
---|---|---|
committer | Antoine Pitrou <solipsis@pitrou.net> | 2011-02-26 16:49:08 (GMT) |
commit | 4914f9e4e226b3bc4ebb650a8e5e3f1ef2acc3c6 (patch) | |
tree | 4a06e1e0aea6447486b8c7ac2e7f9582d58d3c24 /Lib/test | |
parent | 89807a5277be5733c7a8308867103bd75a1ece23 (diff) | |
download | cpython-4914f9e4e226b3bc4ebb650a8e5e3f1ef2acc3c6.zip cpython-4914f9e4e226b3bc4ebb650a8e5e3f1ef2acc3c6.tar.gz cpython-4914f9e4e226b3bc4ebb650a8e5e3f1ef2acc3c6.tar.bz2 |
Merged revisions 88652 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/branches/py3k
........
r88652 | antoine.pitrou | 2011-02-26 16:58:05 +0100 (sam., 26 févr. 2011) | 4 lines
Issue #9931: Fix hangs in GUI tests under Windows in certain conditions.
Patch by Hirokazu Yamamoto.
........
Diffstat (limited to 'Lib/test')
-rw-r--r-- | Lib/test/support.py | 34 |
1 files changed, 34 insertions, 0 deletions
diff --git a/Lib/test/support.py b/Lib/test/support.py index ea5b9cb..7a43f97 100644 --- a/Lib/test/support.py +++ b/Lib/test/support.py @@ -233,6 +233,36 @@ def forget(modname): unlink(imp.cache_from_source(source, debug_override=True)) unlink(imp.cache_from_source(source, debug_override=False)) +# On some platforms, should not run gui test even if it is allowed +# in `use_resources'. +if sys.platform.startswith('win'): + import ctypes + import ctypes.wintypes + def _is_gui_available(): + UOI_FLAGS = 1 + WSF_VISIBLE = 0x0001 + class USEROBJECTFLAGS(ctypes.Structure): + _fields_ = [("fInherit", ctypes.wintypes.BOOL), + ("fReserved", ctypes.wintypes.BOOL), + ("dwFlags", ctypes.wintypes.DWORD)] + dll = ctypes.windll.user32 + h = dll.GetProcessWindowStation() + if not h: + raise ctypes.WinError() + uof = USEROBJECTFLAGS() + needed = ctypes.wintypes.DWORD() + res = dll.GetUserObjectInformationW(h, + UOI_FLAGS, + ctypes.byref(uof), + ctypes.sizeof(uof), + ctypes.byref(needed)) + if not res: + raise ctypes.WinError() + return bool(uof.dwFlags & WSF_VISIBLE) +else: + def _is_gui_available(): + return True + def is_resource_enabled(resource): """Test whether a resource is enabled. Known resources are set by regrtest.py.""" @@ -245,6 +275,8 @@ def requires(resource, msg=None): possibility of False being returned occurs when regrtest.py is executing. """ + if resource == 'gui' and not _is_gui_available(): + raise unittest.SkipTest("Cannot use the 'gui' resource") # see if the caller's module is __main__ - if so, treat as if # the resource was set if sys._getframe(1).f_globals.get("__name__") == "__main__": @@ -1063,6 +1095,8 @@ def _id(obj): return obj def requires_resource(resource): + if resource == 'gui' and not _is_gui_available(): + return unittest.skip("resource 'gui' is not available") if is_resource_enabled(resource): return _id else: |