Cleaned up i18n regression tests
This commit is contained in:
parent
58cc3e8484
commit
e70170c2cb
|
@ -23,7 +23,7 @@ from django.utils import six
|
||||||
from django.utils.six import PY3
|
from django.utils.six import PY3
|
||||||
from django.utils.translation import (ugettext, ugettext_lazy, activate,
|
from django.utils.translation import (ugettext, ugettext_lazy, activate,
|
||||||
deactivate, gettext_lazy, pgettext, npgettext, to_locale,
|
deactivate, gettext_lazy, pgettext, npgettext, to_locale,
|
||||||
get_language_info, get_language, get_language_from_request)
|
get_language_info, get_language, get_language_from_request, trans_real)
|
||||||
|
|
||||||
|
|
||||||
from .commands.tests import can_run_extraction_tests, can_run_compilation_tests
|
from .commands.tests import can_run_extraction_tests, can_run_compilation_tests
|
||||||
|
@ -45,6 +45,9 @@ from .patterns.tests import (URLRedirectWithoutTrailingSlashTests,
|
||||||
|
|
||||||
|
|
||||||
here = os.path.dirname(os.path.abspath(__file__))
|
here = os.path.dirname(os.path.abspath(__file__))
|
||||||
|
extended_locale_paths = settings.LOCALE_PATHS + (
|
||||||
|
os.path.join(here, 'other', 'locale'),
|
||||||
|
)
|
||||||
|
|
||||||
class TranslationTests(TestCase):
|
class TranslationTests(TestCase):
|
||||||
|
|
||||||
|
@ -86,13 +89,8 @@ class TranslationTests(TestCase):
|
||||||
s2 = pickle.loads(pickle.dumps(s1))
|
s2 = pickle.loads(pickle.dumps(s1))
|
||||||
self.assertEqual(six.text_type(s2), "test")
|
self.assertEqual(six.text_type(s2), "test")
|
||||||
|
|
||||||
|
@override_settings(LOCALE_PATHS=extended_locale_paths)
|
||||||
def test_pgettext(self):
|
def test_pgettext(self):
|
||||||
# Reset translation catalog to include other/locale/de
|
|
||||||
extended_locale_paths = settings.LOCALE_PATHS + (
|
|
||||||
os.path.join(here, 'other', 'locale'),
|
|
||||||
)
|
|
||||||
with self.settings(LOCALE_PATHS=extended_locale_paths):
|
|
||||||
from django.utils.translation import trans_real
|
|
||||||
trans_real._active = local()
|
trans_real._active = local()
|
||||||
trans_real._translations = {}
|
trans_real._translations = {}
|
||||||
with translation.override('de'):
|
with translation.override('de'):
|
||||||
|
@ -101,18 +99,13 @@ class TranslationTests(TestCase):
|
||||||
self.assertEqual(pgettext("verb", "May"), "Kann")
|
self.assertEqual(pgettext("verb", "May"), "Kann")
|
||||||
self.assertEqual(npgettext("search", "%d result", "%d results", 4) % 4, "4 Resultate")
|
self.assertEqual(npgettext("search", "%d result", "%d results", 4) % 4, "4 Resultate")
|
||||||
|
|
||||||
|
@override_settings(LOCALE_PATHS=extended_locale_paths)
|
||||||
def test_template_tags_pgettext(self):
|
def test_template_tags_pgettext(self):
|
||||||
"""
|
"""
|
||||||
Ensure that message contexts are taken into account the {% trans %} and
|
Ensure that message contexts are taken into account the {% trans %} and
|
||||||
{% blocktrans %} template tags.
|
{% blocktrans %} template tags.
|
||||||
Refs #14806.
|
Refs #14806.
|
||||||
"""
|
"""
|
||||||
# Reset translation catalog to include other/locale/de
|
|
||||||
extended_locale_paths = settings.LOCALE_PATHS + (
|
|
||||||
os.path.join(here, 'other', 'locale'),
|
|
||||||
)
|
|
||||||
with self.settings(LOCALE_PATHS=extended_locale_paths):
|
|
||||||
from django.utils.translation import trans_real
|
|
||||||
trans_real._active = local()
|
trans_real._active = local()
|
||||||
trans_real._translations = {}
|
trans_real._translations = {}
|
||||||
with translation.override('de'):
|
with translation.override('de'):
|
||||||
|
@ -247,8 +240,7 @@ class TranslationTests(TestCase):
|
||||||
Translations on files with mac or dos end of lines will be converted
|
Translations on files with mac or dos end of lines will be converted
|
||||||
to unix eof in .po catalogs, and they have to match when retrieved
|
to unix eof in .po catalogs, and they have to match when retrieved
|
||||||
"""
|
"""
|
||||||
from django.utils.translation.trans_real import translation as Trans
|
ca_translation = trans_real.translation('ca')
|
||||||
ca_translation = Trans('ca')
|
|
||||||
ca_translation._catalog['Mac\nEOF\n'] = 'Catalan Mac\nEOF\n'
|
ca_translation._catalog['Mac\nEOF\n'] = 'Catalan Mac\nEOF\n'
|
||||||
ca_translation._catalog['Win\nEOF\n'] = 'Catalan Win\nEOF\n'
|
ca_translation._catalog['Win\nEOF\n'] = 'Catalan Win\nEOF\n'
|
||||||
with translation.override('ca', deactivate=True):
|
with translation.override('ca', deactivate=True):
|
||||||
|
@ -267,9 +259,8 @@ class TranslationTests(TestCase):
|
||||||
"""
|
"""
|
||||||
Test the to_language function
|
Test the to_language function
|
||||||
"""
|
"""
|
||||||
from django.utils.translation.trans_real import to_language
|
self.assertEqual(trans_real.to_language('en_US'), 'en-us')
|
||||||
self.assertEqual(to_language('en_US'), 'en-us')
|
self.assertEqual(trans_real.to_language('sr_Lat'), 'sr-lat')
|
||||||
self.assertEqual(to_language('sr_Lat'), 'sr-lat')
|
|
||||||
|
|
||||||
@override_settings(LOCALE_PATHS=(os.path.join(here, 'other', 'locale'),))
|
@override_settings(LOCALE_PATHS=(os.path.join(here, 'other', 'locale'),))
|
||||||
def test_bad_placeholder_1(self):
|
def test_bad_placeholder_1(self):
|
||||||
|
@ -710,8 +701,7 @@ class MiscTests(TestCase):
|
||||||
values according to the spec (and that we extract all the pieces in
|
values according to the spec (and that we extract all the pieces in
|
||||||
the right order).
|
the right order).
|
||||||
"""
|
"""
|
||||||
from django.utils.translation.trans_real import parse_accept_lang_header
|
p = trans_real.parse_accept_lang_header
|
||||||
p = parse_accept_lang_header
|
|
||||||
# Good headers.
|
# Good headers.
|
||||||
self.assertEqual([('de', 1.0)], p('de'))
|
self.assertEqual([('de', 1.0)], p('de'))
|
||||||
self.assertEqual([('en-AU', 1.0)], p('en-AU'))
|
self.assertEqual([('en-AU', 1.0)], p('en-AU'))
|
||||||
|
@ -811,7 +801,7 @@ class MiscTests(TestCase):
|
||||||
self.assertEqual(g(r), 'zh-cn')
|
self.assertEqual(g(r), 'zh-cn')
|
||||||
|
|
||||||
def test_get_language_from_path_real(self):
|
def test_get_language_from_path_real(self):
|
||||||
from django.utils.translation.trans_real import get_language_from_path as g
|
g = trans_real.get_language_from_path
|
||||||
self.assertEqual(g('/pl/'), 'pl')
|
self.assertEqual(g('/pl/'), 'pl')
|
||||||
self.assertEqual(g('/pl'), 'pl')
|
self.assertEqual(g('/pl'), 'pl')
|
||||||
self.assertEqual(g('/xyz/'), None)
|
self.assertEqual(g('/xyz/'), None)
|
||||||
|
@ -822,11 +812,8 @@ class MiscTests(TestCase):
|
||||||
self.assertEqual(g('/pl'), None)
|
self.assertEqual(g('/pl'), None)
|
||||||
self.assertEqual(g('/xyz/'), None)
|
self.assertEqual(g('/xyz/'), None)
|
||||||
|
|
||||||
|
@override_settings(LOCALE_PATHS=extended_locale_paths)
|
||||||
def test_percent_in_translatable_block(self):
|
def test_percent_in_translatable_block(self):
|
||||||
extended_locale_paths = settings.LOCALE_PATHS + (
|
|
||||||
os.path.join(here, 'other', 'locale'),
|
|
||||||
)
|
|
||||||
with self.settings(LOCALE_PATHS=extended_locale_paths):
|
|
||||||
t_sing = Template("{% load i18n %}{% blocktrans %}The result was {{ percent }}%{% endblocktrans %}")
|
t_sing = Template("{% load i18n %}{% blocktrans %}The result was {{ percent }}%{% endblocktrans %}")
|
||||||
t_plur = Template("{% load i18n %}{% blocktrans count num as number %}{{ percent }}% represents {{ num }} object{% plural %}{{ percent }}% represents {{ num }} objects{% endblocktrans %}")
|
t_plur = Template("{% load i18n %}{% blocktrans count num as number %}{{ percent }}% represents {{ num }} object{% plural %}{{ percent }}% represents {{ num }} objects{% endblocktrans %}")
|
||||||
with translation.override('de'):
|
with translation.override('de'):
|
||||||
|
@ -838,7 +825,6 @@ class MiscTests(TestCase):
|
||||||
class ResolutionOrderI18NTests(TestCase):
|
class ResolutionOrderI18NTests(TestCase):
|
||||||
|
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
from django.utils.translation import trans_real
|
|
||||||
# Okay, this is brutal, but we have no other choice to fully reset
|
# Okay, this is brutal, but we have no other choice to fully reset
|
||||||
# the translation framework
|
# the translation framework
|
||||||
trans_real._active = local()
|
trans_real._active = local()
|
||||||
|
@ -867,17 +853,9 @@ class AppResolutionOrderI18NTests(ResolutionOrderI18NTests):
|
||||||
def test_app_translation(self):
|
def test_app_translation(self):
|
||||||
self.assertUgettext('Date/time', 'APP')
|
self.assertUgettext('Date/time', 'APP')
|
||||||
|
|
||||||
|
@override_settings(LOCALE_PATHS=extended_locale_paths)
|
||||||
class LocalePathsResolutionOrderI18NTests(ResolutionOrderI18NTests):
|
class LocalePathsResolutionOrderI18NTests(ResolutionOrderI18NTests):
|
||||||
|
|
||||||
def setUp(self):
|
|
||||||
self.old_locale_paths = settings.LOCALE_PATHS
|
|
||||||
settings.LOCALE_PATHS += (os.path.join(here, 'other', 'locale'),)
|
|
||||||
super(LocalePathsResolutionOrderI18NTests, self).setUp()
|
|
||||||
|
|
||||||
def tearDown(self):
|
|
||||||
settings.LOCALE_PATHS = self.old_locale_paths
|
|
||||||
super(LocalePathsResolutionOrderI18NTests, self).tearDown()
|
|
||||||
|
|
||||||
def test_locale_paths_translation(self):
|
def test_locale_paths_translation(self):
|
||||||
self.assertUgettext('Time', 'LOCALE_PATHS')
|
self.assertUgettext('Time', 'LOCALE_PATHS')
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue