mirror of
https://github.com/searxng/searxng.git
synced 2025-01-05 16:08:41 +00:00
d448def1a6
This commit includes some refactoring in unit tests. As we test more plugins, it seems unweildy to include every test class in the test_plugins.py file. This patch split apart all of the test plugins to their own respective files, including the new test_plugin_calculator.py file.
65 lines
2.4 KiB
Python
65 lines
2.4 KiB
Python
# SPDX-License-Identifier: AGPL-3.0-or-later
|
|
# pylint: disable=missing-module-docstring, invalid-name
|
|
|
|
from mock import Mock
|
|
from parameterized.parameterized import parameterized
|
|
|
|
from searx import (
|
|
plugins,
|
|
limiter,
|
|
botdetection,
|
|
)
|
|
from tests import SearxTestCase
|
|
from .test_plugins import get_search_mock
|
|
|
|
|
|
class PluginIPSelfInfo(SearxTestCase): # pylint: disable=missing-class-docstring
|
|
def setUp(self):
|
|
plugin = plugins.load_and_initialize_plugin('searx.plugins.self_info', False, (None, {}))
|
|
self.store = plugins.PluginStore()
|
|
self.store.register(plugin)
|
|
cfg = limiter.get_cfg()
|
|
botdetection.init(cfg, None)
|
|
|
|
def test_plugin_store_init(self):
|
|
self.assertEqual(1, len(self.store.plugins))
|
|
|
|
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)
|
|
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)
|
|
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=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)
|