]> granicus.if.org Git - python/commitdiff
Issue 17502: unittest discovery should use self.testLoader
authorMichael Foord <michael@voidspace.org.uk>
Sun, 10 Feb 2013 23:59:46 +0000 (23:59 +0000)
committerMichael Foord <michael@voidspace.org.uk>
Sun, 10 Feb 2013 23:59:46 +0000 (23:59 +0000)
Lib/unittest/main.py
Lib/unittest/test/test_discovery.py
Misc/NEWS

index 3396bb0ab69caae8434116c696052050596cff3d..1e001a6a2605a01c5118ab4d3d5db10f4c0b6147 100644 (file)
@@ -157,7 +157,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 1155de116f9bef18daa4287f2a6efed0a1a0e86e..3dec2ee57e1da45ed6157018be6dac9ecd9b3c08 100644 (file)
@@ -220,12 +220,26 @@ class TestDiscovery(unittest.TestCase):
 
         program = object.__new__(unittest.TestProgram)
         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 = object.__new__(unittest.TestProgram)
 
index 9989b7b10c3f2b7b0fd76c4ab81acace99a49a2e..d5186d3353b1d3db84c74a89b65caf671a232238 100644 (file)
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -202,6 +202,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