1
0
mirror of https://github.com/scrapy/scrapy.git synced 2025-02-25 02:44:22 +00:00

Fix backwards-compatibility for users who explicitly set _BASE settings

This commit is contained in:
Jakob de Maeyer 2015-10-27 13:56:14 +01:00
parent f249b309ab
commit 03f1720afb
2 changed files with 21 additions and 10 deletions

View File

@ -116,9 +116,9 @@ class BaseSettings(MutableMapping):
def getbool(self, name, default=False):
"""
Get a setting value as a boolean.
``1``, ``'1'``, and ``True`` return ``True``, while ``0``, ``'0'``,
``False`` and ``None`` return ``False``.
``False`` and ``None`` return ``False``.
For example, settings populated through environment variables set to
``'0'`` will return ``False`` when using this method.
@ -203,11 +203,17 @@ class BaseSettings(MutableMapping):
if basename in self:
warnings.warn('_BASE settings are deprecated.',
category=ScrapyDeprecationWarning)
compsett = BaseSettings(self[name + "_BASE"], priority='default')
compsett.update(self[name])
# When users defined a _BASE setting, they explicitly don't want to
# use any of Scrapy's defaults. Therefore, we only use these entries
# from self[name] (where the defaults now live) that have a priority
# higher than 'default'
compsett = BaseSettings(self[basename], priority='default')
for k in self[name]:
prio = self[name].getpriority(k)
if prio > get_settings_priority('default'):
compsett.set(k, self[name][k], prio)
return compsett
else:
return self[name]
return self[name]
def getpriority(self, name):
"""

View File

@ -252,12 +252,17 @@ class BaseSettingsTest(unittest.TestCase):
def test_getcomposite(self):
s = BaseSettings({'TEST_BASE': {1: 1, 2: 2},
'TEST': BaseSettings({1: 10}),
'HASNOBASE': BaseSettings({1: 1})})
'TEST': BaseSettings({1: 10, 3: 30}, 'default'),
'HASNOBASE': BaseSettings({1: 1}, 'default')})
s['TEST'].set(4, 4, priority='project')
# When users specify a _BASE setting they explicitly don't want to use
# Scrapy's defaults, so we don't want to see anything that has a
# 'default' priority from TEST
cs = s._getcomposite('TEST')
self.assertEqual(len(cs), 2)
self.assertEqual(cs[1], 10)
self.assertEqual(len(cs), 3)
self.assertEqual(cs[1], 1)
self.assertEqual(cs[2], 2)
self.assertEqual(cs[4], 4)
cs = s._getcomposite('HASNOBASE')
self.assertEqual(len(cs), 1)
self.assertEqual(cs[1], 1)