summaryrefslogtreecommitdiff
path: root/tests/unit
diff options
context:
space:
mode:
Diffstat (limited to 'tests/unit')
-rw-r--r--tests/unit/settings/test_settings.yml5
-rw-r--r--tests/unit/test_search.py24
-rw-r--r--tests/unit/test_standalone_searx.py113
-rw-r--r--tests/unit/test_webapp.py4
4 files changed, 24 insertions, 122 deletions
diff --git a/tests/unit/settings/test_settings.yml b/tests/unit/settings/test_settings.yml
index a975c8739..e08105853 100644
--- a/tests/unit/settings/test_settings.yml
+++ b/tests/unit/settings/test_settings.yml
@@ -3,3 +3,8 @@
use_default_settings: true
search:
formats: [html, csv, json, rss]
+
+engines:
+ - name: general dummy
+ engine: demo_offline
+ timeout: 3
diff --git a/tests/unit/test_search.py b/tests/unit/test_search.py
index 33bf90840..11cb8d4e4 100644
--- a/tests/unit/test_search.py
+++ b/tests/unit/test_search.py
@@ -43,6 +43,12 @@ class SearchQueryTestCase(SearxTestCase):
class SearchTestCase(SearxTestCase):
+ def setUp(self):
+
+ from searx import webapp # pylint disable=import-outside-toplevel
+
+ self.app = webapp.app
+
@classmethod
def setUpClass(cls):
searx.search.initialize(TEST_ENGINES)
@@ -53,7 +59,8 @@ class SearchTestCase(SearxTestCase):
'test', [EngineRef(PUBLIC_ENGINE_NAME, 'general')], 'en-US', SAFESEARCH, PAGENO, None, None
)
search = searx.search.Search(search_query)
- search.search()
+ with self.app.test_request_context('/search'):
+ search.search()
self.assertEqual(search.actual_timeout, 3.0)
def test_timeout_query_above_default_nomax(self):
@@ -62,7 +69,8 @@ class SearchTestCase(SearxTestCase):
'test', [EngineRef(PUBLIC_ENGINE_NAME, 'general')], 'en-US', SAFESEARCH, PAGENO, None, 5.0
)
search = searx.search.Search(search_query)
- search.search()
+ with self.app.test_request_context('/search'):
+ search.search()
self.assertEqual(search.actual_timeout, 3.0)
def test_timeout_query_below_default_nomax(self):
@@ -71,7 +79,8 @@ class SearchTestCase(SearxTestCase):
'test', [EngineRef(PUBLIC_ENGINE_NAME, 'general')], 'en-US', SAFESEARCH, PAGENO, None, 1.0
)
search = searx.search.Search(search_query)
- search.search()
+ with self.app.test_request_context('/search'):
+ search.search()
self.assertEqual(search.actual_timeout, 1.0)
def test_timeout_query_below_max(self):
@@ -80,7 +89,8 @@ class SearchTestCase(SearxTestCase):
'test', [EngineRef(PUBLIC_ENGINE_NAME, 'general')], 'en-US', SAFESEARCH, PAGENO, None, 5.0
)
search = searx.search.Search(search_query)
- search.search()
+ with self.app.test_request_context('/search'):
+ search.search()
self.assertEqual(search.actual_timeout, 5.0)
def test_timeout_query_above_max(self):
@@ -89,7 +99,8 @@ class SearchTestCase(SearxTestCase):
'test', [EngineRef(PUBLIC_ENGINE_NAME, 'general')], 'en-US', SAFESEARCH, PAGENO, None, 15.0
)
search = searx.search.Search(search_query)
- search.search()
+ with self.app.test_request_context('/search'):
+ search.search()
self.assertEqual(search.actual_timeout, 10.0)
def test_external_bang(self):
@@ -119,6 +130,7 @@ class SearchTestCase(SearxTestCase):
)
search = searx.search.Search(search_query)
- results = search.search()
+ with self.app.test_request_context('/search'):
+ results = search.search()
# This should not redirect
self.assertTrue(results.redirect_url is None)
diff --git a/tests/unit/test_standalone_searx.py b/tests/unit/test_standalone_searx.py
deleted file mode 100644
index 6a450485f..000000000
--- a/tests/unit/test_standalone_searx.py
+++ /dev/null
@@ -1,113 +0,0 @@
-# -*- coding: utf-8 -*-
-"""Test utils/standalone_searx.py"""
-import datetime
-import io
-import sys
-
-from mock import Mock, patch
-from nose2.tools import params
-
-from searx.search import SearchQuery, EngineRef, initialize
-from searxng_extra import standalone_searx as sas
-from tests import SearxTestCase
-
-
-class StandaloneSearx(SearxTestCase):
- """Unit test for standalone_searx."""
-
- @classmethod
- def setUpClass(cls):
- engine_list = [{'engine': 'dummy', 'name': 'engine1', 'shortcut': 'e1'}]
-
- initialize(engine_list)
-
- def test_parse_argument_no_args(self):
- """Test parse argument without args."""
- with patch.object(sys, 'argv', ['standalone_searx']), self.assertRaises(SystemExit):
- sys.stderr = io.StringIO()
- sas.parse_argument()
- sys.stdout = sys.__stderr__
-
- def test_parse_argument_basic_args(self):
- """Test parse argument with basic args."""
- query = 'red box'
- exp_dict = {
- 'query': query,
- 'category': 'general',
- 'lang': 'all',
- 'pageno': 1,
- 'safesearch': '0',
- 'timerange': None,
- }
- args = ['standalone_searx', query]
- with patch.object(sys, 'argv', args):
- res = sas.parse_argument()
- self.assertEqual(exp_dict, vars(res))
- res2 = sas.parse_argument(args[1:])
- self.assertEqual(exp_dict, vars(res2))
-
- def test_to_dict(self):
- """test to_dict."""
- self.assertEqual(
- sas.to_dict(sas.get_search_query(sas.parse_argument(['red box']))),
- {
- 'search': {'q': 'red box', 'pageno': 1, 'lang': 'all', 'safesearch': 0, 'timerange': None},
- 'results': [],
- 'infoboxes': [],
- 'suggestions': [],
- 'answers': [],
- 'paging': False,
- 'number_of_results': 0,
- },
- )
-
- def test_to_dict_with_mock(self):
- """test to dict."""
- with patch.object(sas.searx.search, 'Search') as mock_s:
- m_search = mock_s().search()
- m_sq = Mock()
- self.assertEqual(
- sas.to_dict(m_sq),
- {
- 'answers': [],
- 'infoboxes': m_search.infoboxes,
- 'paging': m_search.paging,
- 'results': m_search.get_ordered_results(),
- 'number_of_results': m_search.number_of_results,
- 'search': {
- 'lang': m_sq.lang,
- 'pageno': m_sq.pageno,
- 'q': m_sq.query,
- 'safesearch': m_sq.safesearch,
- 'timerange': m_sq.time_range,
- },
- 'suggestions': [],
- },
- )
-
- def test_get_search_query(self):
- """test get_search_query."""
- args = sas.parse_argument(
- [
- 'rain',
- ]
- )
- search_q = sas.get_search_query(args)
- self.assertTrue(search_q)
- self.assertEqual(
- search_q, SearchQuery('rain', [EngineRef('engine1', 'general')], 'all', 0, 1, None, None, None)
- )
-
- def test_no_parsed_url(self):
- """test no_parsed_url func"""
- self.assertEqual(sas.no_parsed_url([{'parsed_url': 'http://example.com'}]), [{}])
-
- @params((datetime.datetime(2020, 1, 1), '2020-01-01T00:00:00'), ('a'.encode('utf8'), 'a'), (set([1]), [1]))
- def test_json_serial(self, arg, exp_res):
- """test json_serial func"""
- self.assertEqual(sas.json_serial(arg), exp_res)
-
- def test_json_serial_error(self):
- """test error on json_serial."""
- with self.assertRaises(TypeError):
- sas.json_serial('a')
diff --git a/tests/unit/test_webapp.py b/tests/unit/test_webapp.py
index 948b40aee..e3ca0e261 100644
--- a/tests/unit/test_webapp.py
+++ b/tests/unit/test_webapp.py
@@ -198,9 +198,7 @@ class ViewsTestCase(SearxTestCase):
result = self.app.get('/preferences')
self.assertEqual(result.status_code, 200)
self.assertIn(b'<form id="search_form" method="post" action="/preferences"', result.data)
- self.assertIn(
- b'<input type="checkbox" id="checkbox_general" name="category_general" checked="checked"/>', result.data
- )
+ self.assertIn(b'<div id="categories_container">', result.data)
self.assertIn(b'<legend id="pref_ui_locale">Interface language</legend>', result.data)
def test_browser_locale(self):