summaryrefslogtreecommitdiff
path: root/tests/template_tests/syntax_tests/i18n/test_translate.py
diff options
context:
space:
mode:
authordjango-bot <ops@djangoproject.com>2022-02-03 20:24:19 +0100
committerMariusz Felisiak <felisiak.mariusz@gmail.com>2022-02-07 20:37:05 +0100
commit9c19aff7c7561e3a82978a272ecdaad40dda5c00 (patch)
treef0506b668a013d0063e5fba3dbf4863b466713ba /tests/template_tests/syntax_tests/i18n/test_translate.py
parentf68fa8b45dfac545cfc4111d4e52804c86db68d3 (diff)
Refs #33476 -- Reformatted code with Black.
Diffstat (limited to 'tests/template_tests/syntax_tests/i18n/test_translate.py')
-rw-r--r--tests/template_tests/syntax_tests/i18n/test_translate.py268
1 files changed, 152 insertions, 116 deletions
diff --git a/tests/template_tests/syntax_tests/i18n/test_translate.py b/tests/template_tests/syntax_tests/i18n/test_translate.py
index 55fdb92f7a..932b47a373 100644
--- a/tests/template_tests/syntax_tests/i18n/test_translate.py
+++ b/tests/template_tests/syntax_tests/i18n/test_translate.py
@@ -16,14 +16,16 @@ from .base import MultipleLocaleActivationTestCase, extended_locale_paths
def setup(templates, *args, **kwargs):
translate_setup = base_setup(templates, *args, **kwargs)
- trans_setup = base_setup({
- name: template.replace('{% translate ', '{% trans ')
- for name, template in templates.items()
- })
+ trans_setup = base_setup(
+ {
+ name: template.replace("{% translate ", "{% trans ")
+ for name, template in templates.items()
+ }
+ )
tags = {
- 'trans': trans_setup,
- 'translate': translate_setup,
+ "trans": trans_setup,
+ "translate": translate_setup,
}
def decorator(func):
@@ -31,143 +33,162 @@ def setup(templates, *args, **kwargs):
def inner(self, *args):
signature = inspect.signature(func)
for tag_name, setup_func in tags.items():
- if 'tag_name' in signature.parameters:
+ if "tag_name" in signature.parameters:
setup_func(partial(func, tag_name=tag_name))(self)
else:
setup_func(func)(self)
+
return inner
+
return decorator
class I18nTransTagTests(SimpleTestCase):
- libraries = {'i18n': 'django.templatetags.i18n'}
+ libraries = {"i18n": "django.templatetags.i18n"}
- @setup({'i18n01': '{% load i18n %}{% translate \'xxxyyyxxx\' %}'})
+ @setup({"i18n01": "{% load i18n %}{% translate 'xxxyyyxxx' %}"})
def test_i18n01(self):
"""simple translation of a string delimited by '."""
- output = self.engine.render_to_string('i18n01')
- self.assertEqual(output, 'xxxyyyxxx')
+ output = self.engine.render_to_string("i18n01")
+ self.assertEqual(output, "xxxyyyxxx")
- @setup({'i18n02': '{% load i18n %}{% translate "xxxyyyxxx" %}'})
+ @setup({"i18n02": '{% load i18n %}{% translate "xxxyyyxxx" %}'})
def test_i18n02(self):
"""simple translation of a string delimited by "."""
- output = self.engine.render_to_string('i18n02')
- self.assertEqual(output, 'xxxyyyxxx')
+ output = self.engine.render_to_string("i18n02")
+ self.assertEqual(output, "xxxyyyxxx")
- @setup({'i18n06': '{% load i18n %}{% translate "Page not found" %}'})
+ @setup({"i18n06": '{% load i18n %}{% translate "Page not found" %}'})
def test_i18n06(self):
"""simple translation of a string to German"""
- with translation.override('de'):
- output = self.engine.render_to_string('i18n06')
- self.assertEqual(output, 'Seite nicht gefunden')
+ with translation.override("de"):
+ output = self.engine.render_to_string("i18n06")
+ self.assertEqual(output, "Seite nicht gefunden")
- @setup({'i18n09': '{% load i18n %}{% translate "Page not found" noop %}'})
+ @setup({"i18n09": '{% load i18n %}{% translate "Page not found" noop %}'})
def test_i18n09(self):
"""simple non-translation (only marking) of a string to German"""
- with translation.override('de'):
- output = self.engine.render_to_string('i18n09')
- self.assertEqual(output, 'Page not found')
+ with translation.override("de"):
+ output = self.engine.render_to_string("i18n09")
+ self.assertEqual(output, "Page not found")
- @setup({'i18n20': '{% load i18n %}{% translate andrew %}'})
+ @setup({"i18n20": "{% load i18n %}{% translate andrew %}"})
def test_i18n20(self):
- output = self.engine.render_to_string('i18n20', {'andrew': 'a & b'})
- self.assertEqual(output, 'a &amp; b')
+ output = self.engine.render_to_string("i18n20", {"andrew": "a & b"})
+ self.assertEqual(output, "a &amp; b")
- @setup({'i18n22': '{% load i18n %}{% translate andrew %}'})
+ @setup({"i18n22": "{% load i18n %}{% translate andrew %}"})
def test_i18n22(self):
- output = self.engine.render_to_string('i18n22', {'andrew': mark_safe('a & b')})
- self.assertEqual(output, 'a & b')
+ output = self.engine.render_to_string("i18n22", {"andrew": mark_safe("a & b")})
+ self.assertEqual(output, "a & b")
- @setup({'i18n23': '{% load i18n %}{% translate "Page not found"|capfirst|slice:"6:" %}'})
+ @setup(
+ {
+ "i18n23": '{% load i18n %}{% translate "Page not found"|capfirst|slice:"6:" %}'
+ }
+ )
def test_i18n23(self):
"""Using filters with the {% translate %} tag (#5972)."""
- with translation.override('de'):
- output = self.engine.render_to_string('i18n23')
- self.assertEqual(output, 'nicht gefunden')
+ with translation.override("de"):
+ output = self.engine.render_to_string("i18n23")
+ self.assertEqual(output, "nicht gefunden")
- @setup({'i18n24': '{% load i18n %}{% translate \'Page not found\'|upper %}'})
+ @setup({"i18n24": "{% load i18n %}{% translate 'Page not found'|upper %}"})
def test_i18n24(self):
- with translation.override('de'):
- output = self.engine.render_to_string('i18n24')
- self.assertEqual(output, 'SEITE NICHT GEFUNDEN')
+ with translation.override("de"):
+ output = self.engine.render_to_string("i18n24")
+ self.assertEqual(output, "SEITE NICHT GEFUNDEN")
- @setup({'i18n25': '{% load i18n %}{% translate somevar|upper %}'})
+ @setup({"i18n25": "{% load i18n %}{% translate somevar|upper %}"})
def test_i18n25(self):
- with translation.override('de'):
- output = self.engine.render_to_string('i18n25', {'somevar': 'Page not found'})
- self.assertEqual(output, 'SEITE NICHT GEFUNDEN')
+ with translation.override("de"):
+ output = self.engine.render_to_string(
+ "i18n25", {"somevar": "Page not found"}
+ )
+ self.assertEqual(output, "SEITE NICHT GEFUNDEN")
# trans tag with as var
- @setup({'i18n35': '{% load i18n %}{% translate "Page not found" as page_not_found %}{{ page_not_found }}'})
+ @setup(
+ {
+ "i18n35": '{% load i18n %}{% translate "Page not found" as page_not_found %}{{ page_not_found }}'
+ }
+ )
def test_i18n35(self):
- with translation.override('de'):
- output = self.engine.render_to_string('i18n35')
- self.assertEqual(output, 'Seite nicht gefunden')
+ with translation.override("de"):
+ output = self.engine.render_to_string("i18n35")
+ self.assertEqual(output, "Seite nicht gefunden")
- @setup({'i18n36': '{% load i18n %}'
- '{% translate "Page not found" noop as page_not_found %}{{ page_not_found }}'})
+ @setup(
+ {
+ "i18n36": "{% load i18n %}"
+ '{% translate "Page not found" noop as page_not_found %}{{ page_not_found }}'
+ }
+ )
def test_i18n36(self):
- with translation.override('de'):
- output = self.engine.render_to_string('i18n36')
- self.assertEqual(output, 'Page not found')
+ with translation.override("de"):
+ output = self.engine.render_to_string("i18n36")
+ self.assertEqual(output, "Page not found")
- @setup({'template': '{% load i18n %}{% translate %}A}'})
+ @setup({"template": "{% load i18n %}{% translate %}A}"})
def test_syntax_error_no_arguments(self, tag_name):
msg = "'{}' takes at least one argument".format(tag_name)
with self.assertRaisesMessage(TemplateSyntaxError, msg):
- self.engine.render_to_string('template')
+ self.engine.render_to_string("template")
- @setup({'template': '{% load i18n %}{% translate "Yes" badoption %}'})
+ @setup({"template": '{% load i18n %}{% translate "Yes" badoption %}'})
def test_syntax_error_bad_option(self, tag_name):
msg = "Unknown argument for '{}' tag: 'badoption'".format(tag_name)
with self.assertRaisesMessage(TemplateSyntaxError, msg):
- self.engine.render_to_string('template')
+ self.engine.render_to_string("template")
- @setup({'template': '{% load i18n %}{% translate "Yes" as %}'})
+ @setup({"template": '{% load i18n %}{% translate "Yes" as %}'})
def test_syntax_error_missing_assignment(self, tag_name):
msg = "No argument provided to the '{}' tag for the as option.".format(tag_name)
with self.assertRaisesMessage(TemplateSyntaxError, msg):
- self.engine.render_to_string('template')
+ self.engine.render_to_string("template")
- @setup({'template': '{% load i18n %}{% translate "Yes" as var context %}'})
+ @setup({"template": '{% load i18n %}{% translate "Yes" as var context %}'})
def test_syntax_error_missing_context(self, tag_name):
- msg = "No argument provided to the '{}' tag for the context option.".format(tag_name)
+ msg = "No argument provided to the '{}' tag for the context option.".format(
+ tag_name
+ )
with self.assertRaisesMessage(TemplateSyntaxError, msg):
- self.engine.render_to_string('template')
+ self.engine.render_to_string("template")
- @setup({'template': '{% load i18n %}{% translate "Yes" context as var %}'})
+ @setup({"template": '{% load i18n %}{% translate "Yes" context as var %}'})
def test_syntax_error_context_as(self, tag_name):
- msg = "Invalid argument 'as' provided to the '{}' tag for the context option".format(tag_name)
+ msg = "Invalid argument 'as' provided to the '{}' tag for the context option".format(
+ tag_name
+ )
with self.assertRaisesMessage(TemplateSyntaxError, msg):
- self.engine.render_to_string('template')
+ self.engine.render_to_string("template")
- @setup({'template': '{% load i18n %}{% translate "Yes" context noop %}'})
+ @setup({"template": '{% load i18n %}{% translate "Yes" context noop %}'})
def test_syntax_error_context_noop(self, tag_name):
- msg = "Invalid argument 'noop' provided to the '{}' tag for the context option".format(tag_name)
+ msg = "Invalid argument 'noop' provided to the '{}' tag for the context option".format(
+ tag_name
+ )
with self.assertRaisesMessage(TemplateSyntaxError, msg):
- self.engine.render_to_string('template')
+ self.engine.render_to_string("template")
- @setup({'template': '{% load i18n %}{% translate "Yes" noop noop %}'})
+ @setup({"template": '{% load i18n %}{% translate "Yes" noop noop %}'})
def test_syntax_error_duplicate_option(self):
msg = "The 'noop' option was specified more than once."
with self.assertRaisesMessage(TemplateSyntaxError, msg):
- self.engine.render_to_string('template')
+ self.engine.render_to_string("template")
- @setup({'template': '{% load i18n %}{% translate "%s" %}'})
+ @setup({"template": '{% load i18n %}{% translate "%s" %}'})
def test_trans_tag_using_a_string_that_looks_like_str_fmt(self):
- output = self.engine.render_to_string('template')
- self.assertEqual(output, '%s')
+ output = self.engine.render_to_string("template")
+ self.assertEqual(output, "%s")
class TranslationTransTagTests(SimpleTestCase):
- tag_name = 'trans'
+ tag_name = "trans"
def get_template(self, template_string):
return Template(
- template_string.replace(
- '{{% translate ',
- '{{% {}'.format(self.tag_name)
- )
+ template_string.replace("{{% translate ", "{{% {}".format(self.tag_name))
)
@override_settings(LOCALE_PATHS=extended_locale_paths)
@@ -175,58 +196,71 @@ class TranslationTransTagTests(SimpleTestCase):
"""{% translate %} takes message contexts into account (#14806)."""
trans_real._active = Local()
trans_real._translations = {}
- with translation.override('de'):
+ with translation.override("de"):
# Nonexistent context...
- t = self.get_template('{% load i18n %}{% translate "May" context "nonexistent" %}')
+ t = self.get_template(
+ '{% load i18n %}{% translate "May" context "nonexistent" %}'
+ )
rendered = t.render(Context())
- self.assertEqual(rendered, 'May')
+ self.assertEqual(rendered, "May")
# Existing context... using a literal
- t = self.get_template('{% load i18n %}{% translate "May" context "month name" %}')
+ t = self.get_template(
+ '{% load i18n %}{% translate "May" context "month name" %}'
+ )
rendered = t.render(Context())
- self.assertEqual(rendered, 'Mai')
+ self.assertEqual(rendered, "Mai")
t = self.get_template('{% load i18n %}{% translate "May" context "verb" %}')
rendered = t.render(Context())
- self.assertEqual(rendered, 'Kann')
+ self.assertEqual(rendered, "Kann")
# Using a variable
- t = self.get_template('{% load i18n %}{% translate "May" context message_context %}')
- rendered = t.render(Context({'message_context': 'month name'}))
- self.assertEqual(rendered, 'Mai')
- t = self.get_template('{% load i18n %}{% translate "May" context message_context %}')
- rendered = t.render(Context({'message_context': 'verb'}))
- self.assertEqual(rendered, 'Kann')
+ t = self.get_template(
+ '{% load i18n %}{% translate "May" context message_context %}'
+ )
+ rendered = t.render(Context({"message_context": "month name"}))
+ self.assertEqual(rendered, "Mai")
+ t = self.get_template(
+ '{% load i18n %}{% translate "May" context message_context %}'
+ )
+ rendered = t.render(Context({"message_context": "verb"}))
+ self.assertEqual(rendered, "Kann")
# Using a filter
- t = self.get_template('{% load i18n %}{% translate "May" context message_context|lower %}')
- rendered = t.render(Context({'message_context': 'MONTH NAME'}))
- self.assertEqual(rendered, 'Mai')
- t = self.get_template('{% load i18n %}{% translate "May" context message_context|lower %}')
- rendered = t.render(Context({'message_context': 'VERB'}))
- self.assertEqual(rendered, 'Kann')
+ t = self.get_template(
+ '{% load i18n %}{% translate "May" context message_context|lower %}'
+ )
+ rendered = t.render(Context({"message_context": "MONTH NAME"}))
+ self.assertEqual(rendered, "Mai")
+ t = self.get_template(
+ '{% load i18n %}{% translate "May" context message_context|lower %}'
+ )
+ rendered = t.render(Context({"message_context": "VERB"}))
+ self.assertEqual(rendered, "Kann")
# Using 'as'
- t = self.get_template('{% load i18n %}{% translate "May" context "month name" as var %}Value: {{ var }}')
+ t = self.get_template(
+ '{% load i18n %}{% translate "May" context "month name" as var %}Value: {{ var }}'
+ )
rendered = t.render(Context())
- self.assertEqual(rendered, 'Value: Mai')
- t = self.get_template('{% load i18n %}{% translate "May" as var context "verb" %}Value: {{ var }}')
+ self.assertEqual(rendered, "Value: Mai")
+ t = self.get_template(
+ '{% load i18n %}{% translate "May" as var context "verb" %}Value: {{ var }}'
+ )
rendered = t.render(Context())
- self.assertEqual(rendered, 'Value: Kann')
+ self.assertEqual(rendered, "Value: Kann")
class TranslationTranslateTagTests(TranslationTransTagTests):
- tag_name = 'translate'
+ tag_name = "translate"
class MultipleLocaleActivationTransTagTests(MultipleLocaleActivationTestCase):
- tag_name = 'trans'
+ tag_name = "trans"
def get_template(self, template_string):
return Template(
- template_string.replace(
- '{{% translate ',
- '{{% {}'.format(self.tag_name)
- )
+ template_string.replace("{{% translate ", "{{% {}".format(self.tag_name))
)
def test_single_locale_activation(self):
@@ -234,36 +268,38 @@ class MultipleLocaleActivationTransTagTests(MultipleLocaleActivationTestCase):
Simple baseline behavior with one locale for all the supported i18n
constructs.
"""
- with translation.override('fr'):
+ with translation.override("fr"):
self.assertEqual(
- self.get_template("{% load i18n %}{% translate 'Yes' %}").render(Context({})),
- 'Oui'
+ self.get_template("{% load i18n %}{% translate 'Yes' %}").render(
+ Context({})
+ ),
+ "Oui",
)
def test_multiple_locale_trans(self):
- with translation.override('de'):
+ with translation.override("de"):
t = self.get_template("{% load i18n %}{% translate 'No' %}")
- with translation.override(self._old_language), translation.override('nl'):
- self.assertEqual(t.render(Context({})), 'Nee')
+ with translation.override(self._old_language), translation.override("nl"):
+ self.assertEqual(t.render(Context({})), "Nee")
def test_multiple_locale_deactivate_trans(self):
- with translation.override('de', deactivate=True):
+ with translation.override("de", deactivate=True):
t = self.get_template("{% load i18n %}{% translate 'No' %}")
- with translation.override('nl'):
- self.assertEqual(t.render(Context({})), 'Nee')
+ with translation.override("nl"):
+ self.assertEqual(t.render(Context({})), "Nee")
def test_multiple_locale_direct_switch_trans(self):
- with translation.override('de'):
+ with translation.override("de"):
t = self.get_template("{% load i18n %}{% translate 'No' %}")
- with translation.override('nl'):
- self.assertEqual(t.render(Context({})), 'Nee')
+ with translation.override("nl"):
+ self.assertEqual(t.render(Context({})), "Nee")
class MultipleLocaleActivationTranslateTagTests(MultipleLocaleActivationTransTagTests):
- tag_name = 'translate'
+ tag_name = "translate"
class LocalizeNodeTests(SimpleTestCase):
def test_repr(self):
node = LocalizeNode(nodelist=[], use_l10n=True)
- self.assertEqual(repr(node), '<LocalizeNode>')
+ self.assertEqual(repr(node), "<LocalizeNode>")