summaryrefslogtreecommitdiff
path: root/tests/unit/test_plugins.py
diff options
context:
space:
mode:
Diffstat (limited to 'tests/unit/test_plugins.py')
-rw-r--r--tests/unit/test_plugins.py205
1 files changed, 94 insertions, 111 deletions
diff --git a/tests/unit/test_plugins.py b/tests/unit/test_plugins.py
index 72d68ba29..0b89d46fa 100644
--- a/tests/unit/test_plugins.py
+++ b/tests/unit/test_plugins.py
@@ -2,6 +2,7 @@
# pylint: disable=missing-module-docstring
from mock import Mock
+from parameterized.parameterized import parameterized
from searx import (
plugins,
@@ -23,143 +24,125 @@ class PluginMock: # pylint: disable=missing-class-docstring, too-few-public-met
class PluginStoreTest(SearxTestCase): # pylint: disable=missing-class-docstring
- def test_PluginStore_init(self):
- store = plugins.PluginStore()
- self.assertTrue(isinstance(store.plugins, list) and len(store.plugins) == 0)
+ def setUp(self):
+ self.store = plugins.PluginStore()
- def test_PluginStore_register(self):
- store = plugins.PluginStore()
+ def test_init(self):
+ self.assertEqual(0, len(self.store.plugins))
+ self.assertIsInstance(self.store.plugins, list)
+
+ def test_register(self):
testplugin = PluginMock()
- store.register(testplugin)
+ self.store.register(testplugin)
+ self.assertEqual(1, len(self.store.plugins))
- self.assertTrue(len(store.plugins) == 1)
+ def test_call_empty(self):
+ testplugin = PluginMock()
+ self.store.register(testplugin)
+ setattr(testplugin, 'asdf', Mock())
+ request = Mock()
+ self.store.call([], 'asdf', request, Mock())
+ self.assertFalse(getattr(testplugin, 'asdf').called) # pylint: disable=E1101
- def test_PluginStore_call(self):
+ def test_call_with_plugin(self):
store = plugins.PluginStore()
testplugin = PluginMock()
store.register(testplugin)
setattr(testplugin, 'asdf', Mock())
request = Mock()
- store.call([], 'asdf', request, Mock())
-
- self.assertFalse(testplugin.asdf.called) # pylint: disable=E1101
-
store.call([testplugin], 'asdf', request, Mock())
- self.assertTrue(testplugin.asdf.called) # pylint: disable=E1101
+ self.assertTrue(getattr(testplugin, 'asdf').called) # pylint: disable=E1101
-class SelfIPTest(SearxTestCase): # pylint: disable=missing-class-docstring
- def test_PluginStore_init(self):
+class PluginIPSelfInfo(SearxTestCase): # pylint: disable=missing-class-docstring
+ def setUp(self):
plugin = plugins.load_and_initialize_plugin('searx.plugins.self_info', False, (None, {}))
- store = plugins.PluginStore()
- store.register(plugin)
+ self.store = plugins.PluginStore()
+ self.store.register(plugin)
cfg = limiter.get_cfg()
botdetection.init(cfg, None)
- self.assertTrue(len(store.plugins) == 1)
+ def test_plugin_store_init(self):
+ self.assertEqual(1, len(self.store.plugins))
- # IP test
+ def test_ip_in_answer(self):
request = Mock()
request.remote_addr = '127.0.0.1'
request.headers = {'X-Forwarded-For': '1.2.3.4, 127.0.0.1', 'X-Real-IP': '127.0.0.1'}
- search = get_search_mock(
- query='ip',
- pageno=1,
- )
- store.call(store.plugins, 'post_search', request, search)
- self.assertTrue('127.0.0.1' in search.result_container.answers["ip"]["answer"])
+ search = get_search_mock(query='ip', pageno=1)
+ self.store.call(self.store.plugins, 'post_search', request, search)
+ self.assertIn('127.0.0.1', search.result_container.answers["ip"]["answer"])
+ def test_ip_not_in_answer(self):
+ request = Mock()
+ request.remote_addr = '127.0.0.1'
+ request.headers = {'X-Forwarded-For': '1.2.3.4, 127.0.0.1', 'X-Real-IP': '127.0.0.1'}
search = get_search_mock(query='ip', pageno=2)
- store.call(store.plugins, 'post_search', request, search)
- self.assertFalse('ip' in search.result_container.answers)
-
- # User agent test
+ self.store.call(self.store.plugins, 'post_search', request, search)
+ self.assertNotIn('ip', search.result_container.answers)
+
+ @parameterized.expand(
+ [
+ 'user-agent',
+ 'What is my User-Agent?',
+ ]
+ )
+ def test_user_agent_in_answer(self, query: str):
request = Mock(user_agent=Mock(string='Mock'))
-
- search = get_search_mock(query='user-agent', pageno=1)
- store.call(store.plugins, 'post_search', request, search)
- self.assertTrue('Mock' in search.result_container.answers["user-agent"]["answer"])
-
- search = get_search_mock(query='user-agent', pageno=2)
- store.call(store.plugins, 'post_search', request, search)
- self.assertFalse('user-agent' in search.result_container.answers)
-
- search = get_search_mock(query='user-agent', pageno=1)
- store.call(store.plugins, 'post_search', request, search)
- self.assertTrue('Mock' in search.result_container.answers["user-agent"]["answer"])
-
- search = get_search_mock(query='user-agent', pageno=2)
- store.call(store.plugins, 'post_search', request, search)
- self.assertFalse('user-agent' in search.result_container.answers)
-
- search = get_search_mock(query='What is my User-Agent?', pageno=1)
- store.call(store.plugins, 'post_search', request, search)
- self.assertTrue('Mock' in search.result_container.answers["user-agent"]["answer"])
-
- search = get_search_mock(query='What is my User-Agent?', pageno=2)
- store.call(store.plugins, 'post_search', request, search)
- self.assertFalse('user-agent' in search.result_container.answers)
+ search = get_search_mock(query=query, pageno=1)
+ self.store.call(self.store.plugins, 'post_search', request, search)
+ self.assertIn('Mock', search.result_container.answers["user-agent"]["answer"])
+
+ @parameterized.expand(
+ [
+ 'user-agent',
+ 'What is my User-Agent?',
+ ]
+ )
+ def test_user_agent_not_in_answer(self, query: str):
+ request = Mock(user_agent=Mock(string='Mock'))
+ search = get_search_mock(query=query, pageno=2)
+ self.store.call(self.store.plugins, 'post_search', request, search)
+ self.assertNotIn('user-agent', search.result_container.answers)
-class HashPluginTest(SearxTestCase): # pylint: disable=missing-class-docstring
- def test_PluginStore_init(self):
- store = plugins.PluginStore()
+class PluginHashTest(SearxTestCase): # pylint: disable=missing-class-docstring
+ def setUp(self):
+ self.store = plugins.PluginStore()
plugin = plugins.load_and_initialize_plugin('searx.plugins.hash_plugin', False, (None, {}))
- store.register(plugin)
-
- self.assertTrue(len(store.plugins) == 1)
-
+ self.store.register(plugin)
+
+ 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'])
- # MD5
- search = get_search_mock(query='md5 test', pageno=1)
- store.call(store.plugins, 'post_search', request, search)
- self.assertTrue(
- 'md5 hash digest: 098f6bcd4621d373cade4e832627b4f6' in 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)
- store.call(store.plugins, 'post_search', request, search)
- self.assertFalse('hash' in search.result_container.answers)
-
- # SHA1
- search = get_search_mock(query='sha1 test', pageno=1)
- store.call(store.plugins, 'post_search', request, search)
- self.assertTrue(
- 'sha1 hash digest: a94a8fe5ccb19ba61c4c0873d391e9879'
- '82fbbd3' in search.result_container.answers['hash']['answer']
- )
-
- # SHA224
- search = get_search_mock(query='sha224 test', pageno=1)
- store.call(store.plugins, 'post_search', request, search)
- self.assertTrue(
- 'sha224 hash digest: 90a3ed9e32b2aaf4c61c410eb9254261'
- '19e1a9dc53d4286ade99a809' in search.result_container.answers['hash']['answer']
- )
-
- # SHA256
- search = get_search_mock(query='sha256 test', pageno=1)
- store.call(store.plugins, 'post_search', request, search)
- self.assertTrue(
- 'sha256 hash digest: 9f86d081884c7d659a2feaa0c55ad015a'
- '3bf4f1b2b0b822cd15d6c15b0f00a08' in search.result_container.answers['hash']['answer']
- )
-
- # SHA384
- search = get_search_mock(query='sha384 test', pageno=1)
- store.call(store.plugins, 'post_search', request, search)
- self.assertTrue(
- 'sha384 hash digest: 768412320f7b0aa5812fce428dc4706b3c'
- 'ae50e02a64caa16a782249bfe8efc4b7ef1ccb126255d196047dfedf1'
- '7a0a9' in search.result_container.answers['hash']['answer']
- )
-
- # SHA512
- search = get_search_mock(query='sha512 test', pageno=1)
- store.call(store.plugins, 'post_search', request, search)
- self.assertTrue(
- 'sha512 hash digest: ee26b0dd4af7e749aa1a8ee3c10ae9923f6'
- '18980772e473f8819a5d4940e0db27ac185f8a0e1d5f84f88bc887fd67b143732c304cc5'
- 'fa9ad8e6f57f50028a8ff' in search.result_container.answers['hash']['answer']
- )
+ self.store.call(self.store.plugins, 'post_search', request, search)
+ self.assertNotIn('hash', search.result_container.answers)