summaryrefslogtreecommitdiffstats
path: root/Lib
diff options
context:
space:
mode:
authorTarek Ziadé <ziade.tarek@gmail.com>2008-12-29 22:23:53 (GMT)
committerTarek Ziadé <ziade.tarek@gmail.com>2008-12-29 22:23:53 (GMT)
commitc13acb18bc2db9d8824ba94b86d8e4c8909d6b6c (patch)
tree985cbee160d36e67a6d72b564078b6195cfc5ead /Lib
parentfc5a8543ce4f11c9ef39ce59ca433e473df74179 (diff)
downloadcpython-c13acb18bc2db9d8824ba94b86d8e4c8909d6b6c.zip
cpython-c13acb18bc2db9d8824ba94b86d8e4c8909d6b6c.tar.gz
cpython-c13acb18bc2db9d8824ba94b86d8e4c8909d6b6c.tar.bz2
fixed #4646 : distutils was choking on empty options arg in the setup function.
Diffstat (limited to 'Lib')
-rw-r--r--Lib/distutils/dist.py2
-rw-r--r--Lib/distutils/tests/test_dist.py24
2 files changed, 25 insertions, 1 deletions
diff --git a/Lib/distutils/dist.py b/Lib/distutils/dist.py
index 9ad94fb..c15ca97 100644
--- a/Lib/distutils/dist.py
+++ b/Lib/distutils/dist.py
@@ -235,7 +235,7 @@ Common commands: (see '--help-commands' for more)
# command options will override any supplied redundantly
# through the general options dictionary.
options = attrs.get('options')
- if options:
+ if options is not None:
del attrs['options']
for (command, cmd_options) in options.items():
opt_dict = self.get_option_dict(command)
diff --git a/Lib/distutils/tests/test_dist.py b/Lib/distutils/tests/test_dist.py
index 6f5fe9c..bf59c41 100644
--- a/Lib/distutils/tests/test_dist.py
+++ b/Lib/distutils/tests/test_dist.py
@@ -8,6 +8,7 @@ import os
import StringIO
import sys
import unittest
+import warnings
from test.test_support import TESTFN
@@ -131,6 +132,29 @@ class DistributionTestCase(unittest.TestCase):
if os.path.exists(my_file):
os.remove(my_file)
+ def test_empty_options(self):
+ # an empty options dictionary should not stay in the
+ # list of attributes
+ klass = distutils.dist.Distribution
+
+ # catching warnings
+ warns = []
+ def _warn(msg):
+ warns.append(msg)
+
+ old_warn = warnings.warn
+ warnings.warn = _warn
+ try:
+ dist = klass(attrs={'author': 'xxx',
+ 'name': 'xxx',
+ 'version': 'xxx',
+ 'url': 'xxxx',
+ 'options': {}})
+ finally:
+ warnings.warn = old_warn
+
+ self.assertEquals(len(warns), 0)
+
class MetadataTestCase(unittest.TestCase):
def test_simple_metadata(self):