test_locales.py 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110
  1. # SPDX-License-Identifier: AGPL-3.0-or-later
  2. # pylint: disable=missing-module-docstring
  3. """Test some code from module :py:obj:`searx.locales`"""
  4. from searx import locales
  5. from searx.sxng_locales import sxng_locales
  6. from tests import SearxTestCase
  7. class TestLocales(SearxTestCase):
  8. """Implemented tests:
  9. - :py:obj:`searx.locales.match_locale`
  10. """
  11. def test_match_locale(self):
  12. locale_tag_list = [x[0] for x in sxng_locales]
  13. # Test SearXNG search languages
  14. self.assertEqual(locales.match_locale('de', locale_tag_list), 'de')
  15. self.assertEqual(locales.match_locale('fr', locale_tag_list), 'fr')
  16. self.assertEqual(locales.match_locale('zh', locale_tag_list), 'zh')
  17. # Test SearXNG search regions
  18. self.assertEqual(locales.match_locale('ca-es', locale_tag_list), 'ca-ES')
  19. self.assertEqual(locales.match_locale('de-at', locale_tag_list), 'de-AT')
  20. self.assertEqual(locales.match_locale('de-de', locale_tag_list), 'de-DE')
  21. self.assertEqual(locales.match_locale('en-UK', locale_tag_list), 'en-GB')
  22. self.assertEqual(locales.match_locale('fr-be', locale_tag_list), 'fr-BE')
  23. self.assertEqual(locales.match_locale('fr-be', locale_tag_list), 'fr-BE')
  24. self.assertEqual(locales.match_locale('fr-ca', locale_tag_list), 'fr-CA')
  25. self.assertEqual(locales.match_locale('fr-ch', locale_tag_list), 'fr-CH')
  26. self.assertEqual(locales.match_locale('zh-cn', locale_tag_list), 'zh-CN')
  27. self.assertEqual(locales.match_locale('zh-tw', locale_tag_list), 'zh-TW')
  28. self.assertEqual(locales.match_locale('zh-hk', locale_tag_list), 'zh-HK')
  29. # Test language script code
  30. self.assertEqual(locales.match_locale('zh-hans', locale_tag_list), 'zh-CN')
  31. self.assertEqual(locales.match_locale('zh-hans-cn', locale_tag_list), 'zh-CN')
  32. self.assertEqual(locales.match_locale('zh-hant', locale_tag_list), 'zh-TW')
  33. self.assertEqual(locales.match_locale('zh-hant-tw', locale_tag_list), 'zh-TW')
  34. # Test individual locale lists
  35. self.assertEqual(locales.match_locale('es', [], fallback='fallback'), 'fallback')
  36. self.assertEqual(locales.match_locale('de', ['de-CH', 'de-DE']), 'de-DE')
  37. self.assertEqual(locales.match_locale('de', ['de-CH', 'de-DE']), 'de-DE')
  38. self.assertEqual(locales.match_locale('es', ['ES']), 'ES')
  39. self.assertEqual(locales.match_locale('es', ['es-AR', 'es-ES', 'es-MX']), 'es-ES')
  40. self.assertEqual(locales.match_locale('es-AR', ['es-AR', 'es-ES', 'es-MX']), 'es-AR')
  41. self.assertEqual(locales.match_locale('es-CO', ['es-AR', 'es-ES']), 'es-ES')
  42. self.assertEqual(locales.match_locale('es-CO', ['es-AR']), 'es-AR')
  43. # Tests from the commit message of 9ae409a05a
  44. # Assumption:
  45. # A. When a user selects a language the results should be optimized according to
  46. # the selected language.
  47. #
  48. # B. When user selects a language and a territory the results should be
  49. # optimized with first priority on territory and second on language.
  50. # Assume we have an engine that supports the following locales:
  51. locale_tag_list = ['zh-CN', 'zh-HK', 'nl-BE', 'fr-CA']
  52. # Examples (Assumption A.)
  53. # ------------------------
  54. # A user selects region 'zh-TW' which should end in zh_HK.
  55. # hint: CN is 'Hans' and HK ('Hant') fits better to TW ('Hant')
  56. self.assertEqual(locales.match_locale('zh-TW', locale_tag_list), 'zh-HK')
  57. # A user selects only the language 'zh' which should end in CN
  58. self.assertEqual(locales.match_locale('zh', locale_tag_list), 'zh-CN')
  59. # A user selects only the language 'fr' which should end in fr_CA
  60. self.assertEqual(locales.match_locale('fr', locale_tag_list), 'fr-CA')
  61. # The difference in priority on the territory is best shown with a
  62. # engine that supports the following locales:
  63. locale_tag_list = ['fr-FR', 'fr-CA', 'en-GB', 'nl-BE']
  64. # A user selects only a language
  65. self.assertEqual(locales.match_locale('en', locale_tag_list), 'en-GB')
  66. # hint: the engine supports fr_FR and fr_CA since no territory is given,
  67. # fr_FR takes priority ..
  68. self.assertEqual(locales.match_locale('fr', locale_tag_list), 'fr-FR')
  69. # Examples (Assumption B.)
  70. # ------------------------
  71. # A user selects region 'fr-BE' which should end in nl-BE
  72. self.assertEqual(locales.match_locale('fr-BE', locale_tag_list), 'nl-BE')
  73. # If the user selects a language and there are two locales like the
  74. # following:
  75. locale_tag_list = ['fr-BE', 'fr-CH']
  76. # The get_engine_locale selects the locale by looking at the "population
  77. # percent" and this percentage has an higher amount in BE (68.%)
  78. # compared to CH (21%)
  79. self.assertEqual(locales.match_locale('fr', locale_tag_list), 'fr-BE')