forked from Icycoide/searxng
Change plugin API :
- pre_search(request, search) - post_search(request, search) - on_result(request, search, result) with - request is the Flask request - search a searx.Search instance - result a searx result as usual
This commit is contained in:
parent
67e11c42b9
commit
fbb080f358
6 changed files with 54 additions and 67 deletions
|
@ -6,8 +6,8 @@ from mock import Mock
|
|||
|
||||
|
||||
def get_search_mock(query, **kwargs):
|
||||
return {'search': Mock(query=query, **kwargs),
|
||||
'result_container': Mock(answers=set())}
|
||||
return Mock(search_query=Mock(query=query, **kwargs),
|
||||
result_container=Mock(answers=set()))
|
||||
|
||||
|
||||
class PluginStoreTest(SearxTestCase):
|
||||
|
@ -51,39 +51,39 @@ class SelfIPTest(SearxTestCase):
|
|||
request = Mock(user_plugins=store.plugins,
|
||||
remote_addr='127.0.0.1')
|
||||
request.headers.getlist.return_value = []
|
||||
ctx = get_search_mock(query='ip', pageno=1)
|
||||
store.call('post_search', request, ctx)
|
||||
self.assertTrue('127.0.0.1' in ctx['result_container'].answers)
|
||||
search = get_search_mock(query='ip', pageno=1)
|
||||
store.call('post_search', request, search)
|
||||
self.assertTrue('127.0.0.1' in search.result_container.answers)
|
||||
|
||||
ctx = get_search_mock(query='ip', pageno=2)
|
||||
store.call('post_search', request, ctx)
|
||||
self.assertFalse('127.0.0.1' in ctx['result_container'].answers)
|
||||
search = get_search_mock(query='ip', pageno=2)
|
||||
store.call('post_search', request, search)
|
||||
self.assertFalse('127.0.0.1' in search.result_container.answers)
|
||||
|
||||
# User agent test
|
||||
request = Mock(user_plugins=store.plugins,
|
||||
user_agent='Mock')
|
||||
request.headers.getlist.return_value = []
|
||||
|
||||
ctx = get_search_mock(query='user-agent', pageno=1)
|
||||
store.call('post_search', request, ctx)
|
||||
self.assertTrue('Mock' in ctx['result_container'].answers)
|
||||
search = get_search_mock(query='user-agent', pageno=1)
|
||||
store.call('post_search', request, search)
|
||||
self.assertTrue('Mock' in search.result_container.answers)
|
||||
|
||||
ctx = get_search_mock(query='user-agent', pageno=2)
|
||||
store.call('post_search', request, ctx)
|
||||
self.assertFalse('Mock' in ctx['result_container'].answers)
|
||||
search = get_search_mock(query='user-agent', pageno=2)
|
||||
store.call('post_search', request, search)
|
||||
self.assertFalse('Mock' in search.result_container.answers)
|
||||
|
||||
ctx = get_search_mock(query='user-agent', pageno=1)
|
||||
store.call('post_search', request, ctx)
|
||||
self.assertTrue('Mock' in ctx['result_container'].answers)
|
||||
search = get_search_mock(query='user-agent', pageno=1)
|
||||
store.call('post_search', request, search)
|
||||
self.assertTrue('Mock' in search.result_container.answers)
|
||||
|
||||
ctx = get_search_mock(query='user-agent', pageno=2)
|
||||
store.call('post_search', request, ctx)
|
||||
self.assertFalse('Mock' in ctx['result_container'].answers)
|
||||
search = get_search_mock(query='user-agent', pageno=2)
|
||||
store.call('post_search', request, search)
|
||||
self.assertFalse('Mock' in search.result_container.answers)
|
||||
|
||||
ctx = get_search_mock(query='What is my User-Agent?', pageno=1)
|
||||
store.call('post_search', request, ctx)
|
||||
self.assertTrue('Mock' in ctx['result_container'].answers)
|
||||
search = get_search_mock(query='What is my User-Agent?', pageno=1)
|
||||
store.call('post_search', request, search)
|
||||
self.assertTrue('Mock' in search.result_container.answers)
|
||||
|
||||
ctx = get_search_mock(query='What is my User-Agent?', pageno=2)
|
||||
store.call('post_search', request, ctx)
|
||||
self.assertFalse('Mock' in ctx['result_container'].answers)
|
||||
search = get_search_mock(query='What is my User-Agent?', pageno=2)
|
||||
store.call('post_search', request, search)
|
||||
self.assertFalse('Mock' in search.result_container.answers)
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue