summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMarkus Heiser <markus.heiser@darmarit.de>2020-03-26 18:41:45 +0100
committerMarkus Heiser <markus.heiser@darmarit.de>2020-03-26 18:41:45 +0100
commit1075f58a722fad7801a7b8397cd7e6de31d99da2 (patch)
tree661e277342c404201fa57ed4fb3d72a0eaabeaa6
parente7fbefa8bdecca04824b3ef744786d8bb45c35fe (diff)
test: move tests from manage.sh to Makefile
Signed-off-by: Markus Heiser <markus.heiser@darmarit.de>
-rw-r--r--Makefile47
-rwxr-xr-xmanage.sh42
2 files changed, 36 insertions, 53 deletions
diff --git a/Makefile b/Makefile
index 8b760093b..fe65acade 100644
--- a/Makefile
+++ b/Makefile
@@ -43,7 +43,7 @@ PHONY += uninstall
uninstall: pyenvuninstall
PHONY += clean
-clean: pyclean node.clean
+clean: pyclean node.clean test.clean
$(call cmd,common_clean)
PHONY += run
@@ -160,27 +160,52 @@ PHONY += docker
docker:
$(Q)./manage.sh docker_build
+# gecko
+# -----
+
+PHONY += gecko.driver
+gecko.driver:
+ $(PY_ENV_ACT); ./manage.sh install_geckodriver
# test
# ----
-PHONY += test test.pylint test.pep8 test.unit test.robot
+PHONY += test test.pylint test.pep8 test.unit test.coverage test.robot
-test: test.pylint test.pep8 test.unit test.robot
+test: test.pylint test.pep8 test.unit gecko.driver test.robot
# TODO: balance linting with pylint
test.pylint: pyenvinstall
- $(call cmd,pylint,searx/preferences.py)
- $(call cmd,pylint,searx/testing.py)
+ $(call cmd,pylint,\
+ searx/preferences.py \
+ searx/testing.py \
+ )
+
+# ignored rules:
+# E402 module level import not at top of file
+# W503 line break before binary operator
test.pep8: pyenvinstall
- $(PY_ENV_ACT); ./manage.sh pep8_check
+ @echo "TEST pep8"
+ $(Q)$(PY_ENV_ACT); pep8 --exclude=searx/static --max-line-length=120 --ignore "E402,W503" searx tests
test.unit: pyenvinstall
- $(PY_ENV_ACT); ./manage.sh unit_tests
-
-test.robot: pyenvinstall
- $(PY_ENV_ACT); ./manage.sh install_geckodriver
- $(PY_ENV_ACT); ./manage.sh robot_tests
+ @echo "TEST tests/unit"
+ $(Q)$(PY_ENV_ACT); python -m nose2 -s tests/unit
+
+test.coverage: pyenvinstall
+ @echo "TEST unit test coverage"
+ $(Q)$(PY_ENV_ACT); \
+ python -m nose2 -C --log-capture --with-coverage --coverage searx -s tests/unit \
+ && coverage report \
+ && coverage html \
+
+test.robot: pyenvinstall gecko.driver
+ @echo "TEST robot"
+ $(Q)$(PY_ENV_ACT); PYTHONPATH=. python searx/testing.py robot
+
+test.clean:
+ @echo "CLEAN intermediate test stuff"
+ $(Q)rm -rf geckodriver.log .coverage coverage/
.PHONY: $(PHONY)
diff --git a/manage.sh b/manage.sh
index 4f46fd6d7..6667274b1 100755
--- a/manage.sh
+++ b/manage.sh
@@ -70,40 +70,6 @@ locales() {
pybabel compile -d "$SEARX_DIR/translations"
}
-pep8_check() {
- echo '[!] Running pep8 check'
- # ignored rules:
- # E402 module level import not at top of file
- # W503 line break before binary operator
- pep8 --exclude=searx/static --max-line-length=120 --ignore "E402,W503" "$SEARX_DIR" "$BASE_DIR/tests"
-}
-
-unit_tests() {
- echo '[!] Running unit tests'
- python -m nose2 -s "$BASE_DIR/tests/unit"
-}
-
-py_test_coverage() {
- echo '[!] Running python test coverage'
- PYTHONPATH="`pwd`" python -m nose2 -C --log-capture --with-coverage --coverage "$SEARX_DIR" -s "$BASE_DIR/tests/unit" \
- && coverage report \
- && coverage html
-}
-
-robot_tests() {
- echo '[!] Running robot tests'
- PYTHONPATH="`pwd`" python "$SEARX_DIR/testing.py" robot
-}
-
-tests() {
- set -e
- pep8_check
- unit_tests
- install_geckodriver
- robot_tests
- set +e
-}
-
#
# Web
@@ -220,14 +186,6 @@ Commands
Build
-----
locales - Compile locales
-
- Tests
- -----
- unit_tests - Run unit tests
- pep8_check - Pep8 validation
- robot_tests - Run selenium tests
- tests - Run all python tests (pep8, unit, robot_tests)
- py_test_coverage - Unit test coverage
"
}