diff options
author | Terry Jan Reedy <tjreedy@udel.edu> | 2013-07-22 00:13:24 (GMT) |
---|---|---|
committer | Terry Jan Reedy <tjreedy@udel.edu> | 2013-07-22 00:13:24 (GMT) |
commit | 09eb26fe26d533974f38907328b1160cbcfd6d21 (patch) | |
tree | 4770432c7a9b93029ce5285efb341b8f99c95aa0 | |
parent | 241f653b8a2d62d41c5392056f5610173e82d11e (diff) | |
download | cpython-09eb26fe26d533974f38907328b1160cbcfd6d21.zip cpython-09eb26fe26d533974f38907328b1160cbcfd6d21.tar.gz cpython-09eb26fe26d533974f38907328b1160cbcfd6d21.tar.bz2 |
Issue #18441: Make test.support.requires('gui') skip when it should.
(Consolidating this check and various checks in tkinter files and moving them
to test.support and test.regrtest will be another issue.)
-rw-r--r-- | Lib/idlelib/idle_test/test_text.py | 5 | ||||
-rw-r--r-- | Lib/test/test_idle.py | 20 |
2 files changed, 17 insertions, 8 deletions
diff --git a/Lib/idlelib/idle_test/test_text.py b/Lib/idlelib/idle_test/test_text.py index 904ace7..3a0705b 100644 --- a/Lib/idlelib/idle_test/test_text.py +++ b/Lib/idlelib/idle_test/test_text.py @@ -216,10 +216,7 @@ class TkTextTest(TextTest, unittest.TestCase): requires('gui') from Tkinter import Tk, Text cls.Text = Text - try: - cls.root = Tk() - except TclError as msg: - raise unittest.SkipTest('TclError: %s' % msg) + cls.root = Tk() @classmethod def tearDownClass(cls): diff --git a/Lib/test/test_idle.py b/Lib/test/test_idle.py index 4262aa3..540f7d2 100644 --- a/Lib/test/test_idle.py +++ b/Lib/test/test_idle.py @@ -1,9 +1,21 @@ -# Skip test if _tkinter or _thread wasn't built or idlelib was deleted. -from test.test_support import import_module -import_module('Tkinter') -import_module('threading') # imported by PyShell, imports _thread +# Skip test if _thread or _tkinter wasn't built or idlelib was deleted. +from test.test_support import import_module, use_resources +import_module('threading') # imported by idlelib.PyShell, imports _thread +tk = import_module('Tkinter') idletest = import_module('idlelib.idle_test') +# If buildbot improperly sets gui resource (#18365, #18441), remove it +# so requires('gui') tests are skipped while non-gui tests still run. +if use_resources and 'gui' in use_resources: + try: + root = tk.Tk() + root.destroy() + except TclError: + while True: + use_resources.delete('gui') + if 'gui' not in use_resources: + break + # Without test_main present, regrtest.runtest_inner (line1219) calls # unittest.TestLoader().loadTestsFromModule(this_module) which calls # load_tests() if it finds it. (Unittest.main does the same.) |