Commit 4914f9e4 authored by Antoine Pitrou's avatar Antoine Pitrou

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.
........
parent 89807a52
...@@ -233,6 +233,36 @@ def forget(modname): ...@@ -233,6 +233,36 @@ def forget(modname):
unlink(imp.cache_from_source(source, debug_override=True)) unlink(imp.cache_from_source(source, debug_override=True))
unlink(imp.cache_from_source(source, debug_override=False)) 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): def is_resource_enabled(resource):
"""Test whether a resource is enabled. Known resources are set by """Test whether a resource is enabled. Known resources are set by
regrtest.py.""" regrtest.py."""
...@@ -245,6 +275,8 @@ def requires(resource, msg=None): ...@@ -245,6 +275,8 @@ def requires(resource, msg=None):
possibility of False being returned occurs when regrtest.py is possibility of False being returned occurs when regrtest.py is
executing. 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 # see if the caller's module is __main__ - if so, treat as if
# the resource was set # the resource was set
if sys._getframe(1).f_globals.get("__name__") == "__main__": if sys._getframe(1).f_globals.get("__name__") == "__main__":
...@@ -1063,6 +1095,8 @@ def _id(obj): ...@@ -1063,6 +1095,8 @@ def _id(obj):
return obj return obj
def requires_resource(resource): 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): if is_resource_enabled(resource):
return _id return _id
else: else:
......
...@@ -55,6 +55,9 @@ Build ...@@ -55,6 +55,9 @@ Build
Tests Tests
----- -----
- Issue #9931: Fix hangs in GUI tests under Windows in certain conditions.
Patch by Hirokazu Yamamoto.
- Issue #10826: Prevent sporadic failure in test_subprocess on Solaris due - Issue #10826: Prevent sporadic failure in test_subprocess on Solaris due
to open door files. to open door files.
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment