mirror of
				https://github.com/searxng/searxng.git
				synced 2025-11-04 03:27:06 -05:00 
			
		
		
		
	In the past, some files were tested with the standard profile, others with a profile in which most of the messages were switched off ... some files were not checked at all. - ``PYLINT_SEARXNG_DISABLE_OPTION`` has been abolished - the distinction ``# lint: pylint`` is no longer necessary - the pylint tasks have been reduced from three to two 1. ./searx/engines -> lint engines with additional builtins 2. ./searx ./searxng_extra ./tests -> lint all other python files Signed-off-by: Markus Heiser <markus.heiser@darmarit.de>
		
			
				
	
	
		
			166 lines
		
	
	
		
			6.4 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			166 lines
		
	
	
		
			6.4 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
# SPDX-License-Identifier: AGPL-3.0-or-later
 | 
						|
# pylint: disable=missing-module-docstring
 | 
						|
 | 
						|
from mock import Mock
 | 
						|
 | 
						|
from searx import (
 | 
						|
    plugins,
 | 
						|
    limiter,
 | 
						|
    botdetection,
 | 
						|
)
 | 
						|
 | 
						|
from tests import SearxTestCase
 | 
						|
 | 
						|
 | 
						|
def get_search_mock(query, **kwargs):
 | 
						|
    return Mock(search_query=Mock(query=query, **kwargs), result_container=Mock(answers={}))
 | 
						|
 | 
						|
 | 
						|
class PluginMock:  # pylint: disable=missing-class-docstring, too-few-public-methods
 | 
						|
    default_on = False
 | 
						|
    name = 'Default plugin'
 | 
						|
    description = 'Default plugin description'
 | 
						|
 | 
						|
 | 
						|
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 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):  # pylint: disable=missing-class-docstring
 | 
						|
    def test_PluginStore_init(self):
 | 
						|
        plugin = plugins.load_and_initialize_plugin('searx.plugins.self_info', False, (None, {}))
 | 
						|
        store = plugins.PluginStore()
 | 
						|
        store.register(plugin)
 | 
						|
        cfg = limiter.get_cfg()
 | 
						|
        botdetection.init(cfg, None)
 | 
						|
 | 
						|
        self.assertTrue(len(store.plugins) == 1)
 | 
						|
 | 
						|
        # IP test
 | 
						|
        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=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')
 | 
						|
 | 
						|
        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):  # pylint: disable=missing-class-docstring
 | 
						|
    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')
 | 
						|
 | 
						|
        # 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']
 | 
						|
        )
 |