From: Tarek Ziadé Date: Mon, 29 Dec 2008 22:23:53 +0000 (+0000) Subject: fixed #4646 : distutils was choking on empty options arg in the setup function. X-Git-Tag: v2.7a1~2462 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=c13acb18bc2db9d8824ba94b86d8e4c8909d6b6c;p=python fixed #4646 : distutils was choking on empty options arg in the setup function. --- diff --git a/Lib/distutils/dist.py b/Lib/distutils/dist.py index 9ad94fbeb8..c15ca9770d 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 6f5fe9c757..bf59c41844 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): diff --git a/Misc/NEWS b/Misc/NEWS index 1fd8d33316..539a41a08f 100644 --- a/Misc/NEWS +++ b/Misc/NEWS @@ -97,6 +97,9 @@ Core and Builtins Library ------- +- Issue #4646: distutils was choking on empty options arg in the setup + function. Original patch by Thomas Heller. + - Issue #3767: Convert Tk object to string in tkColorChooser. - Issue #3248: Allow placing ScrolledText in a PanedWindow.