summaryrefslogtreecommitdiff
path: root/tests/test_install.py
diff options
context:
space:
mode:
authorTarek Ziadé <ziade.tarek@gmail.com>2009-02-27 12:58:56 +0000
committerTarek Ziadé <ziade.tarek@gmail.com>2009-02-27 12:58:56 +0000
commit42e1c973f8cb4baba16a761b1aa6263ee5f47278 (patch)
tree52c3e540b32f3ed6e660bf71ee306fe2fecee2b5 /tests/test_install.py
parent73ac2e14e27f78bd054a1192099437777bc87c2d (diff)
downloadpython-setuptools-git-42e1c973f8cb4baba16a761b1aa6263ee5f47278.tar.gz
Merged revisions 70017 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk ........ r70017 | tarek.ziade | 2009-02-27 13:53:34 +0100 (Fri, 27 Feb 2009) | 1 line Issue #5052: make Distutils compatible with 2.3 again. ........
Diffstat (limited to 'tests/test_install.py')
-rw-r--r--tests/test_install.py64
1 files changed, 64 insertions, 0 deletions
diff --git a/tests/test_install.py b/tests/test_install.py
index c834b91b..9ceccf68 100644
--- a/tests/test_install.py
+++ b/tests/test_install.py
@@ -1,9 +1,14 @@
"""Tests for distutils.command.install."""
import os
+import os.path
+import sys
import unittest
+import site
from distutils.command.install import install
+from distutils.command import install as install_module
+from distutils.command.install import INSTALL_SCHEMES
from distutils.core import Distribution
from distutils.tests import support
@@ -47,6 +52,65 @@ class InstallTestCase(support.TempdirManager, unittest.TestCase):
check_path(cmd.install_scripts, os.path.join(destination, "bin"))
check_path(cmd.install_data, destination)
+ def test_user_site(self):
+ # site.USER_SITE was introduced in 2.6
+ if sys.version < '2.6':
+ return
+
+ # preparing the environement for the test
+ self.old_user_base = site.USER_BASE
+ self.old_user_site = site.USER_SITE
+ self.tmpdir = self.mkdtemp()
+ self.user_base = os.path.join(self.tmpdir, 'B')
+ self.user_site = os.path.join(self.tmpdir, 'S')
+ site.USER_BASE = self.user_base
+ site.USER_SITE = self.user_site
+ install_module.USER_BASE = self.user_base
+ install_module.USER_SITE = self.user_site
+
+ def _expanduser(path):
+ return self.tmpdir
+ self.old_expand = os.path.expanduser
+ os.path.expanduser = _expanduser
+
+ try:
+ # this is the actual test
+ self._test_user_site()
+ finally:
+ site.USER_BASE = self.old_user_base
+ site.USER_SITE = self.old_user_site
+ install_module.USER_BASE = self.old_user_base
+ install_module.USER_SITE = self.old_user_site
+ os.path.expanduser = self.old_expand
+
+ def _test_user_site(self):
+ for key in ('nt_user', 'unix_user', 'os2_home'):
+ self.assert_(key in INSTALL_SCHEMES)
+
+ dist = Distribution({'name': 'xx'})
+ cmd = install(dist)
+
+ # making sure the user option is there
+ options = [name for name, short, lable in
+ cmd.user_options]
+ self.assert_('user' in options)
+
+ # setting a value
+ cmd.user = 1
+
+ # user base and site shouldn't be created yet
+ self.assert_(not os.path.exists(self.user_base))
+ self.assert_(not os.path.exists(self.user_site))
+
+ # let's run finalize
+ cmd.ensure_finalized()
+
+ # now they should
+ self.assert_(os.path.exists(self.user_base))
+ self.assert_(os.path.exists(self.user_site))
+
+ self.assert_('userbase' in cmd.config_vars)
+ self.assert_('usersite' in cmd.config_vars)
def test_suite():
return unittest.makeSuite(InstallTestCase)