Commit 5b6ba91b authored by Georg Brandl's avatar Georg Brandl

merge with 3.3

parents 036968d7 590f1383
...@@ -343,6 +343,18 @@ Common commands: (see '--help-commands' for more) ...@@ -343,6 +343,18 @@ Common commands: (see '--help-commands' for more)
def parse_config_files(self, filenames=None): def parse_config_files(self, filenames=None):
from configparser import ConfigParser from configparser import ConfigParser
# Ignore install directory options if we have a venv
if sys.prefix != sys.base_prefix:
ignore_options = [
'install-base', 'install-platbase', 'install-lib',
'install-platlib', 'install-purelib', 'install-headers',
'install-scripts', 'install-data', 'prefix', 'exec-prefix',
'home', 'user', 'root']
else:
ignore_options = []
ignore_options = frozenset(ignore_options)
if filenames is None: if filenames is None:
filenames = self.find_config_files() filenames = self.find_config_files()
...@@ -359,7 +371,7 @@ Common commands: (see '--help-commands' for more) ...@@ -359,7 +371,7 @@ Common commands: (see '--help-commands' for more)
opt_dict = self.get_option_dict(section) opt_dict = self.get_option_dict(section)
for opt in options: for opt in options:
if opt != '__name__': if opt != '__name__' and opt not in ignore_options:
val = parser.get(section,opt) val = parser.get(section,opt)
opt = opt.replace('-', '_') opt = opt.replace('-', '_')
opt_dict[opt] = (filename, val) opt_dict[opt] = (filename, val)
......
...@@ -6,6 +6,8 @@ import unittest ...@@ -6,6 +6,8 @@ import unittest
import warnings import warnings
import textwrap import textwrap
from unittest import mock
from distutils.dist import Distribution, fix_help_options from distutils.dist import Distribution, fix_help_options
from distutils.cmd import Command from distutils.cmd import Command
...@@ -77,6 +79,64 @@ class DistributionTestCase(support.LoggingSilencer, ...@@ -77,6 +79,64 @@ class DistributionTestCase(support.LoggingSilencer,
self.assertIsInstance(cmd, test_dist) self.assertIsInstance(cmd, test_dist)
self.assertEqual(cmd.sample_option, "sometext") self.assertEqual(cmd.sample_option, "sometext")
def test_venv_install_options(self):
sys.argv.append("install")
self.addCleanup(os.unlink, TESTFN)
fakepath = '/somedir'
with open(TESTFN, "w") as f:
print(("[install]\n"
"install-base = {0}\n"
"install-platbase = {0}\n"
"install-lib = {0}\n"
"install-platlib = {0}\n"
"install-purelib = {0}\n"
"install-headers = {0}\n"
"install-scripts = {0}\n"
"install-data = {0}\n"
"prefix = {0}\n"
"exec-prefix = {0}\n"
"home = {0}\n"
"user = {0}\n"
"root = {0}").format(fakepath), file=f)
# Base case: Not in a Virtual Environment
with mock.patch.multiple(sys, prefix='/a', base_prefix='/a') as values:
d = self.create_distribution([TESTFN])
option_tuple = (TESTFN, fakepath)
result_dict = {
'install_base': option_tuple,
'install_platbase': option_tuple,
'install_lib': option_tuple,
'install_platlib': option_tuple,
'install_purelib': option_tuple,
'install_headers': option_tuple,
'install_scripts': option_tuple,
'install_data': option_tuple,
'prefix': option_tuple,
'exec_prefix': option_tuple,
'home': option_tuple,
'user': option_tuple,
'root': option_tuple,
}
self.assertEqual(
sorted(d.command_options.get('install').keys()),
sorted(result_dict.keys()))
for (key, value) in d.command_options.get('install').items():
self.assertEqual(value, result_dict[key])
# Test case: In a Virtual Environment
with mock.patch.multiple(sys, prefix='/a', base_prefix='/b') as values:
d = self.create_distribution([TESTFN])
for key in result_dict.keys():
self.assertNotIn(key, d.command_options.get('install', {}))
def test_command_packages_configfile(self): def test_command_packages_configfile(self):
sys.argv.append("build") sys.argv.append("build")
self.addCleanup(os.unlink, TESTFN) self.addCleanup(os.unlink, TESTFN)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment