test_engines_init.py 3.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677
  1. # SPDX-License-Identifier: AGPL-3.0-or-later
  2. # pylint: disable=missing-module-docstring,disable=missing-class-docstring,invalid-name
  3. from searx import settings, engines
  4. from tests import SearxTestCase
  5. class TestEnginesInit(SearxTestCase):
  6. def test_initialize_engines_default(self):
  7. engine_list = [
  8. {'engine': 'dummy', 'name': 'engine1', 'shortcut': 'e1'},
  9. {'engine': 'dummy', 'name': 'engine2', 'shortcut': 'e2'},
  10. ]
  11. engines.load_engines(engine_list)
  12. self.assertEqual(len(engines.engines), 2)
  13. self.assertIn('engine1', engines.engines)
  14. self.assertIn('engine2', engines.engines)
  15. def test_initialize_engines_exclude_onions(self):
  16. settings['outgoing']['using_tor_proxy'] = False
  17. engine_list = [
  18. {'engine': 'dummy', 'name': 'engine1', 'shortcut': 'e1', 'categories': 'general'},
  19. {'engine': 'dummy', 'name': 'engine2', 'shortcut': 'e2', 'categories': 'onions'},
  20. ]
  21. engines.load_engines(engine_list)
  22. self.assertEqual(len(engines.engines), 1)
  23. self.assertIn('engine1', engines.engines)
  24. self.assertNotIn('onions', engines.categories)
  25. def test_initialize_engines_include_onions(self):
  26. settings['outgoing']['using_tor_proxy'] = True
  27. settings['outgoing']['extra_proxy_timeout'] = 100.0
  28. engine_list = [
  29. {
  30. 'engine': 'dummy',
  31. 'name': 'engine1',
  32. 'shortcut': 'e1',
  33. 'categories': 'general',
  34. 'timeout': 20.0,
  35. 'onion_url': 'http://engine1.onion',
  36. },
  37. {'engine': 'dummy', 'name': 'engine2', 'shortcut': 'e2', 'categories': 'onions'},
  38. ]
  39. engines.load_engines(engine_list)
  40. self.assertEqual(len(engines.engines), 2)
  41. self.assertIn('engine1', engines.engines)
  42. self.assertIn('engine2', engines.engines)
  43. self.assertIn('onions', engines.categories)
  44. self.assertIn('http://engine1.onion', engines.engines['engine1'].search_url)
  45. self.assertEqual(engines.engines['engine1'].timeout, 120.0)
  46. def test_missing_name_field(self):
  47. settings['outgoing']['using_tor_proxy'] = False
  48. engine_list = [
  49. {'engine': 'dummy', 'shortcut': 'e1', 'categories': 'general'},
  50. ]
  51. with self.assertLogs('searx.engines', level='ERROR') as cm: # pylint: disable=invalid-name
  52. engines.load_engines(engine_list)
  53. self.assertEqual(len(engines.engines), 0)
  54. self.assertEqual(cm.output, ['ERROR:searx.engines:An engine does not have a "name" field'])
  55. def test_missing_engine_field(self):
  56. settings['outgoing']['using_tor_proxy'] = False
  57. engine_list = [
  58. {'name': 'engine2', 'shortcut': 'e2', 'categories': 'onions'},
  59. ]
  60. with self.assertLogs('searx.engines', level='ERROR') as cm: # pylint: disable=invalid-name
  61. engines.load_engines(engine_list)
  62. self.assertEqual(len(engines.engines), 0)
  63. self.assertEqual(
  64. cm.output, ['ERROR:searx.engines:The "engine" field is missing for the engine named "engine2"']
  65. )