diff options
Diffstat (limited to 'tests/unit/test_plugin_hash.py')
| -rw-r--r-- | tests/unit/test_plugin_hash.py | 100 |
1 files changed, 59 insertions, 41 deletions
diff --git a/tests/unit/test_plugin_hash.py b/tests/unit/test_plugin_hash.py index 5c55d7ff1..f7da3c67f 100644 --- a/tests/unit/test_plugin_hash.py +++ b/tests/unit/test_plugin_hash.py @@ -1,51 +1,69 @@ # SPDX-License-Identifier: AGPL-3.0-or-later -# pylint: disable=missing-module-docstring, invalid-name +# pylint: disable=missing-module-docstring,disable=missing-class-docstring,invalid-name -from mock import Mock from parameterized.parameterized import parameterized -from searx import plugins + +import searx.plugins +import searx.preferences + +from searx.extended_types import sxng_request +from searx.result_types import Answer + from tests import SearxTestCase +from .test_plugins import do_post_search -from .test_plugins import get_search_mock +query_res = [ + ("md5 test", "md5 hash digest: 098f6bcd4621d373cade4e832627b4f6"), + ("sha1 test", "sha1 hash digest: a94a8fe5ccb19ba61c4c0873d391e987982fbbd3"), + ("sha224 test", "sha224 hash digest: 90a3ed9e32b2aaf4c61c410eb925426119e1a9dc53d4286ade99a809"), + ("sha256 test", "sha256 hash digest: 9f86d081884c7d659a2feaa0c55ad015a3bf4f1b2b0b822cd15d6c15b0f00a08"), + ( + "sha384 test", + "sha384 hash digest: 768412320f7b0aa5812fce428dc4706b3c" + "ae50e02a64caa16a782249bfe8efc4b7ef1ccb126255d196047dfedf1" + "7a0a9", + ), + ( + "sha512 test", + "sha512 hash digest: ee26b0dd4af7e749aa1a8ee3c10ae9923f6" + "18980772e473f8819a5d4940e0db27ac185f8a0e1d5f84f88bc887fd67b143732c304cc5" + "fa9ad8e6f57f50028a8ff", + ), +] -class PluginHashTest(SearxTestCase): # pylint: disable=missing-class-docstring +class PluginHashTest(SearxTestCase): + def setUp(self): - self.store = plugins.PluginStore() - plugin = plugins.load_and_initialize_plugin('searx.plugins.hash_plugin', False, (None, {})) - self.store.register(plugin) + super().setUp() + engines = {} + + self.storage = searx.plugins.PluginStorage() + self.storage.register_by_fqn("searx.plugins.hash_plugin.SXNGPlugin") + self.storage.init(self.app) + self.pref = searx.preferences.Preferences(["simple"], ["general"], engines, self.storage) + self.pref.parse_dict({"locale": "en"}) def test_plugin_store_init(self): - self.assertEqual(1, len(self.store.plugins)) - - @parameterized.expand( - [ - ('md5 test', 'md5 hash digest: 098f6bcd4621d373cade4e832627b4f6'), - ('sha1 test', 'sha1 hash digest: a94a8fe5ccb19ba61c4c0873d391e987982fbbd3'), - ('sha224 test', 'sha224 hash digest: 90a3ed9e32b2aaf4c61c410eb925426119e1a9dc53d4286ade99a809'), - ('sha256 test', 'sha256 hash digest: 9f86d081884c7d659a2feaa0c55ad015a3bf4f1b2b0b822cd15d6c15b0f00a08'), - ( - 'sha384 test', - 'sha384 hash digest: 768412320f7b0aa5812fce428dc4706b3c' - 'ae50e02a64caa16a782249bfe8efc4b7ef1ccb126255d196047dfedf1' - '7a0a9', - ), - ( - 'sha512 test', - 'sha512 hash digest: ee26b0dd4af7e749aa1a8ee3c10ae9923f6' - '18980772e473f8819a5d4940e0db27ac185f8a0e1d5f84f88bc887fd67b143732c304cc5' - 'fa9ad8e6f57f50028a8ff', - ), - ] - ) - def test_hash_digest_new(self, query: str, hash_str: str): - request = Mock(remote_addr='127.0.0.1') - search = get_search_mock(query=query, pageno=1) - self.store.call(self.store.plugins, 'post_search', request, search) - self.assertIn(hash_str, search.result_container.answers['hash']['answer']) - - def test_md5_bytes_no_answer(self): - request = Mock(remote_addr='127.0.0.1') - search = get_search_mock(query=b'md5 test', pageno=2) - self.store.call(self.store.plugins, 'post_search', request, search) - self.assertNotIn('hash', search.result_container.answers) + self.assertEqual(1, len(self.storage)) + + @parameterized.expand(query_res) + def test_hash_digest_new(self, query: str, res: str): + with self.app.test_request_context(): + sxng_request.preferences = self.pref + answer = Answer(results=[], answer=res) + + search = do_post_search(query, self.storage) + self.assertIn(answer, search.result_container.answers) + + def test_pageno_1_2(self): + with self.app.test_request_context(): + sxng_request.preferences = self.pref + query, res = query_res[0] + answer = Answer(results=[], answer=res) + + search = do_post_search(query, self.storage, pageno=1) + self.assertIn(answer, search.result_container.answers) + + search = do_post_search(query, self.storage, pageno=2) + self.assertEqual(list(search.result_container.answers), []) |