mirror of
https://github.com/python/cpython.git
synced 2025-08-01 15:43:13 +00:00
Issue 17502: unittest discovery should use self.testLoader
This commit is contained in:
parent
6c22b1d760
commit
8fd396bd22
3 changed files with 20 additions and 1 deletions
|
@ -197,7 +197,10 @@ class TestProgram(object):
|
||||||
self.test = self.testLoader.loadTestsFromNames(self.testNames,
|
self.test = self.testLoader.loadTestsFromNames(self.testNames,
|
||||||
self.module)
|
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
|
# handle command line args for test discovery
|
||||||
self.progName = '%s discover' % self.progName
|
self.progName = '%s discover' % self.progName
|
||||||
import optparse
|
import optparse
|
||||||
|
|
|
@ -253,12 +253,26 @@ class TestDiscovery(unittest.TestCase):
|
||||||
|
|
||||||
program = TestableTestProgram()
|
program = TestableTestProgram()
|
||||||
program.usageExit = usageExit
|
program.usageExit = usageExit
|
||||||
|
program.testLoader = None
|
||||||
|
|
||||||
with self.assertRaises(Stop):
|
with self.assertRaises(Stop):
|
||||||
# too many args
|
# too many args
|
||||||
program._do_discovery(['one', 'two', 'three', 'four'])
|
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):
|
def test_command_line_handling_do_discovery_calls_loader(self):
|
||||||
program = TestableTestProgram()
|
program = TestableTestProgram()
|
||||||
|
|
||||||
|
|
|
@ -221,6 +221,8 @@ Core and Builtins
|
||||||
Library
|
Library
|
||||||
-------
|
-------
|
||||||
|
|
||||||
|
- Issue #17502: unittest discovery should use self.testLoader.
|
||||||
|
|
||||||
- Issue #17141: random.vonmisesvariate() no more hangs for large kappas.
|
- Issue #17141: random.vonmisesvariate() no more hangs for large kappas.
|
||||||
|
|
||||||
- Issue #17149: Fix random.vonmisesvariate to always return results in
|
- Issue #17149: Fix random.vonmisesvariate to always return results in
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue