2009-02-13 18:26:15 -04:00
|
|
|
"""Tests for distutils.util."""
|
|
|
|
import os
|
|
|
|
import sys
|
|
|
|
import unittest
|
2009-04-13 09:37:57 -03:00
|
|
|
from copy import copy
|
2009-07-16 13:18:19 -03:00
|
|
|
from io import BytesIO
|
|
|
|
import subprocess
|
2009-02-13 18:26:15 -04:00
|
|
|
|
2010-01-29 07:41:03 -04:00
|
|
|
from sysconfig import get_config_vars, get_platform
|
2009-10-25 20:08:47 -03:00
|
|
|
from distutils.errors import DistutilsPlatformError, DistutilsByteCompileError
|
2010-01-29 07:41:03 -04:00
|
|
|
from distutils.util import (convert_path, change_root,
|
2009-05-10 09:20:44 -03:00
|
|
|
check_environ, split_quoted, strtobool,
|
2009-07-16 13:18:19 -03:00
|
|
|
rfc822_escape, get_compiler_versions,
|
2009-10-25 20:08:47 -03:00
|
|
|
_find_exe_version, _MAC_OS_X_LD_VERSION,
|
|
|
|
byte_compile)
|
2009-07-16 13:18:19 -03:00
|
|
|
from distutils import util
|
2009-05-10 09:20:44 -03:00
|
|
|
from distutils.tests import support
|
2009-07-16 13:18:19 -03:00
|
|
|
from distutils.version import LooseVersion
|
|
|
|
|
|
|
|
class FakePopen(object):
|
|
|
|
test_class = None
|
|
|
|
def __init__(self, cmd, shell, stdout, stderr):
|
|
|
|
self.cmd = cmd.split()[0]
|
|
|
|
exes = self.test_class._exes
|
|
|
|
if self.cmd not in exes:
|
|
|
|
# we don't want to call the system, returning an empty
|
|
|
|
# output so it doesn't match
|
|
|
|
self.stdout = BytesIO()
|
|
|
|
self.stderr = BytesIO()
|
|
|
|
else:
|
|
|
|
self.stdout = BytesIO(exes[self.cmd])
|
|
|
|
self.stderr = BytesIO()
|
2009-02-13 18:26:15 -04:00
|
|
|
|
2009-05-10 09:20:44 -03:00
|
|
|
class UtilTestCase(support.EnvironGuard, unittest.TestCase):
|
2009-02-13 18:26:15 -04:00
|
|
|
|
|
|
|
def setUp(self):
|
2009-05-10 09:20:44 -03:00
|
|
|
super(UtilTestCase, self).setUp()
|
2009-02-13 18:26:15 -04:00
|
|
|
# saving the environment
|
|
|
|
self.name = os.name
|
|
|
|
self.platform = sys.platform
|
|
|
|
self.version = sys.version
|
|
|
|
self.sep = os.sep
|
|
|
|
self.join = os.path.join
|
|
|
|
self.isabs = os.path.isabs
|
|
|
|
self.splitdrive = os.path.splitdrive
|
2010-01-29 07:41:03 -04:00
|
|
|
#self._config_vars = copy(sysconfig._config_vars)
|
2009-02-13 18:26:15 -04:00
|
|
|
|
|
|
|
# patching os.uname
|
|
|
|
if hasattr(os, 'uname'):
|
|
|
|
self.uname = os.uname
|
|
|
|
self._uname = os.uname()
|
|
|
|
else:
|
|
|
|
self.uname = None
|
|
|
|
self._uname = None
|
2009-02-13 19:48:11 -04:00
|
|
|
os.uname = self._get_uname
|
|
|
|
|
2009-07-16 13:18:19 -03:00
|
|
|
# patching POpen
|
|
|
|
self.old_find_executable = util.find_executable
|
|
|
|
util.find_executable = self._find_executable
|
|
|
|
self._exes = {}
|
|
|
|
self.old_popen = subprocess.Popen
|
2009-11-01 18:38:44 -04:00
|
|
|
self.old_stdout = sys.stdout
|
|
|
|
self.old_stderr = sys.stderr
|
2009-07-16 13:18:19 -03:00
|
|
|
FakePopen.test_class = self
|
|
|
|
subprocess.Popen = FakePopen
|
|
|
|
|
2009-02-13 18:26:15 -04:00
|
|
|
def tearDown(self):
|
2009-04-13 09:37:57 -03:00
|
|
|
# getting back the environment
|
2009-02-13 18:26:15 -04:00
|
|
|
os.name = self.name
|
|
|
|
sys.platform = self.platform
|
|
|
|
sys.version = self.version
|
|
|
|
os.sep = self.sep
|
|
|
|
os.path.join = self.join
|
|
|
|
os.path.isabs = self.isabs
|
|
|
|
os.path.splitdrive = self.splitdrive
|
|
|
|
if self.uname is not None:
|
|
|
|
os.uname = self.uname
|
2009-03-11 09:52:00 -03:00
|
|
|
else:
|
|
|
|
del os.uname
|
2010-01-29 07:41:03 -04:00
|
|
|
#sysconfig._config_vars = copy(self._config_vars)
|
2009-07-16 13:18:19 -03:00
|
|
|
util.find_executable = self.old_find_executable
|
|
|
|
subprocess.Popen = self.old_popen
|
2009-11-01 18:38:44 -04:00
|
|
|
sys.old_stdout = self.old_stdout
|
|
|
|
sys.old_stderr = self.old_stderr
|
2009-05-10 09:20:44 -03:00
|
|
|
super(UtilTestCase, self).tearDown()
|
2009-02-13 18:26:15 -04:00
|
|
|
|
|
|
|
def _set_uname(self, uname):
|
|
|
|
self._uname = uname
|
|
|
|
|
|
|
|
def _get_uname(self):
|
|
|
|
return self._uname
|
|
|
|
|
2010-01-29 07:46:31 -04:00
|
|
|
def test_get_platform(self):
|
|
|
|
platform = util.get_platform()
|
|
|
|
self.assertEquals(platform, get_platform())
|
|
|
|
util.set_platform('MyOwnPlatform')
|
|
|
|
self.assertEquals('MyOwnPlatform', util.get_platform())
|
|
|
|
util.set_platform(platform)
|
2009-02-13 18:26:15 -04:00
|
|
|
|
|
|
|
def test_convert_path(self):
|
|
|
|
# linux/mac
|
|
|
|
os.sep = '/'
|
|
|
|
def _join(path):
|
|
|
|
return '/'.join(path)
|
|
|
|
os.path.join = _join
|
|
|
|
|
|
|
|
self.assertEquals(convert_path('/home/to/my/stuff'),
|
|
|
|
'/home/to/my/stuff')
|
|
|
|
|
|
|
|
# win
|
|
|
|
os.sep = '\\'
|
|
|
|
def _join(*path):
|
|
|
|
return '\\'.join(path)
|
|
|
|
os.path.join = _join
|
|
|
|
|
|
|
|
self.assertRaises(ValueError, convert_path, '/home/to/my/stuff')
|
|
|
|
self.assertRaises(ValueError, convert_path, 'home/to/my/stuff/')
|
|
|
|
|
|
|
|
self.assertEquals(convert_path('home/to/my/stuff'),
|
|
|
|
'home\\to\\my\\stuff')
|
|
|
|
self.assertEquals(convert_path('.'),
|
|
|
|
os.curdir)
|
|
|
|
|
|
|
|
def test_change_root(self):
|
|
|
|
# linux/mac
|
|
|
|
os.name = 'posix'
|
|
|
|
def _isabs(path):
|
|
|
|
return path[0] == '/'
|
|
|
|
os.path.isabs = _isabs
|
2009-02-13 19:48:11 -04:00
|
|
|
def _join(*path):
|
|
|
|
return '/'.join(path)
|
|
|
|
os.path.join = _join
|
2009-02-13 18:26:15 -04:00
|
|
|
|
|
|
|
self.assertEquals(change_root('/root', '/old/its/here'),
|
|
|
|
'/root/old/its/here')
|
|
|
|
self.assertEquals(change_root('/root', 'its/here'),
|
|
|
|
'/root/its/here')
|
|
|
|
|
|
|
|
# windows
|
|
|
|
os.name = 'nt'
|
|
|
|
def _isabs(path):
|
|
|
|
return path.startswith('c:\\')
|
|
|
|
os.path.isabs = _isabs
|
|
|
|
def _splitdrive(path):
|
|
|
|
if path.startswith('c:'):
|
|
|
|
return ('', path.replace('c:', ''))
|
|
|
|
return ('', path)
|
|
|
|
os.path.splitdrive = _splitdrive
|
|
|
|
def _join(*path):
|
|
|
|
return '\\'.join(path)
|
|
|
|
os.path.join = _join
|
|
|
|
|
|
|
|
self.assertEquals(change_root('c:\\root', 'c:\\old\\its\\here'),
|
|
|
|
'c:\\root\\old\\its\\here')
|
|
|
|
self.assertEquals(change_root('c:\\root', 'its\\here'),
|
|
|
|
'c:\\root\\its\\here')
|
|
|
|
|
|
|
|
# BugsBunny os (it's a great os)
|
|
|
|
os.name = 'BugsBunny'
|
|
|
|
self.assertRaises(DistutilsPlatformError,
|
|
|
|
change_root, 'c:\\root', 'its\\here')
|
|
|
|
|
|
|
|
# XXX platforms to be covered: os2, mac
|
|
|
|
|
|
|
|
def test_check_environ(self):
|
|
|
|
util._environ_checked = 0
|
2009-10-18 08:34:51 -03:00
|
|
|
if 'HOME' in os.environ:
|
|
|
|
del os.environ['HOME']
|
2009-02-13 18:26:15 -04:00
|
|
|
|
|
|
|
# posix without HOME
|
|
|
|
if os.name == 'posix': # this test won't run on windows
|
2009-05-10 09:20:44 -03:00
|
|
|
check_environ()
|
|
|
|
import pwd
|
2009-10-18 08:34:51 -03:00
|
|
|
self.assertEquals(os.environ['HOME'], pwd.getpwuid(os.getuid())[5])
|
2009-02-13 18:26:15 -04:00
|
|
|
else:
|
|
|
|
check_environ()
|
|
|
|
|
2009-10-18 08:34:51 -03:00
|
|
|
self.assertEquals(os.environ['PLAT'], get_platform())
|
2009-02-13 18:26:15 -04:00
|
|
|
self.assertEquals(util._environ_checked, 1)
|
|
|
|
|
|
|
|
def test_split_quoted(self):
|
|
|
|
self.assertEquals(split_quoted('""one"" "two" \'three\' \\four'),
|
|
|
|
['one', 'two', 'three', 'four'])
|
|
|
|
|
|
|
|
def test_strtobool(self):
|
|
|
|
yes = ('y', 'Y', 'yes', 'True', 't', 'true', 'True', 'On', 'on', '1')
|
|
|
|
no = ('n', 'no', 'f', 'false', 'off', '0', 'Off', 'No', 'N')
|
|
|
|
|
|
|
|
for y in yes:
|
2009-06-30 20:06:06 -03:00
|
|
|
self.assertTrue(strtobool(y))
|
2009-02-13 18:26:15 -04:00
|
|
|
|
|
|
|
for n in no:
|
2009-06-30 20:06:06 -03:00
|
|
|
self.assertTrue(not strtobool(n))
|
2009-02-13 18:26:15 -04:00
|
|
|
|
|
|
|
def test_rfc822_escape(self):
|
|
|
|
header = 'I am a\npoor\nlonesome\nheader\n'
|
|
|
|
res = rfc822_escape(header)
|
|
|
|
wanted = ('I am a%(8s)spoor%(8s)slonesome%(8s)s'
|
|
|
|
'header%(8s)s') % {'8s': '\n'+8*' '}
|
|
|
|
self.assertEquals(res, wanted)
|
|
|
|
|
2009-07-16 13:18:19 -03:00
|
|
|
def test_find_exe_version(self):
|
|
|
|
# the ld version scheme under MAC OS is:
|
|
|
|
# ^@(#)PROGRAM:ld PROJECT:ld64-VERSION
|
|
|
|
#
|
|
|
|
# where VERSION is a 2-digit number for major
|
|
|
|
# revisions. For instance under Leopard, it's
|
|
|
|
# currently 77
|
|
|
|
#
|
|
|
|
# Dots are used when branching is done.
|
|
|
|
#
|
|
|
|
# The SnowLeopard ld64 is currently 95.2.12
|
|
|
|
|
|
|
|
for output, version in ((b'@(#)PROGRAM:ld PROJECT:ld64-77', '77'),
|
|
|
|
(b'@(#)PROGRAM:ld PROJECT:ld64-95.2.12',
|
|
|
|
'95.2.12')):
|
|
|
|
result = _MAC_OS_X_LD_VERSION.search(output)
|
|
|
|
self.assertEquals(result.group(1).decode(), version)
|
|
|
|
|
|
|
|
def _find_executable(self, name):
|
|
|
|
if name in self._exes:
|
|
|
|
return name
|
|
|
|
return None
|
|
|
|
|
|
|
|
def test_get_compiler_versions(self):
|
|
|
|
# get_versions calls distutils.spawn.find_executable on
|
|
|
|
# 'gcc', 'ld' and 'dllwrap'
|
|
|
|
self.assertEquals(get_compiler_versions(), (None, None, None))
|
|
|
|
|
|
|
|
# Let's fake we have 'gcc' and it returns '3.4.5'
|
|
|
|
self._exes['gcc'] = b'gcc (GCC) 3.4.5 (mingw special)\nFSF'
|
|
|
|
res = get_compiler_versions()
|
|
|
|
self.assertEquals(str(res[0]), '3.4.5')
|
|
|
|
|
|
|
|
# and let's see what happens when the version
|
|
|
|
# doesn't match the regular expression
|
|
|
|
# (\d+\.\d+(\.\d+)*)
|
|
|
|
self._exes['gcc'] = b'very strange output'
|
|
|
|
res = get_compiler_versions()
|
|
|
|
self.assertEquals(res[0], None)
|
|
|
|
|
|
|
|
# same thing for ld
|
|
|
|
if sys.platform != 'darwin':
|
|
|
|
self._exes['ld'] = b'GNU ld version 2.17.50 20060824'
|
|
|
|
res = get_compiler_versions()
|
|
|
|
self.assertEquals(str(res[1]), '2.17.50')
|
|
|
|
self._exes['ld'] = b'@(#)PROGRAM:ld PROJECT:ld64-77'
|
|
|
|
res = get_compiler_versions()
|
|
|
|
self.assertEquals(res[1], None)
|
|
|
|
else:
|
|
|
|
self._exes['ld'] = b'GNU ld version 2.17.50 20060824'
|
|
|
|
res = get_compiler_versions()
|
|
|
|
self.assertEquals(res[1], None)
|
|
|
|
self._exes['ld'] = b'@(#)PROGRAM:ld PROJECT:ld64-77'
|
|
|
|
res = get_compiler_versions()
|
|
|
|
self.assertEquals(str(res[1]), '77')
|
|
|
|
|
|
|
|
# and dllwrap
|
|
|
|
self._exes['dllwrap'] = b'GNU dllwrap 2.17.50 20060824\nFSF'
|
|
|
|
res = get_compiler_versions()
|
|
|
|
self.assertEquals(str(res[2]), '2.17.50')
|
|
|
|
self._exes['dllwrap'] = b'Cheese Wrap'
|
|
|
|
res = get_compiler_versions()
|
|
|
|
self.assertEquals(res[2], None)
|
|
|
|
|
2009-10-25 20:08:47 -03:00
|
|
|
def test_dont_write_bytecode(self):
|
|
|
|
# makes sure byte_compile raise a DistutilsError
|
|
|
|
# if sys.dont_write_bytecode is True
|
|
|
|
old_dont_write_bytecode = sys.dont_write_bytecode
|
|
|
|
sys.dont_write_bytecode = True
|
|
|
|
try:
|
|
|
|
self.assertRaises(DistutilsByteCompileError, byte_compile, [])
|
|
|
|
finally:
|
|
|
|
sys.dont_write_bytecode = old_dont_write_bytecode
|
|
|
|
|
2009-02-13 18:26:15 -04:00
|
|
|
def test_suite():
|
2009-05-10 09:20:44 -03:00
|
|
|
return unittest.makeSuite(UtilTestCase)
|
2009-02-13 18:26:15 -04:00
|
|
|
|
|
|
|
if __name__ == "__main__":
|
|
|
|
unittest.main(defaultTest="test_suite")
|