]> git.ipfire.org Git - thirdparty/Python/cpython.git/commitdiff
Issue 17502: unittest discovery should use self.testLoader
authorMichael Foord <michael@voidspace.org.uk>
Mon, 11 Feb 2013 00:04:24 +0000 (00:04 +0000)
committerMichael Foord <michael@voidspace.org.uk>
Mon, 11 Feb 2013 00:04:24 +0000 (00:04 +0000)
Lib/unittest/main.py
Lib/unittest/test/test_discovery.py
Misc/NEWS

index 55d4e4be148e32597e45835c7c320747ded5b4a7..d09bccdf2c22c53d14a5485ab13ae91c3a7dabdb 100644 (file)
@@ -197,7 +197,10 @@ class TestProgram(object):
             self.test = self.testLoader.loadTestsFromNames(self.testNames,
                                                            self.module)
 
-    def _do_discovery(self, argv, Loader=loader.TestLoader):
+    def _do_discovery(self, argv, Loader=None):
+        if Loader is None:
+            Loader = self.testLoader
+
         # handle command line args for test discovery
         self.progName = '%s discover' % self.progName
         import optparse
index e688f8e35ac61fac7e576694cc254f95e709c0d6..eba269fc7a387c33b5218be825c1ba2276dbd341 100644 (file)
@@ -253,12 +253,26 @@ class TestDiscovery(unittest.TestCase):
 
         program = TestableTestProgram()
         program.usageExit = usageExit
+        program.testLoader = None
 
         with self.assertRaises(Stop):
             # too many args
             program._do_discovery(['one', 'two', 'three', 'four'])
 
 
+    def test_command_line_handling_do_discovery_uses_default_loader(self):
+        program = object.__new__(unittest.TestProgram)
+
+        class Loader(object):
+            args = []
+            def discover(self, start_dir, pattern, top_level_dir):
+                self.args.append((start_dir, pattern, top_level_dir))
+                return 'tests'
+
+        program.testLoader = Loader
+        program._do_discovery(['-v'])
+        self.assertEqual(Loader.args, [('.', 'test*.py', None)])
+
     def test_command_line_handling_do_discovery_calls_loader(self):
         program = TestableTestProgram()
 
index eff2176fadf0351ae6c5b18e8a59ffdc5b689620..d6ac0e7d610d3b5aef071fd5fb29bca72315537e 100644 (file)
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -221,6 +221,8 @@ Core and Builtins
 Library
 -------
 
+- Issue #17502: unittest discovery should use self.testLoader.
+
 - Issue #17141: random.vonmisesvariate() no more hangs for large kappas.
 
 - Issue #17149: Fix random.vonmisesvariate to always return results in