forked from Archives/searxng
You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
215 lines
8.3 KiB
Python
215 lines
8.3 KiB
Python
# -*- coding: utf-8 -*-
|
|
|
|
from searx import plugins, redisdb
|
|
from mock import Mock
|
|
from mock import patch
|
|
from tests import SearxTestCase
|
|
|
|
|
|
def get_search_mock(query, **kwargs):
|
|
return Mock(search_query=Mock(query=query, **kwargs), result_container=Mock(answers=dict()))
|
|
|
|
|
|
class PluginMock:
|
|
default_on = False
|
|
name = 'Default plugin'
|
|
description = 'Default plugin description'
|
|
|
|
|
|
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 = PluginMock()
|
|
store.register(testplugin)
|
|
|
|
self.assertTrue(len(store.plugins) == 1)
|
|
|
|
def test_PluginStore_call(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
|
|
|
|
|
|
class SelfIPTest(SearxTestCase):
|
|
def test_PluginStore_init(self):
|
|
plugin = plugins.load_and_initialize_plugin('searx.plugins.self_info', False, (None, {}))
|
|
store = plugins.PluginStore()
|
|
store.register(plugin)
|
|
|
|
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='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=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='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)
|
|
|
|
|
|
class HashPluginTest(SearxTestCase):
|
|
def test_PluginStore_init(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)
|
|
|
|
request = Mock(remote_addr='127.0.0.1')
|
|
request.headers.getlist.return_value = []
|
|
|
|
# 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']
|
|
)
|
|
|
|
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']
|
|
)
|
|
|
|
|
|
@patch.object(redisdb, '_CLIENT', new=True)
|
|
class LimiterPluginTest(SearxTestCase):
|
|
def test_whitelist(self):
|
|
store = plugins.PluginStore()
|
|
limiter_settings = {
|
|
'server': {
|
|
'limiter': True,
|
|
}
|
|
}
|
|
|
|
app_mock = Mock(before_request=lambda x: True)
|
|
plugin = plugins.load_and_initialize_plugin('searx.plugins.limiter', False, (app_mock, limiter_settings))
|
|
store.register(plugin)
|
|
self.assertTrue(len(store.plugins) == 1)
|
|
|
|
def test_whitelist_case(case):
|
|
plugins.limiter.init_whitelist(case[1]['whitelist_ip'], case[1]['whitelist_subnet'])
|
|
ret = store.call(store.plugins, 'is_whitelist_ip', case[0])
|
|
self.assertEqual(ret, case[2])
|
|
|
|
test_cases = []
|
|
# default test case with no whitelist
|
|
test_cases.append(
|
|
(
|
|
'192.0.43.22', # x_forwarded_for
|
|
{'whitelist_ip': [], 'whitelist_subnet': []},
|
|
False, # expected return value if request is accepted
|
|
)
|
|
)
|
|
|
|
# test single ip
|
|
test_cases.append(('192.0.43.22', {'whitelist_ip': '192.0.43.22', 'whitelist_subnet': []}, True))
|
|
|
|
# test ip in list
|
|
test_cases.append(('192.0.43.22', {'whitelist_ip': ['192.0.43.22'], 'whitelist_subnet': []}, True))
|
|
|
|
# test ok single subnet
|
|
test_cases.append(('192.0.43.22', {'whitelist_ip': [], 'whitelist_subnet': ['192.0.0.0/16']}, True))
|
|
|
|
# test ok subnet in list
|
|
test_cases.append(
|
|
('192.0.43.22', {'whitelist_ip': [], 'whitelist_subnet': ['192.0.0.0/16', '192.0.0.1/24']}, True)
|
|
)
|
|
|
|
# test ko subnet
|
|
test_cases.append(('192.0.43.22', {'whitelist_ip': [], 'whitelist_subnet': ['192.0.0.0/24']}, False))
|
|
|
|
for case in test_cases:
|
|
test_whitelist_case(case)
|
|
|
|
# not an ip
|
|
with self.assertRaises(ValueError):
|
|
test_whitelist_case(('192.0.43.22', {'whitelist_ip': ['not an ip'], 'whitelist_subnet': []}, False))
|
|
|
|
# not a subnet
|
|
with self.assertRaises(ValueError):
|
|
test_whitelist_case(('192.0.43.22', {'whitelist_ip': [], 'whitelist_subnet': ['not a subnet']}, False))
|