summaryrefslogtreecommitdiff
path: root/tests
diff options
context:
space:
mode:
authorAlexandre Flament <alex@al-f.net>2021-09-02 16:01:34 +0200
committerAlexandre Flament <alex@al-f.net>2021-09-02 16:01:34 +0200
commitb9c73fb69784726608d1a2d72b7a17f777d30b9d (patch)
treee1446c28afb7c49328ae7f9279b11c072c5b52c6 /tests
parent065b4dab56bf3c374cab7896314168e9d3106171 (diff)
downloadsearxng-b9c73fb69784726608d1a2d72b7a17f777d30b9d.tar.gz
searxng-b9c73fb69784726608d1a2d72b7a17f777d30b9d.zip
[mod] move searx/testing.py to the tests directory
move robot tests to tests.robot manage calls "python -m tests.robot"
Diffstat (limited to 'tests')
-rw-r--r--tests/__init__.py42
-rw-r--r--tests/robot/__init__.py76
-rw-r--r--tests/robot/__main__.py78
-rw-r--r--tests/robot/settings_robot.yml62
-rw-r--r--tests/robot/test_webapp.py78
-rw-r--r--tests/unit/engines/test_command.py2
-rw-r--r--tests/unit/engines/test_xpath.py2
-rw-r--r--tests/unit/network/test_network.py2
-rw-r--r--tests/unit/test_answerers.py2
-rw-r--r--tests/unit/test_engines_init.py2
-rw-r--r--tests/unit/test_external_bangs.py2
-rw-r--r--tests/unit/test_plugins.py2
-rw-r--r--tests/unit/test_preferences.py2
-rw-r--r--tests/unit/test_query.py2
-rw-r--r--tests/unit/test_results.py2
-rw-r--r--tests/unit/test_search.py4
-rw-r--r--tests/unit/test_settings_loader.py2
-rw-r--r--tests/unit/test_standalone_searx.py2
-rw-r--r--tests/unit/test_utils.py3
-rw-r--r--tests/unit/test_webadapter.py2
-rw-r--r--tests/unit/test_webapp.py5
-rw-r--r--tests/unit/test_webutils.py2
22 files changed, 281 insertions, 95 deletions
diff --git a/tests/__init__.py b/tests/__init__.py
index cb43fc22a..d4b101cc4 100644
--- a/tests/__init__.py
+++ b/tests/__init__.py
@@ -1,5 +1,47 @@
import os
+import aiounittest
+
os.environ['SEARX_DEBUG'] = '1'
os.environ['SEARX_DISABLE_ETC_SETTINGS'] = '1'
os.environ.pop('SEARX_SETTINGS_PATH', None)
+
+
+class SearxTestLayer:
+ """Base layer for non-robot tests."""
+
+ __name__ = 'SearxTestLayer'
+
+ @classmethod
+ def setUp(cls):
+ pass
+
+ @classmethod
+ def tearDown(cls):
+ pass
+
+ @classmethod
+ def testSetUp(cls):
+ pass
+
+ @classmethod
+ def testTearDown(cls):
+ pass
+
+
+class SearxTestCase(aiounittest.AsyncTestCase):
+ """Base test case for non-robot tests."""
+
+ layer = SearxTestLayer
+
+ def setattr4test(self, obj, attr, value):
+ """
+ setattr(obj, attr, value)
+ but reset to the previous value in the cleanup.
+ """
+ previous_value = getattr(obj, attr)
+
+ def cleanup_patch():
+ setattr(obj, attr, previous_value)
+ self.addCleanup(cleanup_patch)
+ setattr(obj, attr, value)
diff --git a/tests/robot/__init__.py b/tests/robot/__init__.py
index 7c08a91bd..e69de29bb 100644
--- a/tests/robot/__init__.py
+++ b/tests/robot/__init__.py
@@ -1,76 +0,0 @@
-# -*- coding: utf-8 -*-
-
-from time import sleep
-
-url = "http://localhost:11111/"
-
-
-def test_index(browser):
- # Visit URL
- browser.visit(url)
- assert browser.is_text_present('about')
-
-
-def test_404(browser):
- # Visit URL
- browser.visit(url + 'missing_link')
- assert browser.is_text_present('Page not found')
-
-
-def test_about(browser):
- browser.visit(url)
- browser.click_link_by_text('about')
- assert browser.is_text_present('Why use it?')
-
-
-def test_preferences(browser):
- browser.visit(url)
- browser.click_link_by_text('preferences')
- assert browser.is_text_present('Preferences')
- assert browser.is_text_present('Cookies')
-
- assert browser.is_element_present_by_xpath('//label[@for="checkbox_dummy"]')
-
-
-def test_preferences_engine_select(browser):
- browser.visit(url)
- browser.click_link_by_text('preferences')
-
- assert browser.is_element_present_by_xpath('//a[@href="#tab_engine"]')
- browser.find_by_xpath('//a[@href="#tab_engine"]').first.click()
-
- assert not browser.find_by_xpath('//input[@id="engine_general_dummy__general"]').first.checked
- browser.find_by_xpath('//label[@for="engine_general_dummy__general"]').first.check()
- browser.find_by_xpath('//input[@value="save"]').first.click()
-
- # waiting for the redirect - without this the test is flaky..
- sleep(1)
-
- browser.visit(url)
- browser.click_link_by_text('preferences')
- browser.find_by_xpath('//a[@href="#tab_engine"]').first.click()
-
- assert browser.find_by_xpath('//input[@id="engine_general_dummy__general"]').first.checked
-
-
-def test_preferences_locale(browser):
- browser.visit(url)
- browser.click_link_by_text('preferences')
-
- browser.find_by_xpath('//a[@href="#tab_ui"]').first.click()
- browser.select('locale', 'hu')
- browser.find_by_xpath('//input[@value="save"]').first.click()
-
- # waiting for the redirect - without this the test is flaky..
- sleep(1)
-
- browser.visit(url)
- browser.click_link_by_text('beállítások')
- browser.is_text_present('Beállítások')
-
-
-def test_search(browser):
- browser.visit(url)
- browser.fill('q', 'test search query')
- browser.find_by_xpath('//button[@type="submit"]').first.click()
- assert browser.is_text_present('didn\'t find any results')
diff --git a/tests/robot/__main__.py b/tests/robot/__main__.py
new file mode 100644
index 000000000..e435f512a
--- /dev/null
+++ b/tests/robot/__main__.py
@@ -0,0 +1,78 @@
+# SPDX-License-Identifier: AGPL-3.0-or-later
+# lint: pylint
+"""Shared testing code."""
+
+# pylint: disable=missing-function-docstring
+
+import sys
+import os
+import subprocess
+import traceback
+import pathlib
+
+from splinter import Browser
+
+import tests as searx_tests
+from tests.robot import test_webapp
+
+
+class SearxRobotLayer():
+ """Searx Robot Test Layer"""
+
+ def setUp(self):
+ os.setpgrp() # create new process group, become its leader
+
+ tests_path = pathlib.Path(searx_tests.__file__).resolve().parent
+
+ # get program paths
+ webapp = str(tests_path.parent / 'searx' / 'webapp.py')
+ exe = 'python'
+
+ # The Flask app is started by Flask.run(...), don't enable Flask's debug
+ # mode, the debugger from Flask will cause wired process model, where
+ # the server never dies. Further read:
+ #
+ # - debug mode: https://flask.palletsprojects.com/quickstart/#debug-mode
+ # - Flask.run(..): https://flask.palletsprojects.com/api/#flask.Flask.run
+
+ os.environ['SEARX_DEBUG'] = '0'
+
+ # set robot settings path
+ os.environ['SEARX_SETTINGS_PATH'] = str(tests_path / 'robot' / 'settings_robot.yml')
+
+ # run the server
+ self.server = subprocess.Popen( # pylint: disable=consider-using-with
+ [exe, webapp],
+ stdout=subprocess.PIPE,
+ stderr=subprocess.STDOUT
+ )
+ if hasattr(self.server.stdout, 'read1'):
+ print(self.server.stdout.read1(1024).decode())
+
+ def tearDown(self):
+ os.kill(self.server.pid, 9)
+ # remove previously set environment variable
+ del os.environ['SEARX_SETTINGS_PATH']
+
+
+def run_robot_tests(tests):
+ print('Running {0} tests'.format(len(tests)))
+ for test in tests:
+ with Browser('firefox', headless=True, profile_preferences={'intl.accept_languages': 'en'}) as browser:
+ test(browser)
+
+
+def main():
+ test_layer = SearxRobotLayer()
+ try:
+ test_layer.setUp()
+ run_robot_tests([getattr(test_webapp, x) for x in dir(test_webapp) if x.startswith('test_')])
+ except Exception: # pylint: disable=broad-except
+ print('Error occured: {0}'.format(traceback.format_exc()))
+ sys.exit(1)
+ finally:
+ test_layer.tearDown()
+
+
+if __name__ == '__main__':
+ main()
diff --git a/tests/robot/settings_robot.yml b/tests/robot/settings_robot.yml
new file mode 100644
index 000000000..ca65449f7
--- /dev/null
+++ b/tests/robot/settings_robot.yml
@@ -0,0 +1,62 @@
+general:
+ debug: false
+ instance_name: "searx_test"
+
+brand:
+ git_url: https://github.com/searxng/searxng
+ git_branch: master
+ issue_url: https://github.com/searxng/searxng/issues
+ new_issue_url: https://github.com/searxng/searxng/issues/new
+ docs_url: https://searxng.github.io/searxng
+ public_instances: https://searx.space
+ wiki_url: https://github.com/searxng/searxng/wiki
+
+search:
+ language: "all"
+
+server:
+ port: 11111
+ bind_address: 127.0.0.1
+ secret_key: "changedultrasecretkey"
+ base_url: false
+ http_protocol_version: "1.0"
+
+ui:
+ static_path: ""
+ templates_path: ""
+ default_theme: oscar
+
+preferences:
+ lock: []
+
+outgoing:
+ request_timeout: 1.0 # seconds
+ useragent_suffix: ""
+
+engines:
+ - name: general dummy
+ engine: dummy
+ categories: general
+ shortcut: gd
+
+ - name: dummy dummy
+ engine: dummy
+ categories: dummy
+ shortcut: dd
+
+locales:
+ en: English
+ hu: Magyar
+
+doi_resolvers:
+ oadoi.org: 'https://oadoi.org/'
+ doi.org: 'https://doi.org/'
+ doai.io: 'https://dissem.in/'
+ sci-hub.se: 'https://sci-hub.se/'
+ sci-hub.do: 'https://sci-hub.do/'
+ scihubtw.tw: 'https://scihubtw.tw/'
+ sci-hub.st: 'https://sci-hub.st/'
+ sci-hub.bar: 'https://sci-hub.bar/'
+ sci-hub.it.nf: 'https://sci-hub.it.nf/'
+
+default_doi_resolver: 'oadoi.org'
diff --git a/tests/robot/test_webapp.py b/tests/robot/test_webapp.py
new file mode 100644
index 000000000..cc1550c36
--- /dev/null
+++ b/tests/robot/test_webapp.py
@@ -0,0 +1,78 @@
+# SPDX-License-Identifier: AGPL-3.0-or-later
+# lint: pylint
+# pylint: disable=missing-module-docstring,missing-function-docstring
+
+from time import sleep
+
+url = "http://localhost:11111/"
+
+
+def test_index(browser):
+ # Visit URL
+ browser.visit(url)
+ assert browser.is_text_present('about')
+
+
+def test_404(browser):
+ # Visit URL
+ browser.visit(url + 'missing_link')
+ assert browser.is_text_present('Page not found')
+
+
+def test_about(browser):
+ browser.visit(url)
+ browser.click_link_by_text('about')
+ assert browser.is_text_present('Why use it?')
+
+
+def test_preferences(browser):
+ browser.visit(url)
+ browser.click_link_by_text('preferences')
+ assert browser.is_text_present('Preferences')
+ assert browser.is_text_present('Cookies')
+
+ assert browser.is_element_present_by_xpath('//label[@for="checkbox_dummy"]')
+
+
+def test_preferences_engine_select(browser):
+ browser.visit(url)
+ browser.click_link_by_text('preferences')
+
+ assert browser.is_element_present_by_xpath('//a[@href="#tab_engine"]')
+ browser.find_by_xpath('//a[@href="#tab_engine"]').first.click()
+
+ assert not browser.find_by_xpath('//input[@id="engine_general_dummy__general"]').first.checked
+ browser.find_by_xpath('//label[@for="engine_general_dummy__general"]').first.check()
+ browser.find_by_xpath('//input[@value="save"]').first.click()
+
+ # waiting for the redirect - without this the test is flaky..
+ sleep(1)
+
+ browser.visit(url)
+ browser.click_link_by_text('preferences')
+ browser.find_by_xpath('//a[@href="#tab_engine"]').first.click()
+
+ assert browser.find_by_xpath('//input[@id="engine_general_dummy__general"]').first.checked
+
+
+def test_preferences_locale(browser):
+ browser.visit(url)
+ browser.click_link_by_text('preferences')
+
+ browser.find_by_xpath('//a[@href="#tab_ui"]').first.click()
+ browser.select('locale', 'hu')
+ browser.find_by_xpath('//input[@value="save"]').first.click()
+
+ # waiting for the redirect - without this the test is flaky..
+ sleep(1)
+
+ browser.visit(url)
+ browser.click_link_by_text('beállítások')
+ browser.is_text_present('Beállítások')
+
+
+def test_search(browser):
+ browser.visit(url)
+ browser.fill('q', 'test search query')
+ browser.find_by_xpath('//button[@type="submit"]').first.click()
+ assert browser.is_text_present('didn\'t find any results')
diff --git a/tests/unit/engines/test_command.py b/tests/unit/engines/test_command.py
index 8f88b617e..d2bb123f7 100644
--- a/tests/unit/engines/test_command.py
+++ b/tests/unit/engines/test_command.py
@@ -16,7 +16,7 @@ along with searx. If not, see < http://www.gnu.org/licenses/ >.
from searx.engines import command as command_engine
-from searx.testing import SearxTestCase
+from tests import SearxTestCase
class TestCommandEngine(SearxTestCase):
diff --git a/tests/unit/engines/test_xpath.py b/tests/unit/engines/test_xpath.py
index 963a44a25..287beeab4 100644
--- a/tests/unit/engines/test_xpath.py
+++ b/tests/unit/engines/test_xpath.py
@@ -2,7 +2,7 @@
from collections import defaultdict
import mock
from searx.engines import xpath
-from searx.testing import SearxTestCase
+from tests import SearxTestCase
class TestXpathEngine(SearxTestCase):
diff --git a/tests/unit/network/test_network.py b/tests/unit/network/test_network.py
index e8d33240a..0805edc19 100644
--- a/tests/unit/network/test_network.py
+++ b/tests/unit/network/test_network.py
@@ -5,7 +5,7 @@ from mock import patch
import httpx
from searx.network.network import Network, NETWORKS, initialize
-from searx.testing import SearxTestCase
+from tests import SearxTestCase
class TestNetwork(SearxTestCase):
diff --git a/tests/unit/test_answerers.py b/tests/unit/test_answerers.py
index 73d8d26f2..1119b697d 100644
--- a/tests/unit/test_answerers.py
+++ b/tests/unit/test_answerers.py
@@ -3,7 +3,7 @@
from mock import Mock
from searx.answerers import answerers
-from searx.testing import SearxTestCase
+from tests import SearxTestCase
class AnswererTest(SearxTestCase):
diff --git a/tests/unit/test_engines_init.py b/tests/unit/test_engines_init.py
index d2aee41f2..dffeaf8e8 100644
--- a/tests/unit/test_engines_init.py
+++ b/tests/unit/test_engines_init.py
@@ -1,5 +1,5 @@
-from searx.testing import SearxTestCase
from searx import settings, engines
+from tests import SearxTestCase
class TestEnginesInit(SearxTestCase):
diff --git a/tests/unit/test_external_bangs.py b/tests/unit/test_external_bangs.py
index 6a9686782..f320d3037 100644
--- a/tests/unit/test_external_bangs.py
+++ b/tests/unit/test_external_bangs.py
@@ -1,6 +1,6 @@
from searx.external_bang import get_node, resolve_bang_definition, get_bang_url, get_bang_definition_and_autocomplete
from searx.search import SearchQuery, EngineRef
-from searx.testing import SearxTestCase
+from tests import SearxTestCase
TEST_DB = {
diff --git a/tests/unit/test_plugins.py b/tests/unit/test_plugins.py
index 9ef4cd692..245a7566b 100644
--- a/tests/unit/test_plugins.py
+++ b/tests/unit/test_plugins.py
@@ -1,8 +1,8 @@
# -*- coding: utf-8 -*-
-from searx.testing import SearxTestCase
from searx import plugins
from mock import Mock
+from tests import SearxTestCase
def get_search_mock(query, **kwargs):
diff --git a/tests/unit/test_preferences.py b/tests/unit/test_preferences.py
index 510d4985a..903b9b54d 100644
--- a/tests/unit/test_preferences.py
+++ b/tests/unit/test_preferences.py
@@ -1,6 +1,6 @@
from searx.preferences import (EnumStringSetting, MapSetting, MissingArgumentException, SearchLanguageSetting,
MultipleChoiceSetting, PluginsSetting, ValidationException)
-from searx.testing import SearxTestCase
+from tests import SearxTestCase
class PluginStub:
diff --git a/tests/unit/test_query.py b/tests/unit/test_query.py
index dd7ff0766..edb0a18f7 100644
--- a/tests/unit/test_query.py
+++ b/tests/unit/test_query.py
@@ -1,7 +1,7 @@
from searx import settings
from searx.engines import load_engines
from searx.query import RawTextQuery
-from searx.testing import SearxTestCase
+from tests import SearxTestCase
TEST_ENGINES = [
diff --git a/tests/unit/test_results.py b/tests/unit/test_results.py
index 274b5b37a..07d170130 100644
--- a/tests/unit/test_results.py
+++ b/tests/unit/test_results.py
@@ -1,7 +1,7 @@
# -*- coding: utf-8 -*-
from searx.results import ResultContainer
-from searx.testing import SearxTestCase
+from tests import SearxTestCase
def fake_result(url='https://aa.bb/cc?dd=ee#ff',
diff --git a/tests/unit/test_search.py b/tests/unit/test_search.py
index b0988a0c8..c7f15a681 100644
--- a/tests/unit/test_search.py
+++ b/tests/unit/test_search.py
@@ -1,9 +1,9 @@
# -*- coding: utf-8 -*-
-from searx.testing import SearxTestCase
+import searx.search
from searx.search import SearchQuery, EngineRef
from searx import settings
-import searx.search
+from tests import SearxTestCase
SAFESEARCH = 0
diff --git a/tests/unit/test_settings_loader.py b/tests/unit/test_settings_loader.py
index a3257ee4b..ad9fc6e95 100644
--- a/tests/unit/test_settings_loader.py
+++ b/tests/unit/test_settings_loader.py
@@ -3,9 +3,9 @@
from os.path import dirname, join, abspath
from unittest.mock import patch
-from searx.testing import SearxTestCase
from searx.exceptions import SearxSettingsException
from searx import settings_loader
+from tests import SearxTestCase
test_dir = abspath(dirname(__file__))
diff --git a/tests/unit/test_standalone_searx.py b/tests/unit/test_standalone_searx.py
index a69353c03..a5f17c08f 100644
--- a/tests/unit/test_standalone_searx.py
+++ b/tests/unit/test_standalone_searx.py
@@ -8,8 +8,8 @@ from mock import Mock, patch
from nose2.tools import params
from searx.search import SearchQuery, EngineRef, initialize
-from searx.testing import SearxTestCase
from searx_extra import standalone_searx as sas
+from tests import SearxTestCase
class StandaloneSearx(SearxTestCase):
diff --git a/tests/unit/test_utils.py b/tests/unit/test_utils.py
index 91ec2499d..e9c247382 100644
--- a/tests/unit/test_utils.py
+++ b/tests/unit/test_utils.py
@@ -2,10 +2,11 @@
import lxml.etree
from lxml import html
-from searx.testing import SearxTestCase
from searx.exceptions import SearxXPathSyntaxException, SearxEngineXPathException
from searx import utils
+from tests import SearxTestCase
+
class TestUtils(SearxTestCase):
diff --git a/tests/unit/test_webadapter.py b/tests/unit/test_webadapter.py
index 32417f019..9d8ff5f28 100644
--- a/tests/unit/test_webadapter.py
+++ b/tests/unit/test_webadapter.py
@@ -1,12 +1,12 @@
# -*- coding: utf-8 -*-
-from searx.testing import SearxTestCase
from searx.preferences import Preferences
from searx.engines import engines
import searx.search
from searx.search import EngineRef
from searx.webadapter import validate_engineref_list
+from tests import SearxTestCase
PRIVATE_ENGINE_NAME = 'general private offline'
diff --git a/tests/unit/test_webapp.py b/tests/unit/test_webapp.py
index 8598113f7..c5ec1ca97 100644
--- a/tests/unit/test_webapp.py
+++ b/tests/unit/test_webapp.py
@@ -3,9 +3,10 @@
import json
from urllib.parse import ParseResult
from mock import Mock
-from searx.testing import SearxTestCase
-from searx.search import Search
+
import searx.search.processors
+from searx.search import Search
+from tests import SearxTestCase
class ViewsTestCase(SearxTestCase):
diff --git a/tests/unit/test_webutils.py b/tests/unit/test_webutils.py
index 023374b04..6da39a071 100644
--- a/tests/unit/test_webutils.py
+++ b/tests/unit/test_webutils.py
@@ -1,7 +1,7 @@
# -*- coding: utf-8 -*-
import mock
-from searx.testing import SearxTestCase
from searx import webutils
+from tests import SearxTestCase
class TestWebUtils(SearxTestCase):