2009-02-06 04:55:23 -04:00
|
|
|
"""Tests for distutils.cmd."""
|
|
|
|
import unittest
|
2009-04-13 17:03:44 -03:00
|
|
|
import os
|
2010-02-06 19:53:52 -04:00
|
|
|
from test.test_support import captured_stdout, run_unittest
|
2009-02-06 04:55:23 -04:00
|
|
|
|
|
|
|
from distutils.cmd import Command
|
|
|
|
from distutils.dist import Distribution
|
|
|
|
from distutils.errors import DistutilsOptionError
|
2009-09-21 09:19:07 -03:00
|
|
|
from distutils import debug
|
2009-02-06 04:55:23 -04:00
|
|
|
|
2009-02-06 20:05:39 -04:00
|
|
|
class MyCmd(Command):
|
|
|
|
def initialize_options(self):
|
|
|
|
pass
|
2009-02-06 04:55:23 -04:00
|
|
|
|
2009-02-06 20:05:39 -04:00
|
|
|
class CommandTestCase(unittest.TestCase):
|
2009-02-06 04:55:23 -04:00
|
|
|
|
2009-02-06 20:05:39 -04:00
|
|
|
def setUp(self):
|
2009-02-06 04:55:23 -04:00
|
|
|
dist = Distribution()
|
2009-02-06 20:05:39 -04:00
|
|
|
self.cmd = MyCmd(dist)
|
|
|
|
|
|
|
|
def test_ensure_string_list(self):
|
2009-02-06 04:55:23 -04:00
|
|
|
|
2009-02-06 20:05:39 -04:00
|
|
|
cmd = self.cmd
|
2009-02-06 04:55:23 -04:00
|
|
|
cmd.not_string_list = ['one', 2, 'three']
|
|
|
|
cmd.yes_string_list = ['one', 'two', 'three']
|
|
|
|
cmd.not_string_list2 = object()
|
|
|
|
cmd.yes_string_list2 = 'ok'
|
|
|
|
cmd.ensure_string_list('yes_string_list')
|
|
|
|
cmd.ensure_string_list('yes_string_list2')
|
|
|
|
|
|
|
|
self.assertRaises(DistutilsOptionError,
|
|
|
|
cmd.ensure_string_list, 'not_string_list')
|
|
|
|
|
|
|
|
self.assertRaises(DistutilsOptionError,
|
|
|
|
cmd.ensure_string_list, 'not_string_list2')
|
|
|
|
|
2009-02-06 20:05:39 -04:00
|
|
|
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):
|
2010-11-21 09:34:58 -04:00
|
|
|
self.assertEqual(exec_msg, 'generating out from in')
|
2009-02-06 20:05:39 -04:00
|
|
|
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']
|
2010-11-21 09:34:58 -04:00
|
|
|
self.assertEqual(msgs, wanted)
|
2009-02-06 20:05:39 -04:00
|
|
|
|
2009-04-13 17:03:44 -03:00
|
|
|
def test_ensure_string(self):
|
|
|
|
cmd = self.cmd
|
|
|
|
cmd.option1 = 'ok'
|
|
|
|
cmd.ensure_string('option1')
|
|
|
|
|
|
|
|
cmd.option2 = None
|
|
|
|
cmd.ensure_string('option2', 'xxx')
|
2009-06-30 19:57:08 -03:00
|
|
|
self.assertTrue(hasattr(cmd, 'option2'))
|
2009-04-13 17:03:44 -03:00
|
|
|
|
|
|
|
cmd.option3 = 1
|
|
|
|
self.assertRaises(DistutilsOptionError, cmd.ensure_string, 'option3')
|
|
|
|
|
|
|
|
def test_ensure_string_list(self):
|
|
|
|
cmd = self.cmd
|
|
|
|
cmd.option1 = 'ok,dok'
|
|
|
|
cmd.ensure_string_list('option1')
|
2010-11-21 09:34:58 -04:00
|
|
|
self.assertEqual(cmd.option1, ['ok', 'dok'])
|
2009-04-13 17:03:44 -03:00
|
|
|
|
|
|
|
cmd.option2 = ['xxx', 'www']
|
|
|
|
cmd.ensure_string_list('option2')
|
|
|
|
|
|
|
|
cmd.option3 = ['ok', 2]
|
|
|
|
self.assertRaises(DistutilsOptionError, cmd.ensure_string_list,
|
|
|
|
'option3')
|
|
|
|
|
|
|
|
def test_ensure_filename(self):
|
|
|
|
cmd = self.cmd
|
|
|
|
cmd.option1 = __file__
|
|
|
|
cmd.ensure_filename('option1')
|
|
|
|
cmd.option2 = 'xxx'
|
|
|
|
self.assertRaises(DistutilsOptionError, cmd.ensure_filename, 'option2')
|
|
|
|
|
|
|
|
def test_ensure_dirname(self):
|
|
|
|
cmd = self.cmd
|
Merged revisions 86236,86240,86332,86340,87271,87273,87447 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/branches/py3k
To comply with the 2.x doc style, the methods in trace.rst use brackets around
optional arguments. The rest is a mostly straight merge, modulo support changed
to test_support and use of the old super call style in test_tuple.
........
r86236 | eric.araujo | 2010-11-06 03:44:43 +0100 (sam., 06 nov. 2010) | 2 lines
Make sure each test can be run standalone (./python Lib/distutils/tests/x.py)
........
r86240 | eric.araujo | 2010-11-06 05:11:59 +0100 (sam., 06 nov. 2010) | 2 lines
Prevent ResourceWarnings in test_gettext
........
r86332 | eric.araujo | 2010-11-08 19:15:17 +0100 (lun., 08 nov. 2010) | 4 lines
Add missing NEWS entry for a fix committed by Senthil.
All recent modifications to distutils should now be covered in NEWS.
........
r86340 | eric.araujo | 2010-11-08 22:48:23 +0100 (lun., 08 nov. 2010) | 2 lines
This was actually fixed for the previous alpha.
........
r87271 | eric.araujo | 2010-12-15 20:09:58 +0100 (mer., 15 déc. 2010) | 2 lines
Improve trace documentation (#9264). Patch by Eli Bendersky.
........
r87273 | eric.araujo | 2010-12-15 20:30:15 +0100 (mer., 15 déc. 2010) | 2 lines
Use nested method directives, rewrap long lines, fix whitespace.
........
r87447 | eric.araujo | 2010-12-23 20:13:05 +0100 (jeu., 23 déc. 2010) | 2 lines
Fix typo in superclass method name
........
2011-02-02 20:12:18 -04:00
|
|
|
cmd.option1 = os.path.dirname(__file__) or os.curdir
|
2009-04-13 17:03:44 -03:00
|
|
|
cmd.ensure_dirname('option1')
|
|
|
|
cmd.option2 = 'xxx'
|
|
|
|
self.assertRaises(DistutilsOptionError, cmd.ensure_dirname, 'option2')
|
|
|
|
|
2009-09-21 09:19:07 -03:00
|
|
|
def test_debug_print(self):
|
|
|
|
cmd = self.cmd
|
|
|
|
with captured_stdout() as stdout:
|
|
|
|
cmd.debug_print('xxx')
|
|
|
|
stdout.seek(0)
|
2010-11-21 09:34:58 -04:00
|
|
|
self.assertEqual(stdout.read(), '')
|
2009-09-21 09:19:07 -03:00
|
|
|
|
|
|
|
debug.DEBUG = True
|
|
|
|
try:
|
|
|
|
with captured_stdout() as stdout:
|
|
|
|
cmd.debug_print('xxx')
|
|
|
|
stdout.seek(0)
|
2010-11-21 09:34:58 -04:00
|
|
|
self.assertEqual(stdout.read(), 'xxx\n')
|
2009-09-21 09:19:07 -03:00
|
|
|
finally:
|
|
|
|
debug.DEBUG = False
|
|
|
|
|
2009-02-06 04:55:23 -04:00
|
|
|
def test_suite():
|
|
|
|
return unittest.makeSuite(CommandTestCase)
|
|
|
|
|
|
|
|
if __name__ == '__main__':
|
2010-02-06 19:53:52 -04:00
|
|
|
run_unittest(test_suite())
|