#!/bin/sh # author: deadc0de6 (https://github.com/deadc0de6) # Copyright (c) 2017, deadc0de6 # stop on first error #set -ev set -e # versions echo "pylint version:" pylint --version echo "pycodestyle version:" pycodestyle --version echo "pyflakes version:" pyflakes --version # PEP8 tests which pycodestyle >/dev/null 2>&1 [ "$?" != "0" ] && echo "Install pycodestyle" && exit 1 echo "testing with pycodestyle" pycodestyle --ignore=W503,W504,W605 dotdrop/ pycodestyle tests/ pycodestyle scripts/ # pyflakes tests echo "testing with pyflakes" pyflakes dotdrop/ pyflakes tests/ # pylint echo "testing with pylint" pylint \ --disable=R0902 \ --disable=R0913 \ --disable=R0903 \ --disable=R0914 \ --disable=R0915 \ --disable=R0912 \ --disable=R0911 \ --disable=R1732 \ --disable=C0209 \ dotdrop/ # retrieve the nosetests binary nosebin="nosetests" which ${nosebin} >/dev/null 2>&1 [ "$?" != "0" ] && nosebin="nosetests3" which ${nosebin} >/dev/null 2>&1 [ "$?" != "0" ] && echo "Install nosetests" && exit 1 echo "nose version:" ${nosebin} --version # do not print debugs when running tests (faster) export DOTDROP_FORCE_NODEBUG=yes # coverage file location rl="readlink -f" if ! ${rl} "${0}" >/dev/null 2>&1; then rl="realpath" if ! hash ${rl}; then echo "\"${rl}\" not found!" && exit 1 fi fi cur=`dirname $(${rl} "${0}")` workers=${DOTDROP_WORKERS} if [ ! -z ${workers} ]; then unset DOTDROP_WORKERS echo "DISABLE workers" fi # execute tests with coverage if [ -z ${GITHUB_WORKFLOW} ]; then ## local export COVERAGE_FILE= PYTHONPATH="dotdrop" ${nosebin} -s --processes=-1 --with-coverage --cover-package=dotdrop #export DOTDROP_DEBUG=yes #unset DOTDROP_FORCE_NODEBUG else ## CI/CD export COVERAGE_FILE="${cur}/.coverage" PYTHONPATH="dotdrop" ${nosebin} --processes=0 --with-coverage --cover-package=dotdrop #unset DOTDROP_DEBUG= #export DOTDROP_FORCE_NODEBUG=yes fi #PYTHONPATH="dotdrop" python3 -m pytest tests # disable debug logs unset DOTDROP_DEBUG= export DOTDROP_FORCE_NODEBUG=yes tmpworkdir="/tmp/dotdrop-tests-workdir" export DOTDROP_WORKDIR="${tmpworkdir}" if [ ! -z ${workers} ]; then DOTDROP_WORKERS=${workers} echo "ENABLE workers: ${workers}" fi # run bash tests workdir_tmp_exists="no" [ -d "~/.config/dotdrop/tmp" ] && workdir_tmp_exists="yes" if [ -z ${GITHUB_WORKFLOW} ]; then ## local export COVERAGE_FILE= tests-ng/tests-launcher.py else ## CI/CD export COVERAGE_FILE="${cur}/.coverage" tests-ng/tests-launcher.py 1 fi # clear workdir [ "${workdir_tmp_exists}" = "no" ] && rm -rf ~/.config/dotdrop/tmp # clear temp workdir rm -rf "${tmpworkdir}" ## test the doc with remark ## https://github.com/remarkjs/remark-validate-links set +e which remark >/dev/null 2>&1 r="$?" set -e if [ "$r" != "0" ]; then echo "[WARNING] install \"remark\" to test the doc" else remark -f -u validate-links docs/ remark -f -u validate-links *.md fi ### test the doc with markdown-link-check ### https://github.com/tcort/markdown-link-check #set +e #which markdown-link-check >/dev/null 2>&1 #r="$?" #set -e #if [ "$r" != "0" ]; then # echo "[WARNING] install \"markdown-link-check\" to test the doc" #else # for i in `find docs -iname '*.md'`; do markdown-link-check $i; done # markdown-link-check README.md #fi ## done echo "All test finished successfully"