summaryrefslogtreecommitdiff
path: root/tests/unit/test_plugin_calculator.py
diff options
context:
space:
mode:
Diffstat (limited to 'tests/unit/test_plugin_calculator.py')
-rw-r--r--tests/unit/test_plugin_calculator.py99
1 files changed, 0 insertions, 99 deletions
diff --git a/tests/unit/test_plugin_calculator.py b/tests/unit/test_plugin_calculator.py
deleted file mode 100644
index ca5c5d6c8..000000000
--- a/tests/unit/test_plugin_calculator.py
+++ /dev/null
@@ -1,99 +0,0 @@
-# SPDX-License-Identifier: AGPL-3.0-or-later
-# pylint: disable=missing-module-docstring,disable=missing-class-docstring,invalid-name
-
-import warnings
-
-from parameterized.parameterized import parameterized
-
-import searx.plugins
-import searx.preferences
-
-from searx.extended_types import sxng_request
-from searx.result_types import Answer
-
-from tests import SearxTestCase
-from .test_utils import random_string
-from .test_plugins import do_post_search
-
-
-# Reporting the DeprecationWarning once should be sufficient when running tests
-warnings.filterwarnings("once", category=DeprecationWarning)
-
-
-class PluginCalculator(SearxTestCase):
-
- def setUp(self):
- super().setUp()
- engines = {}
-
- self.storage = searx.plugins.PluginStorage()
- self.storage.load_settings({"searx.plugins.calculator.SXNGPlugin": {"active": True}})
- self.storage.init(self.app)
- self.pref = searx.preferences.Preferences(["simple"], ["general"], engines, self.storage)
- self.pref.parse_dict({"locale": "en"})
-
- def test_plugin_store_init(self):
- self.assertEqual(1, len(self.storage))
-
- def test_pageno_1_2(self):
- with self.app.test_request_context():
- sxng_request.preferences = self.pref
- query = "1+1"
- answer = Answer(answer=f"{query} = {eval(query)}") # pylint: disable=eval-used
-
- search = do_post_search(query, self.storage, pageno=1)
- self.assertIn(answer, search.result_container.answers)
-
- search = do_post_search(query, self.storage, pageno=2)
- self.assertEqual(list(search.result_container.answers), [])
-
- def test_long_query_ignored(self):
- with self.app.test_request_context():
- sxng_request.preferences = self.pref
- query = f"1+1 {random_string(101)}"
- search = do_post_search(query, self.storage)
- self.assertEqual(list(search.result_container.answers), [])
-
- @parameterized.expand(
- [
- ("1+1", "2", "en"),
- ("1-1", "0", "en"),
- ("1*1", "1", "en"),
- ("1/1", "1", "en"),
- ("1**1", "1", "en"),
- ("1^1", "1", "en"),
- ("1,000.0+1,000.0", "2,000", "en"),
- ("1.0+1.0", "2", "en"),
- ("1.0-1.0", "0", "en"),
- ("1.0*1.0", "1", "en"),
- ("1.0/1.0", "1", "en"),
- ("1.0**1.0", "1", "en"),
- ("1.0^1.0", "1", "en"),
- ("1.000,0+1.000,0", "2.000", "de"),
- ("1,0+1,0", "2", "de"),
- ("1,0-1,0", "0", "de"),
- ("1,0*1,0", "1", "de"),
- ("1,0/1,0", "1", "de"),
- ("1,0**1,0", "1", "de"),
- ("1,0^1,0", "1", "de"),
- ]
- )
- def test_localized_query(self, query: str, res: str, lang: str):
- with self.app.test_request_context():
- self.pref.parse_dict({"locale": lang})
- sxng_request.preferences = self.pref
- answer = Answer(answer=f"{query} = {res}")
-
- search = do_post_search(query, self.storage)
- self.assertIn(answer, search.result_container.answers)
-
- @parameterized.expand(
- [
- "1/0",
- ]
- )
- def test_invalid_operations(self, query):
- with self.app.test_request_context():
- sxng_request.preferences = self.pref
- search = do_post_search(query, self.storage)
- self.assertEqual(list(search.result_container.answers), [])