mirror of https://github.com/django/django.git
Fixed #22820 -- Treated int and long types alike in lazy_number
Thanks kwist for the report and the initial patch.
This commit is contained in:
parent
3a297d7816
commit
5021421799
|
@ -101,7 +101,7 @@ pgettext_lazy = lazy(pgettext, six.text_type)
|
||||||
|
|
||||||
|
|
||||||
def lazy_number(func, resultclass, number=None, **kwargs):
|
def lazy_number(func, resultclass, number=None, **kwargs):
|
||||||
if isinstance(number, int):
|
if isinstance(number, six.integer_types):
|
||||||
kwargs['number'] = number
|
kwargs['number'] = number
|
||||||
proxy = lazy(func, resultclass)(**kwargs)
|
proxy = lazy(func, resultclass)(**kwargs)
|
||||||
else:
|
else:
|
||||||
|
|
|
@ -193,6 +193,17 @@ class TranslationTests(TestCase):
|
||||||
with six.assertRaisesRegex(self, KeyError, 'Your dictionary lacks key.*'):
|
with six.assertRaisesRegex(self, KeyError, 'Your dictionary lacks key.*'):
|
||||||
complex_context_deferred % {'name': 'Jim'}
|
complex_context_deferred % {'name': 'Jim'}
|
||||||
|
|
||||||
|
@skipUnless(six.PY2, "PY3 doesn't distinct int and long types")
|
||||||
|
def test_ungettext_lazy_long(self):
|
||||||
|
"""
|
||||||
|
Regression test for #22820: int and long should be treated alike in ungettext_lazy.
|
||||||
|
"""
|
||||||
|
result = ungettext_lazy('%(name)s has %(num)d good result', '%(name)s has %(num)d good results', 4)
|
||||||
|
self.assertEqual(result % {'name': 'Joe', 'num': 4}, "Joe has 4 good results")
|
||||||
|
# Now with a long
|
||||||
|
result = ungettext_lazy('%(name)s has %(num)d good result', '%(name)s has %(num)d good results', long(4))
|
||||||
|
self.assertEqual(result % {'name': 'Joe', 'num': 4}, "Joe has 4 good results")
|
||||||
|
|
||||||
@override_settings(LOCALE_PATHS=extended_locale_paths)
|
@override_settings(LOCALE_PATHS=extended_locale_paths)
|
||||||
def test_pgettext(self):
|
def test_pgettext(self):
|
||||||
trans_real._active = local()
|
trans_real._active = local()
|
||||||
|
|
Loading…
Reference in New Issue