summaryrefslogtreecommitdiffstats
path: root/Lib/test
diff options
context:
space:
mode:
authorAntoine Pitrou <solipsis@pitrou.net>2011-02-26 16:49:08 (GMT)
committerAntoine Pitrou <solipsis@pitrou.net>2011-02-26 16:49:08 (GMT)
commit4914f9e4e226b3bc4ebb650a8e5e3f1ef2acc3c6 (patch)
tree4a06e1e0aea6447486b8c7ac2e7f9582d58d3c24 /Lib/test
parent89807a5277be5733c7a8308867103bd75a1ece23 (diff)
downloadcpython-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.py34
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: