mirror of
				https://github.com/searxng/searxng.git
				synced 2025-11-03 19:17:07 -05:00 
			
		
		
		
	commit 2c6531b2 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 commit 2c6531b2 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>
		
			
				
	
	
		
			86 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			86 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)
 |