mirror of
https://github.com/searxng/searxng.git
synced 2025-01-22 08:08:07 +00:00
542f7d0d7b
In the past, some files were tested with the standard profile, others with a profile in which most of the messages were switched off ... some files were not checked at all. - ``PYLINT_SEARXNG_DISABLE_OPTION`` has been abolished - the distinction ``# lint: pylint`` is no longer necessary - the pylint tasks have been reduced from three to two 1. ./searx/engines -> lint engines with additional builtins 2. ./searx ./searxng_extra ./tests -> lint all other python files Signed-off-by: Markus Heiser <markus.heiser@darmarit.de>
110 lines
4.9 KiB
Python
110 lines
4.9 KiB
Python
# SPDX-License-Identifier: AGPL-3.0-or-later
|
|
# pylint: disable=missing-module-docstring
|
|
"""Test some code from module :py:obj:`searx.locales`"""
|
|
|
|
from searx import locales
|
|
from searx.sxng_locales import sxng_locales
|
|
from tests import SearxTestCase
|
|
|
|
|
|
class TestLocales(SearxTestCase):
|
|
"""Implemented tests:
|
|
|
|
- :py:obj:`searx.locales.match_locale`
|
|
"""
|
|
|
|
def test_match_locale(self):
|
|
|
|
locale_tag_list = [x[0] for x in sxng_locales]
|
|
|
|
# Test SearXNG search languages
|
|
|
|
self.assertEqual(locales.match_locale('de', locale_tag_list), 'de')
|
|
self.assertEqual(locales.match_locale('fr', locale_tag_list), 'fr')
|
|
self.assertEqual(locales.match_locale('zh', locale_tag_list), 'zh')
|
|
|
|
# Test SearXNG search regions
|
|
|
|
self.assertEqual(locales.match_locale('ca-es', locale_tag_list), 'ca-ES')
|
|
self.assertEqual(locales.match_locale('de-at', locale_tag_list), 'de-AT')
|
|
self.assertEqual(locales.match_locale('de-de', locale_tag_list), 'de-DE')
|
|
self.assertEqual(locales.match_locale('en-UK', locale_tag_list), 'en-GB')
|
|
self.assertEqual(locales.match_locale('fr-be', locale_tag_list), 'fr-BE')
|
|
self.assertEqual(locales.match_locale('fr-be', locale_tag_list), 'fr-BE')
|
|
self.assertEqual(locales.match_locale('fr-ca', locale_tag_list), 'fr-CA')
|
|
self.assertEqual(locales.match_locale('fr-ch', locale_tag_list), 'fr-CH')
|
|
self.assertEqual(locales.match_locale('zh-cn', locale_tag_list), 'zh-CN')
|
|
self.assertEqual(locales.match_locale('zh-tw', locale_tag_list), 'zh-TW')
|
|
self.assertEqual(locales.match_locale('zh-hk', locale_tag_list), 'zh-HK')
|
|
|
|
# Test language script code
|
|
|
|
self.assertEqual(locales.match_locale('zh-hans', locale_tag_list), 'zh-CN')
|
|
self.assertEqual(locales.match_locale('zh-hans-cn', locale_tag_list), 'zh-CN')
|
|
self.assertEqual(locales.match_locale('zh-hant', locale_tag_list), 'zh-TW')
|
|
self.assertEqual(locales.match_locale('zh-hant-tw', locale_tag_list), 'zh-TW')
|
|
|
|
# Test individual locale lists
|
|
|
|
self.assertEqual(locales.match_locale('es', [], fallback='fallback'), 'fallback')
|
|
|
|
self.assertEqual(locales.match_locale('de', ['de-CH', 'de-DE']), 'de-DE')
|
|
self.assertEqual(locales.match_locale('de', ['de-CH', 'de-DE']), 'de-DE')
|
|
self.assertEqual(locales.match_locale('es', ['ES']), 'ES')
|
|
self.assertEqual(locales.match_locale('es', ['es-AR', 'es-ES', 'es-MX']), 'es-ES')
|
|
self.assertEqual(locales.match_locale('es-AR', ['es-AR', 'es-ES', 'es-MX']), 'es-AR')
|
|
self.assertEqual(locales.match_locale('es-CO', ['es-AR', 'es-ES']), 'es-ES')
|
|
self.assertEqual(locales.match_locale('es-CO', ['es-AR']), 'es-AR')
|
|
|
|
# Tests from the commit message of 9ae409a05a
|
|
|
|
# Assumption:
|
|
# A. When a user selects a language the results should be optimized according to
|
|
# the selected language.
|
|
#
|
|
# B. When user selects a language and a territory the results should be
|
|
# optimized with first priority on territory and second on language.
|
|
|
|
# Assume we have an engine that supports the following locales:
|
|
locale_tag_list = ['zh-CN', 'zh-HK', 'nl-BE', 'fr-CA']
|
|
|
|
# Examples (Assumption A.)
|
|
# ------------------------
|
|
|
|
# A user selects region 'zh-TW' which should end in zh_HK.
|
|
# hint: CN is 'Hans' and HK ('Hant') fits better to TW ('Hant')
|
|
self.assertEqual(locales.match_locale('zh-TW', locale_tag_list), 'zh-HK')
|
|
|
|
# A user selects only the language 'zh' which should end in CN
|
|
self.assertEqual(locales.match_locale('zh', locale_tag_list), 'zh-CN')
|
|
|
|
# A user selects only the language 'fr' which should end in fr_CA
|
|
self.assertEqual(locales.match_locale('fr', locale_tag_list), 'fr-CA')
|
|
|
|
# The difference in priority on the territory is best shown with a
|
|
# engine that supports the following locales:
|
|
locale_tag_list = ['fr-FR', 'fr-CA', 'en-GB', 'nl-BE']
|
|
|
|
# A user selects only a language
|
|
self.assertEqual(locales.match_locale('en', locale_tag_list), 'en-GB')
|
|
|
|
# hint: the engine supports fr_FR and fr_CA since no territory is given,
|
|
# fr_FR takes priority ..
|
|
self.assertEqual(locales.match_locale('fr', locale_tag_list), 'fr-FR')
|
|
|
|
# Examples (Assumption B.)
|
|
# ------------------------
|
|
|
|
# A user selects region 'fr-BE' which should end in nl-BE
|
|
self.assertEqual(locales.match_locale('fr-BE', locale_tag_list), 'nl-BE')
|
|
|
|
# If the user selects a language and there are two locales like the
|
|
# following:
|
|
|
|
locale_tag_list = ['fr-BE', 'fr-CH']
|
|
|
|
# The get_engine_locale selects the locale by looking at the "population
|
|
# percent" and this percentage has an higher amount in BE (68.%)
|
|
# compared to CH (21%)
|
|
|
|
self.assertEqual(locales.match_locale('fr', locale_tag_list), 'fr-BE')
|