mirror of
https://github.com/python/cpython.git
synced 2025-07-24 19:54:21 +00:00
Merge. Closes issue 17052.
This commit is contained in:
commit
4e08f786f0
3 changed files with 21 additions and 1 deletions
|
@ -175,6 +175,7 @@ class TestProgram(object):
|
|||
self.module)
|
||||
|
||||
def _getOptParser(self):
|
||||
import optparse
|
||||
parser = optparse.OptionParser()
|
||||
parser.prog = self.progName
|
||||
parser.add_option('-v', '--verbose', dest='verbose', default=False,
|
||||
|
@ -219,7 +220,10 @@ class TestProgram(object):
|
|||
parser.add_option('-t', '--top-level-directory', dest='top', default=None,
|
||||
help='Top level directory of project (defaults to start directory)')
|
||||
|
||||
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
|
||||
parser = self._getOptParser()
|
||||
|
|
|
@ -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()
|
||||
|
||||
|
|
|
@ -250,6 +250,8 @@ Core and Builtins
|
|||
Library
|
||||
-------
|
||||
|
||||
- Issue #17502: unittest discovery should use self.testLoader.
|
||||
|
||||
- Issue #4591: Uid and gid values larger than 2**31 are supported now.
|
||||
|
||||
- Issue #17141: random.vonmisesvariate() no more hangs for large kappas.
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue