mirror of
				https://github.com/searxng/searxng.git
				synced 2025-11-04 03:27:06 -05:00 
			
		
		
		
	- https://github.com/searxng/searxng/pull/3746#issuecomment-2300965005 - https://github.com/searxng/searxng/issues/2988#issuecomment-2226929084 Signed-off-by: Markus Heiser <markus.heiser@darmarit.de>
		
			
				
	
	
		
			144 lines
		
	
	
		
			4.9 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			144 lines
		
	
	
		
			4.9 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
# SPDX-License-Identifier: AGPL-3.0-or-later
 | 
						|
# pylint: disable=missing-module-docstring, invalid-name
 | 
						|
 | 
						|
from copy import copy
 | 
						|
import logging
 | 
						|
 | 
						|
import searx.search
 | 
						|
from searx.search import SearchQuery, EngineRef
 | 
						|
from searx import settings
 | 
						|
from tests import SearxTestCase
 | 
						|
 | 
						|
 | 
						|
SAFESEARCH = 0
 | 
						|
PAGENO = 1
 | 
						|
PUBLIC_ENGINE_NAME = 'general dummy'
 | 
						|
TEST_ENGINES = [
 | 
						|
    {
 | 
						|
        'name': PUBLIC_ENGINE_NAME,
 | 
						|
        'engine': 'dummy',
 | 
						|
        'categories': 'general',
 | 
						|
        'shortcut': 'gd',
 | 
						|
        'timeout': 3.0,
 | 
						|
        'tokens': [],
 | 
						|
    },
 | 
						|
]
 | 
						|
 | 
						|
 | 
						|
class SearchQueryTestCase(SearxTestCase):  # pylint: disable=missing-class-docstring
 | 
						|
    def test_repr(self):
 | 
						|
        s = SearchQuery('test', [EngineRef('bing', 'general')], 'all', 0, 1, '1', 5.0, 'g')
 | 
						|
        self.assertEqual(
 | 
						|
            repr(s), "SearchQuery('test', [EngineRef('bing', 'general')], 'all', 0, 1, '1', 5.0, 'g', None)"
 | 
						|
        )  # noqa
 | 
						|
 | 
						|
    def test_eq(self):
 | 
						|
        s = SearchQuery('test', [EngineRef('bing', 'general')], 'all', 0, 1, None, None, None)
 | 
						|
        t = SearchQuery('test', [EngineRef('google', 'general')], 'all', 0, 1, None, None, None)
 | 
						|
        self.assertEqual(s, s)
 | 
						|
        self.assertNotEqual(s, t)
 | 
						|
 | 
						|
    def test_copy(self):
 | 
						|
        s = SearchQuery('test', [EngineRef('bing', 'general')], 'all', 0, 1, None, None, None)
 | 
						|
        t = copy(s)
 | 
						|
        self.assertEqual(s, t)
 | 
						|
 | 
						|
 | 
						|
class SearchTestCase(SearxTestCase):  # pylint: disable=missing-class-docstring
 | 
						|
    def setUp(self):
 | 
						|
 | 
						|
        log = logging.getLogger("searx")
 | 
						|
        log_lev = log.level
 | 
						|
        log.setLevel(logging.ERROR)
 | 
						|
        from searx import webapp  # pylint: disable=import-outside-toplevel
 | 
						|
 | 
						|
        log.setLevel(log_lev)
 | 
						|
 | 
						|
        self.app = webapp.app
 | 
						|
 | 
						|
    @classmethod
 | 
						|
    def setUpClass(cls):
 | 
						|
        searx.search.initialize(TEST_ENGINES)
 | 
						|
 | 
						|
    def test_timeout_simple(self):
 | 
						|
        settings['outgoing']['max_request_timeout'] = None
 | 
						|
        search_query = SearchQuery(
 | 
						|
            'test', [EngineRef(PUBLIC_ENGINE_NAME, 'general')], 'en-US', SAFESEARCH, PAGENO, None, None
 | 
						|
        )
 | 
						|
        search = searx.search.Search(search_query)
 | 
						|
        with self.app.test_request_context('/search'):
 | 
						|
            search.search()
 | 
						|
        self.assertEqual(search.actual_timeout, 3.0)
 | 
						|
 | 
						|
    def test_timeout_query_above_default_nomax(self):
 | 
						|
        settings['outgoing']['max_request_timeout'] = None
 | 
						|
        search_query = SearchQuery(
 | 
						|
            'test', [EngineRef(PUBLIC_ENGINE_NAME, 'general')], 'en-US', SAFESEARCH, PAGENO, None, 5.0
 | 
						|
        )
 | 
						|
        search = searx.search.Search(search_query)
 | 
						|
        with self.app.test_request_context('/search'):
 | 
						|
            search.search()
 | 
						|
        self.assertEqual(search.actual_timeout, 3.0)
 | 
						|
 | 
						|
    def test_timeout_query_below_default_nomax(self):
 | 
						|
        settings['outgoing']['max_request_timeout'] = None
 | 
						|
        search_query = SearchQuery(
 | 
						|
            'test', [EngineRef(PUBLIC_ENGINE_NAME, 'general')], 'en-US', SAFESEARCH, PAGENO, None, 1.0
 | 
						|
        )
 | 
						|
        search = searx.search.Search(search_query)
 | 
						|
        with self.app.test_request_context('/search'):
 | 
						|
            search.search()
 | 
						|
        self.assertEqual(search.actual_timeout, 1.0)
 | 
						|
 | 
						|
    def test_timeout_query_below_max(self):
 | 
						|
        settings['outgoing']['max_request_timeout'] = 10.0
 | 
						|
        search_query = SearchQuery(
 | 
						|
            'test', [EngineRef(PUBLIC_ENGINE_NAME, 'general')], 'en-US', SAFESEARCH, PAGENO, None, 5.0
 | 
						|
        )
 | 
						|
        search = searx.search.Search(search_query)
 | 
						|
        with self.app.test_request_context('/search'):
 | 
						|
            search.search()
 | 
						|
        self.assertEqual(search.actual_timeout, 5.0)
 | 
						|
 | 
						|
    def test_timeout_query_above_max(self):
 | 
						|
        settings['outgoing']['max_request_timeout'] = 10.0
 | 
						|
        search_query = SearchQuery(
 | 
						|
            'test', [EngineRef(PUBLIC_ENGINE_NAME, 'general')], 'en-US', SAFESEARCH, PAGENO, None, 15.0
 | 
						|
        )
 | 
						|
        search = searx.search.Search(search_query)
 | 
						|
        with self.app.test_request_context('/search'):
 | 
						|
            search.search()
 | 
						|
        self.assertEqual(search.actual_timeout, 10.0)
 | 
						|
 | 
						|
    def test_external_bang(self):
 | 
						|
        search_query = SearchQuery(
 | 
						|
            'yes yes',
 | 
						|
            [EngineRef(PUBLIC_ENGINE_NAME, 'general')],
 | 
						|
            'en-US',
 | 
						|
            SAFESEARCH,
 | 
						|
            PAGENO,
 | 
						|
            None,
 | 
						|
            None,
 | 
						|
            external_bang="yt",
 | 
						|
        )
 | 
						|
        search = searx.search.Search(search_query)
 | 
						|
        results = search.search()
 | 
						|
        # For checking if the user redirected with the youtube external bang
 | 
						|
        self.assertTrue(results.redirect_url is not None)
 | 
						|
 | 
						|
        search_query = SearchQuery(
 | 
						|
            'youtube never gonna give you up',
 | 
						|
            [EngineRef(PUBLIC_ENGINE_NAME, 'general')],
 | 
						|
            'en-US',
 | 
						|
            SAFESEARCH,
 | 
						|
            PAGENO,
 | 
						|
            None,
 | 
						|
            None,
 | 
						|
        )
 | 
						|
 | 
						|
        search = searx.search.Search(search_query)
 | 
						|
        with self.app.test_request_context('/search'):
 | 
						|
            results = search.search()
 | 
						|
        # This should not redirect
 | 
						|
        self.assertTrue(results.redirect_url is None)
 |