test_engines_init.py 3.4 KB

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