mirror of
https://github.com/python/cpython.git
synced 2025-09-26 18:29:57 +00:00
#3986 replacing string and types call (like in the Py3k branch), and put exec_msg call at the right place
This commit is contained in:
parent
363161a418
commit
8be8765a2e
2 changed files with 55 additions and 24 deletions
|
@ -6,7 +6,7 @@ in the distutils.command package.
|
||||||
|
|
||||||
__revision__ = "$Id$"
|
__revision__ = "$Id$"
|
||||||
|
|
||||||
import sys, os, string, re
|
import sys, os, re
|
||||||
from distutils.errors import DistutilsOptionError
|
from distutils.errors import DistutilsOptionError
|
||||||
from distutils import util, dir_util, file_util, archive_util, dep_util
|
from distutils import util, dir_util, file_util, archive_util, dep_util
|
||||||
from distutils import log
|
from distutils import log
|
||||||
|
@ -160,15 +160,15 @@ class Command:
|
||||||
from distutils.fancy_getopt import longopt_xlate
|
from distutils.fancy_getopt import longopt_xlate
|
||||||
if header is None:
|
if header is None:
|
||||||
header = "command options for '%s':" % self.get_command_name()
|
header = "command options for '%s':" % self.get_command_name()
|
||||||
print indent + header
|
self.announce(indent + header, level=log.INFO)
|
||||||
indent = indent + " "
|
indent = indent + " "
|
||||||
for (option, _, _) in self.user_options:
|
for (option, _, _) in self.user_options:
|
||||||
option = string.translate(option, longopt_xlate)
|
option = option.translate(longopt_xlate)
|
||||||
if option[-1] == "=":
|
if option[-1] == "=":
|
||||||
option = option[:-1]
|
option = option[:-1]
|
||||||
value = getattr(self, option)
|
value = getattr(self, option)
|
||||||
print indent + "%s = %s" % (option, value)
|
self.announce(indent + "%s = %s" % (option, value),
|
||||||
|
level=log.INFO)
|
||||||
|
|
||||||
def run (self):
|
def run (self):
|
||||||
"""A command's raison d'etre: carry out the action it exists to
|
"""A command's raison d'etre: carry out the action it exists to
|
||||||
|
@ -415,20 +415,20 @@ class Command:
|
||||||
and it is true, then the command is unconditionally run -- does no
|
and it is true, then the command is unconditionally run -- does no
|
||||||
timestamp checks.
|
timestamp checks.
|
||||||
"""
|
"""
|
||||||
if exec_msg is None:
|
|
||||||
exec_msg = "generating %s from %s" % \
|
|
||||||
(outfile, string.join(infiles, ', '))
|
|
||||||
if skip_msg is None:
|
if skip_msg is None:
|
||||||
skip_msg = "skipping %s (inputs unchanged)" % outfile
|
skip_msg = "skipping %s (inputs unchanged)" % outfile
|
||||||
|
|
||||||
|
|
||||||
# Allow 'infiles' to be a single string
|
# Allow 'infiles' to be a single string
|
||||||
if type(infiles) is StringType:
|
if isinstance(infiles, str):
|
||||||
infiles = (infiles,)
|
infiles = (infiles,)
|
||||||
elif type(infiles) not in (ListType, TupleType):
|
elif not isinstance(infiles, (list, tuple)):
|
||||||
raise TypeError, \
|
raise TypeError, \
|
||||||
"'infiles' must be a string, or a list or tuple of strings"
|
"'infiles' must be a string, or a list or tuple of strings"
|
||||||
|
|
||||||
|
if exec_msg is None:
|
||||||
|
exec_msg = "generating %s from %s" % \
|
||||||
|
(outfile, ', '.join(infiles))
|
||||||
|
|
||||||
# If 'outfile' must be regenerated (either because it doesn't
|
# If 'outfile' must be regenerated (either because it doesn't
|
||||||
# exist, is out-of-date, or the 'force' flag is true) then
|
# exist, is out-of-date, or the 'force' flag is true) then
|
||||||
# perform the action that presumably regenerates it
|
# perform the action that presumably regenerates it
|
||||||
|
|
|
@ -5,23 +5,23 @@ from distutils.cmd import Command
|
||||||
from distutils.dist import Distribution
|
from distutils.dist import Distribution
|
||||||
from distutils.errors import DistutilsOptionError
|
from distutils.errors import DistutilsOptionError
|
||||||
|
|
||||||
class CommandTestCase(unittest.TestCase):
|
|
||||||
|
|
||||||
def test_ensure_string_list(self):
|
|
||||||
|
|
||||||
class MyCmd(Command):
|
class MyCmd(Command):
|
||||||
|
|
||||||
def initialize_options(self):
|
def initialize_options(self):
|
||||||
pass
|
pass
|
||||||
|
|
||||||
dist = Distribution()
|
class CommandTestCase(unittest.TestCase):
|
||||||
cmd = MyCmd(dist)
|
|
||||||
|
|
||||||
|
def setUp(self):
|
||||||
|
dist = Distribution()
|
||||||
|
self.cmd = MyCmd(dist)
|
||||||
|
|
||||||
|
def test_ensure_string_list(self):
|
||||||
|
|
||||||
|
cmd = self.cmd
|
||||||
cmd.not_string_list = ['one', 2, 'three']
|
cmd.not_string_list = ['one', 2, 'three']
|
||||||
cmd.yes_string_list = ['one', 'two', 'three']
|
cmd.yes_string_list = ['one', 'two', 'three']
|
||||||
cmd.not_string_list2 = object()
|
cmd.not_string_list2 = object()
|
||||||
cmd.yes_string_list2 = 'ok'
|
cmd.yes_string_list2 = 'ok'
|
||||||
|
|
||||||
cmd.ensure_string_list('yes_string_list')
|
cmd.ensure_string_list('yes_string_list')
|
||||||
cmd.ensure_string_list('yes_string_list2')
|
cmd.ensure_string_list('yes_string_list2')
|
||||||
|
|
||||||
|
@ -31,6 +31,37 @@ class CommandTestCase(unittest.TestCase):
|
||||||
self.assertRaises(DistutilsOptionError,
|
self.assertRaises(DistutilsOptionError,
|
||||||
cmd.ensure_string_list, 'not_string_list2')
|
cmd.ensure_string_list, 'not_string_list2')
|
||||||
|
|
||||||
|
def test_make_file(self):
|
||||||
|
|
||||||
|
cmd = self.cmd
|
||||||
|
|
||||||
|
# making sure it raises when infiles is not a string or a list/tuple
|
||||||
|
self.assertRaises(TypeError, cmd.make_file,
|
||||||
|
infiles=1, outfile='', func='func', args=())
|
||||||
|
|
||||||
|
# making sure execute gets called properly
|
||||||
|
def _execute(func, args, exec_msg, level):
|
||||||
|
self.assertEquals(exec_msg, 'generating out from in')
|
||||||
|
cmd.force = True
|
||||||
|
cmd.execute = _execute
|
||||||
|
cmd.make_file(infiles='in', outfile='out', func='func', args=())
|
||||||
|
|
||||||
|
def test_dump_options(self):
|
||||||
|
|
||||||
|
msgs = []
|
||||||
|
def _announce(msg, level):
|
||||||
|
msgs.append(msg)
|
||||||
|
cmd = self.cmd
|
||||||
|
cmd.announce = _announce
|
||||||
|
cmd.option1 = 1
|
||||||
|
cmd.option2 = 1
|
||||||
|
cmd.user_options = [('option1', '', ''), ('option2', '', '')]
|
||||||
|
cmd.dump_options()
|
||||||
|
|
||||||
|
wanted = ["command options for 'MyCmd':", ' option1 = 1',
|
||||||
|
' option2 = 1']
|
||||||
|
self.assertEquals(msgs, wanted)
|
||||||
|
|
||||||
def test_suite():
|
def test_suite():
|
||||||
return unittest.makeSuite(CommandTestCase)
|
return unittest.makeSuite(CommandTestCase)
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue