Multilang: more translation sanity checks (#29439)

* tests

* test finished translations

* fix new test failure
pull/29441/head
Shane Smiskol 2 years ago committed by GitHub
parent 25ac9e2148
commit 549a4e9a97
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
  1. 29
      selfdrive/ui/tests/test_translations.py
  2. 12
      selfdrive/ui/translations/main_zh-CHT.ts

@ -67,11 +67,14 @@ class TestTranslations(unittest.TestCase):
self.assertTrue("<translation type=\"vanished\">" not in cur_translations, self.assertTrue("<translation type=\"vanished\">" not in cur_translations,
f"{file} ({name}) translation file has obsolete translations. Run selfdrive/ui/update_translations.py --vanish to remove them") f"{file} ({name}) translation file has obsolete translations. Run selfdrive/ui/update_translations.py --vanish to remove them")
def test_plural_translations(self): def test_finished_translations(self):
""" """
Tests: Tests ran on each translation marked "finished"
- that any numerus (plural) translations marked "finished" have all plural forms non-empty Plural:
- that any numerus (plural) translations have all plural forms non-empty
- that the correct format specifier is used (%n) - that the correct format specifier is used (%n)
Non-plural:
- that translation is not empty
""" """
for name, file in self.translation_files.items(): for name, file in self.translation_files.items():
with self.subTest(name=name, file=file): with self.subTest(name=name, file=file):
@ -79,17 +82,23 @@ class TestTranslations(unittest.TestCase):
for context in tr_xml.getroot(): for context in tr_xml.getroot():
for message in context.iterfind("message"): for message in context.iterfind("message"):
translation = message.find("translation")
source_text = message.find("source").text
# Do not test unfinished translations
if translation.get("type") == "unfinished":
continue
if message.get("numerus") == "yes": if message.get("numerus") == "yes":
translation = message.find("translation")
numerusform = [t.text for t in translation.findall("numerusform")] numerusform = [t.text for t in translation.findall("numerusform")]
# Do not assert finished translations for nf in numerusform:
if translation.get("type") == "unfinished": self.assertIsNotNone(nf, f"Ensure all plural translation forms are completed: {source_text}")
continue self.assertIn("%n", nf, "Ensure numerus argument (%n) exists in translation.")
self.assertIsNone(re.search("%[0-9]+", nf), "Plural translations must use %n, not %1, %2, etc.: {}".format(numerusform))
self.assertNotIn(None, numerusform, "Ensure all plural translation forms are completed.") else:
self.assertTrue(all(re.search("%[0-9]+", t) is None for t in numerusform), self.assertIsNotNone(translation.text, f"Ensure translation is completed: {source_text}")
"Plural translations must use %n, not %1, %2, etc.: {}".format(numerusform))
def test_no_locations(self): def test_no_locations(self):
for name, file in self.translation_files.items(): for name, file in self.translation_files.items():

@ -836,27 +836,27 @@ This may take up to a minute.</source>
</message> </message>
<message> <message>
<source>Wi-Fi</source> <source>Wi-Fi</source>
<translation></translation> <translation type="unfinished"></translation>
</message> </message>
<message> <message>
<source>ETH</source> <source>ETH</source>
<translation></translation> <translation type="unfinished"></translation>
</message> </message>
<message> <message>
<source>2G</source> <source>2G</source>
<translation></translation> <translation type="unfinished"></translation>
</message> </message>
<message> <message>
<source>3G</source> <source>3G</source>
<translation></translation> <translation type="unfinished"></translation>
</message> </message>
<message> <message>
<source>LTE</source> <source>LTE</source>
<translation></translation> <translation type="unfinished"></translation>
</message> </message>
<message> <message>
<source>5G</source> <source>5G</source>
<translation></translation> <translation type="unfinished"></translation>
</message> </message>
</context> </context>
<context> <context>

Loading…
Cancel
Save