summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAlexandre Flament <alex@al-f.net>2021-02-25 17:42:52 +0100
committerAlexandre Flament <alex@al-f.net>2021-03-04 11:59:14 +0100
commitb8cd3264644208d7afa1a239f829222d45226334 (patch)
treeabbbd7fe188e7837f8351935ec47877799bc9474
parent111d38cd8fe35365cab2121a362bd17159c66d3f (diff)
downloadsearxng-b8cd3264644208d7afa1a239f829222d45226334.tar.gz
searxng-b8cd3264644208d7afa1a239f829222d45226334.zip
Add searx_extra package
Split the utils directory into: * searx_extra contains update scripts, standalone_searx.py * utils contains the files to build and setup searx.
-rw-r--r--.github/workflows/data-update.yml16
-rw-r--r--Makefile4
-rw-r--r--docs/index.rst1
-rw-r--r--docs/searx_extra/index.rst14
-rw-r--r--docs/searx_extra/standalone_searx.py.rst9
-rw-r--r--docs/utils/index.rst10
-rw-r--r--docs/utils/standalone_searx.py.rst11
-rw-r--r--searx_extra/__init__.py0
-rw-r--r--searx_extra/google_search.py (renamed from utils/google_search.py)0
-rwxr-xr-xsearx_extra/standalone_searx.py (renamed from utils/standalone_searx.py)2
-rw-r--r--searx_extra/update/__init__.py0
-rwxr-xr-xsearx_extra/update/update_ahmia_blacklist.py (renamed from utils/fetch_ahmia_blacklist.py)5
-rwxr-xr-x[-rw-r--r--]searx_extra/update/update_currencies.py (renamed from utils/fetch_currencies.py)1
-rwxr-xr-x[-rw-r--r--]searx_extra/update/update_engine_descriptions.py (renamed from utils/fetch_engine_descriptions.py)6
-rwxr-xr-xsearx_extra/update/update_external_bangs.py (renamed from utils/fetch_external_bangs.py)6
-rwxr-xr-xsearx_extra/update/update_firefox_version.py (renamed from utils/fetch_firefox_version.py)7
-rwxr-xr-x[-rw-r--r--]searx_extra/update/update_languages.py (renamed from utils/fetch_languages.py)4
-rwxr-xr-xsearx_extra/update/update_translations.sh (renamed from utils/update-translations.sh)0
-rwxr-xr-x[-rw-r--r--]searx_extra/update/update_wikidata_units.py (renamed from utils/fetch_wikidata_units.py)4
-rw-r--r--setup.py2
-rw-r--r--tests/unit/test_standalone_searx.py20
21 files changed, 47 insertions, 75 deletions
diff --git a/.github/workflows/data-update.yml b/.github/workflows/data-update.yml
index c9c6b29a4..eb9bed8c8 100644
--- a/.github/workflows/data-update.yml
+++ b/.github/workflows/data-update.yml
@@ -11,12 +11,12 @@ jobs:
strategy:
matrix:
fetch:
- - ahmia_blacklist
- - currencies
- - external_bangs
- - firefox_version
- - languages
- - wikidata_units
+ - update_ahmia_blacklist.py
+ - update_currencies.py
+ - update_external_bangs.py
+ - update_firefox_version.py
+ - update_languages.py
+ - update_wikidata_units.py
steps:
- name: Checkout
uses: actions/checkout@v2
@@ -45,10 +45,10 @@ jobs:
- name: Fetch data
env:
- FETCH_SCRIPT: utils/fetch_${{ matrix.fetch }}.py
+ FETCH_SCRIPT: ./searx_extra/update/${{ matrix.fetch }}
run: |
source local/py3/bin/activate
- python $FETCH_SCRIPT
+ $FETCH_SCRIPT
- name: Create Pull Request
id: cpr
diff --git a/Makefile b/Makefile
index 4e451b7ca..9917da78b 100644
--- a/Makefile
+++ b/Makefile
@@ -195,8 +195,8 @@ PYLINT_FILES=\
searx/engines/google_videos.py \
searx/engines/google_images.py \
searx/engines/mediathekviewweb.py \
- utils/fetch_external_bangs.py \
- searx/engines/google_scholar.py
+ searx/engines/google_scholar.py \
+ searx_extra/update/update_external_bangs.py
test.pylint: pyenvinstall
$(call cmd,pylint,$(PYLINT_FILES))
diff --git a/docs/index.rst b/docs/index.rst
index 9e590867c..a406da197 100644
--- a/docs/index.rst
+++ b/docs/index.rst
@@ -30,6 +30,7 @@ anyone, you can set up your own, see :ref:`installation`.
user/index
admin/index
dev/index
+ searx_extra/index
utils/index
blog/index
diff --git a/docs/searx_extra/index.rst b/docs/searx_extra/index.rst
new file mode 100644
index 000000000..64d0b9047
--- /dev/null
+++ b/docs/searx_extra/index.rst
@@ -0,0 +1,14 @@
+.. _searx_extra:
+
+======================================================
+Tooling box ``searx_extra`` for developers and users
+======================================================
+
+In the folder :origin:`searx_extra/` we maintain some tools useful for
+developers and users.
+
+.. toctree::
+ :maxdepth: 2
+ :caption: Contents
+
+ standalone_searx.py
diff --git a/docs/searx_extra/standalone_searx.py.rst b/docs/searx_extra/standalone_searx.py.rst
new file mode 100644
index 000000000..ff4b53387
--- /dev/null
+++ b/docs/searx_extra/standalone_searx.py.rst
@@ -0,0 +1,9 @@
+
+.. _standalone_searx.py:
+
+===================================
+``searx_extra/standalone_searx.py``
+===================================
+
+.. automodule:: searx_extra.standalone_searx
+ :members:
diff --git a/docs/utils/index.rst b/docs/utils/index.rst
index 28515318f..32baa5704 100644
--- a/docs/utils/index.rst
+++ b/docs/utils/index.rst
@@ -1,12 +1,11 @@
.. _searx_utils:
.. _toolboxing:
-=======================
-Tooling box ``utils/*``
-=======================
+========================================
+Tooling box ``utils`` for administrators
+========================================
-In the folder :origin:`utils/` we maintain some tools useful for admins and
-developers.
+In the folder :origin:`utils/` we maintain some tools useful for administrators.
.. toctree::
:maxdepth: 2
@@ -16,7 +15,6 @@ developers.
filtron.sh
morty.sh
lxc.sh
- standalone_searx.py
.. _toolboxing common:
diff --git a/docs/utils/standalone_searx.py.rst b/docs/utils/standalone_searx.py.rst
deleted file mode 100644
index 557c4b75b..000000000
--- a/docs/utils/standalone_searx.py.rst
+++ /dev/null
@@ -1,11 +0,0 @@
-
-.. _standalone_searx.py:
-
-=============================
-``utils/standalone_searx.py``
-=============================
-
-.. automodule:: standalone_searx
- :members:
-
-
diff --git a/searx_extra/__init__.py b/searx_extra/__init__.py
new file mode 100644
index 000000000..e69de29bb
--- /dev/null
+++ b/searx_extra/__init__.py
diff --git a/utils/google_search.py b/searx_extra/google_search.py
index cad32eeca..cad32eeca 100644
--- a/utils/google_search.py
+++ b/searx_extra/google_search.py
diff --git a/utils/standalone_searx.py b/searx_extra/standalone_searx.py
index 89023f41b..f52b7e80c 100755
--- a/utils/standalone_searx.py
+++ b/searx_extra/standalone_searx.py
@@ -15,7 +15,7 @@ Example to use this script:
.. code:: bash
- $ python3 utils/standalone_searx.py rain
+ $ python3 searx_extra/standalone_searx.py rain
Example to run it from python:
diff --git a/searx_extra/update/__init__.py b/searx_extra/update/__init__.py
new file mode 100644
index 000000000..e69de29bb
--- /dev/null
+++ b/searx_extra/update/__init__.py
diff --git a/utils/fetch_ahmia_blacklist.py b/searx_extra/update/update_ahmia_blacklist.py
index 3e393edbe..f645880e6 100755
--- a/utils/fetch_ahmia_blacklist.py
+++ b/searx_extra/update/update_ahmia_blacklist.py
@@ -4,11 +4,8 @@
# More info in https://ahmia.fi/blacklist/
# set path
-from sys import path
-from os.path import realpath, dirname, join
-path.append(realpath(dirname(realpath(__file__)) + '/../'))
+from os.path import join
-#
import requests
from searx import searx_dir
diff --git a/utils/fetch_currencies.py b/searx_extra/update/update_currencies.py
index 8811049a5..0cfb7a951 100644..100755
--- a/utils/fetch_currencies.py
+++ b/searx_extra/update/update_currencies.py
@@ -7,7 +7,6 @@ import json
# set path
from sys import path
from os.path import realpath, dirname, join
-path.append(realpath(dirname(realpath(__file__)) + '/../'))
from searx import searx_dir, settings
from searx.engines.wikidata import send_wikidata_query
diff --git a/utils/fetch_engine_descriptions.py b/searx_extra/update/update_engine_descriptions.py
index 9ca001d45..109fdbfa0 100644..100755
--- a/utils/fetch_engine_descriptions.py
+++ b/searx_extra/update/update_engine_descriptions.py
@@ -3,13 +3,9 @@
import sys
import json
from urllib.parse import quote, urlparse
-from os.path import realpath, dirname
-import cld3
+import detect_language
from lxml.html import fromstring
-# set path
-sys.path.append(realpath(dirname(realpath(__file__)) + '/../'))
-
from searx.engines.wikidata import send_wikidata_query
from searx.utils import extract_text
import searx
diff --git a/utils/fetch_external_bangs.py b/searx_extra/update/update_external_bangs.py
index ba6f51e7a..e9dc0ff1d 100755
--- a/utils/fetch_external_bangs.py
+++ b/searx_extra/update/update_external_bangs.py
@@ -13,16 +13,12 @@ but most probably it will requires to update RE_BANG_VERSION
"""
# pylint: disable=C0116
-import sys
import json
import re
-from os.path import realpath, dirname, join
+from os.path import join
import requests
-# set path
-sys.path.append(realpath(dirname(realpath(__file__)) + '/../'))
-
from searx import searx_dir # pylint: disable=E0401 C0413
diff --git a/utils/fetch_firefox_version.py b/searx_extra/update/update_firefox_version.py
index 997a752b3..6acfe76ce 100755
--- a/utils/fetch_firefox_version.py
+++ b/searx_extra/update/update_firefox_version.py
@@ -1,14 +1,9 @@
#!/usr/bin/env python
-# set path
-from sys import path
-from os.path import realpath, dirname, join
-path.append(realpath(dirname(realpath(__file__)) + '/../'))
-
-#
import json
import requests
import re
+from os.path import dirname, join
from urllib.parse import urlparse, urljoin
from distutils.version import LooseVersion, StrictVersion
from lxml import html
diff --git a/utils/fetch_languages.py b/searx_extra/update/update_languages.py
index 582e0ae00..e63282586 100644..100755
--- a/utils/fetch_languages.py
+++ b/searx_extra/update/update_languages.py
@@ -1,4 +1,4 @@
-# -*- coding: utf-8 -*-
+#!/usr/bin/env python
# This script generates languages.py from intersecting each engine's supported languages.
#
@@ -7,11 +7,9 @@
import json
from pathlib import Path
from pprint import pformat
-from sys import path
from babel import Locale, UnknownLocaleError
from babel.languages import get_global
-path.append('../searx') # noqa
from searx import settings, searx_dir
from searx.engines import initialize_engines, engines
diff --git a/utils/update-translations.sh b/searx_extra/update/update_translations.sh
index 240387ae7..240387ae7 100755
--- a/utils/update-translations.sh
+++ b/searx_extra/update/update_translations.sh
diff --git a/utils/fetch_wikidata_units.py b/searx_extra/update/update_wikidata_units.py
index 69ae8ab27..1e6b8b9ca 100644..100755
--- a/utils/fetch_wikidata_units.py
+++ b/searx_extra/update/update_wikidata_units.py
@@ -4,9 +4,7 @@ import json
import collections
# set path
-from sys import path
-from os.path import realpath, dirname, join
-path.append(realpath(dirname(realpath(__file__)) + '/../'))
+from os.path import join
from searx import searx_dir
from searx.engines.wikidata import send_wikidata_query
diff --git a/setup.py b/setup.py
index 09a3021ee..61227d199 100644
--- a/setup.py
+++ b/setup.py
@@ -41,7 +41,7 @@ setup(
author='Adam Tauber',
author_email='asciimoo@gmail.com',
license='GNU Affero General Public License',
- packages=find_packages(exclude=["tests*"]),
+ packages=find_packages(exclude=["tests*", "searx_extra"]),
zip_safe=False,
install_requires=requirements,
extras_require={
diff --git a/tests/unit/test_standalone_searx.py b/tests/unit/test_standalone_searx.py
index 6cc230e6c..a69353c03 100644
--- a/tests/unit/test_standalone_searx.py
+++ b/tests/unit/test_standalone_searx.py
@@ -1,7 +1,6 @@
# -*- coding: utf-8 -*-
"""Test utils/standalone_searx.py"""
import datetime
-import importlib.util
import io
import sys
@@ -10,16 +9,7 @@ from nose2.tools import params
from searx.search import SearchQuery, EngineRef, initialize
from searx.testing import SearxTestCase
-
-
-def get_standalone_searx_module():
- """Get standalone_searx module."""
- module_name = 'utils.standalone_searx'
- filename = 'utils/standalone_searx.py'
- spec = importlib.util.spec_from_file_location(module_name, filename)
- sas = importlib.util.module_from_spec(spec)
- spec.loader.exec_module(sas)
- return sas
+from searx_extra import standalone_searx as sas
class StandaloneSearx(SearxTestCase):
@@ -33,7 +23,6 @@ class StandaloneSearx(SearxTestCase):
def test_parse_argument_no_args(self):
"""Test parse argument without args."""
- sas = get_standalone_searx_module()
with patch.object(sys, 'argv', ['standalone_searx']), \
self.assertRaises(SystemExit):
sys.stderr = io.StringIO()
@@ -42,7 +31,6 @@ class StandaloneSearx(SearxTestCase):
def test_parse_argument_basic_args(self):
"""Test parse argument with basic args."""
- sas = get_standalone_searx_module()
query = 'red box'
exp_dict = {
'query': query, 'category': 'general', 'lang': 'all', 'pageno': 1,
@@ -56,7 +44,6 @@ class StandaloneSearx(SearxTestCase):
def test_to_dict(self):
"""test to_dict."""
- sas = get_standalone_searx_module()
self.assertEqual(
sas.to_dict(
sas.get_search_query(sas.parse_argument(['red box']))),
@@ -72,7 +59,6 @@ class StandaloneSearx(SearxTestCase):
def test_to_dict_with_mock(self):
"""test to dict."""
- sas = get_standalone_searx_module()
with patch.object(sas.searx.search, 'Search') as mock_s:
m_search = mock_s().search()
m_sq = Mock()
@@ -97,7 +83,6 @@ class StandaloneSearx(SearxTestCase):
def test_get_search_query(self):
"""test get_search_query."""
- sas = get_standalone_searx_module()
args = sas.parse_argument(['rain', ])
search_q = sas.get_search_query(args)
self.assertTrue(search_q)
@@ -106,7 +91,6 @@ class StandaloneSearx(SearxTestCase):
def test_no_parsed_url(self):
"""test no_parsed_url func"""
- sas = get_standalone_searx_module()
self.assertEqual(
sas.no_parsed_url([{'parsed_url': 'http://example.com'}]),
[{}]
@@ -119,11 +103,9 @@ class StandaloneSearx(SearxTestCase):
)
def test_json_serial(self, arg, exp_res):
"""test json_serial func"""
- sas = get_standalone_searx_module()
self.assertEqual(sas.json_serial(arg), exp_res)
def test_json_serial_error(self):
"""test error on json_serial."""
- sas = get_standalone_searx_module()
with self.assertRaises(TypeError):
sas.json_serial('a')