| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111 | test.help(){    cat <<EOFtest.:  yamllint  : lint YAML files (YAMLLINT_FILES)  pylint    : lint PYLINT_FILES, searx/engines, searx & tests  pyright   : static type check of python sources  black     : check black code format  unit      : run unit tests  coverage  : run unit tests with coverage  robot     : run robot test  rst       : test .rst files incl. README.rst  clean     : clean intermediate test stuffEOF}test.yamllint() {    build_msg TEST "[yamllint] \$YAMLLINT_FILES"    pyenv.cmd yamllint --strict --format parsable "${YAMLLINT_FILES[@]}"    dump_return $?}test.pylint() {    # shellcheck disable=SC2086    (   set -e        build_msg TEST "[pylint] \$PYLINT_FILES"        pyenv.activate        python ${PYLINT_OPTIONS} ${PYLINT_VERBOSE} \            --additional-builtins="${PYLINT_ADDITIONAL_BUILTINS_FOR_ENGINES}" \            "${PYLINT_FILES[@]}"        build_msg TEST "[pylint] searx/engines"        python ${PYLINT_OPTIONS} ${PYLINT_VERBOSE} \            --disable="${PYLINT_SEARXNG_DISABLE_OPTION}" \            --additional-builtins="${PYLINT_ADDITIONAL_BUILTINS_FOR_ENGINES}" \            searx/engines        build_msg TEST "[pylint] searx tests"        python ${PYLINT_OPTIONS} ${PYLINT_VERBOSE} \            --disable="${PYLINT_SEARXNG_DISABLE_OPTION}" \	    --ignore=searx/engines \	    searx tests    )    dump_return $?}test.pyright() {    build_msg TEST "[pyright] static type check of python sources"    node.env.dev    # We run Pyright in the virtual environment because Pyright    # executes "python" to determine the Python version.    build_msg TEST "[pyright] suppress warnings related to intentional monkey patching"    pyenv.cmd npx --no-install pyright -p pyrightconfig-ci.json \        | grep -v ".py$" \        | grep -v '/engines/.*.py.* - warning: "logger" is not defined'\        | grep -v '/plugins/.*.py.* - error: "logger" is not defined'\        | grep -v '/engines/.*.py.* - warning: "supported_languages" is not defined' \        | grep -v '/engines/.*.py.* - warning: "language_aliases" is not defined' \        | grep -v '/engines/.*.py.* - warning: "categories" is not defined'    dump_return $?}test.black() {    build_msg TEST "[black] \$BLACK_TARGETS"    pyenv.cmd black --check --diff "${BLACK_OPTIONS[@]}" "${BLACK_TARGETS[@]}"    dump_return $?}test.unit() {    build_msg TEST 'tests/unit'    pyenv.cmd python -m nose2 -s tests/unit    dump_return $?}test.coverage() {    build_msg TEST 'unit test coverage'    (   set -e        pyenv.activate        python -m nose2 -C --log-capture --with-coverage --coverage searx -s tests/unit        coverage report        coverage html    )    dump_return $?}test.robot() {    build_msg TEST 'robot'    gecko.driver    PYTHONPATH=. pyenv.cmd python -m tests.robot    dump_return $?}test.rst() {    build_msg TEST "[reST markup] ${RST_FILES[*]}"    for rst in "${RST_FILES[@]}"; do        pyenv.cmd rst2html.py --halt error "$rst" > /dev/null || die 42 "fix issue in $rst"    done}test.pybabel() {    TEST_BABEL_FOLDER="build/test/pybabel"    build_msg TEST "[extract messages] pybabel"    mkdir -p "${TEST_BABEL_FOLDER}"    pyenv.cmd pybabel extract -F babel.cfg -o "${TEST_BABEL_FOLDER}/messages.pot" searx}test.clean() {    build_msg CLEAN  "test stuff"    rm -rf geckodriver.log .coverage coverage/    dump_return $?}
 |