mirror of
https://github.com/searxng/searxng.git
synced 2024-11-05 09:00:02 +00:00
eae3481688
commit2c6531b2
does not only break the unit test, it is a significant change of the data model and the searx search-syntax model (UI) without any discussion nor documentation. At the end, adding routes to instant answers is a nice feature but commit2c6531b2
leaf some questions open. In that sense, this patch is only a hotfix not a assessment. Signed-off-by: Markus Heiser <markus.heiser@darmarit.de>
85 lines
3.2 KiB
Python
85 lines
3.2 KiB
Python
# -*- coding: utf-8 -*-
|
|
|
|
from searx.testing import SearxTestCase
|
|
from searx import plugins
|
|
from mock import Mock
|
|
|
|
|
|
def get_search_mock(query, **kwargs):
|
|
return Mock(search_query=Mock(query=query, **kwargs),
|
|
result_container=Mock(answers=dict()))
|
|
|
|
|
|
class PluginStoreTest(SearxTestCase):
|
|
|
|
def test_PluginStore_init(self):
|
|
store = plugins.PluginStore()
|
|
self.assertTrue(isinstance(store.plugins, list) and len(store.plugins) == 0)
|
|
|
|
def test_PluginStore_register(self):
|
|
store = plugins.PluginStore()
|
|
testplugin = plugins.Plugin()
|
|
store.register(testplugin)
|
|
|
|
self.assertTrue(len(store.plugins) == 1)
|
|
|
|
def test_PluginStore_call(self):
|
|
store = plugins.PluginStore()
|
|
testplugin = plugins.Plugin()
|
|
store.register(testplugin)
|
|
setattr(testplugin, 'asdf', Mock())
|
|
request = Mock()
|
|
store.call([], 'asdf', request, Mock())
|
|
|
|
self.assertFalse(testplugin.asdf.called)
|
|
|
|
store.call([testplugin], 'asdf', request, Mock())
|
|
self.assertTrue(testplugin.asdf.called)
|
|
|
|
|
|
class SelfIPTest(SearxTestCase):
|
|
|
|
def test_PluginStore_init(self):
|
|
store = plugins.PluginStore()
|
|
store.register(plugins.self_info)
|
|
|
|
self.assertTrue(len(store.plugins) == 1)
|
|
|
|
# IP test
|
|
request = Mock(remote_addr='127.0.0.1')
|
|
request.headers.getlist.return_value = []
|
|
search = get_search_mock(query=b'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=b'ip', pageno=2)
|
|
store.call(store.plugins, 'post_search', request, search)
|
|
self.assertFalse('ip' in search.result_container.answers)
|
|
|
|
# User agent test
|
|
request = Mock(user_agent='Mock')
|
|
request.headers.getlist.return_value = []
|
|
|
|
search = get_search_mock(query=b'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=b'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=b'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=b'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=b'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=b'What is my User-Agent?', pageno=2)
|
|
store.call(store.plugins, 'post_search', request, search)
|
|
self.assertFalse('user-agent' in search.result_container.answers)
|