test_webadapter.py 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041
  1. # SPDX-License-Identifier: AGPL-3.0-or-later
  2. # pylint: disable=missing-module-docstring,disable=missing-class-docstring,invalid-name
  3. import searx.plugins
  4. from searx.engines import engines
  5. from searx.preferences import Preferences
  6. from searx.search import EngineRef
  7. from searx.webadapter import validate_engineref_list
  8. from tests import SearxTestCase
  9. PRIVATE_ENGINE_NAME = "dummy private engine" # from the ./settings/test_settings.yml
  10. SEARCHQUERY = [EngineRef(PRIVATE_ENGINE_NAME, "general")]
  11. class ValidateQueryCase(SearxTestCase):
  12. def test_without_token(self):
  13. preferences = Preferences(['simple'], ['general'], engines, searx.plugins.STORAGE)
  14. valid, unknown, invalid_token = validate_engineref_list(SEARCHQUERY, preferences)
  15. self.assertEqual(len(valid), 0)
  16. self.assertEqual(len(unknown), 0)
  17. self.assertEqual(len(invalid_token), 1)
  18. def test_with_incorrect_token(self):
  19. preferences_with_tokens = Preferences(['simple'], ['general'], engines, searx.plugins.STORAGE)
  20. preferences_with_tokens.parse_dict({'tokens': 'bad-token'})
  21. valid, unknown, invalid_token = validate_engineref_list(SEARCHQUERY, preferences_with_tokens)
  22. self.assertEqual(len(valid), 0)
  23. self.assertEqual(len(unknown), 0)
  24. self.assertEqual(len(invalid_token), 1)
  25. def test_with_correct_token(self):
  26. preferences_with_tokens = Preferences(['simple'], ['general'], engines, searx.plugins.STORAGE)
  27. preferences_with_tokens.parse_dict({'tokens': 'my-token'})
  28. valid, unknown, invalid_token = validate_engineref_list(SEARCHQUERY, preferences_with_tokens)
  29. self.assertEqual(len(valid), 1)
  30. self.assertEqual(len(unknown), 0)
  31. self.assertEqual(len(invalid_token), 0)