X-Git-Url: https://wannabe.guru.org/gitweb/?a=blobdiff_plain;f=tests%2Frun_tests.sh;h=547f87cdafccce5194dc989fe73ae59df53283d6;hb=f2600f30801c849fc1d139386e3ddc3c9eb43e30;hp=6c418a2424c52dcfa293f09de52fbb00e4570ed8;hpb=075c18063826d36377aa8d46fba66f71fcf37d20;p=python_utils.git diff --git a/tests/run_tests.sh b/tests/run_tests.sh index 6c418a2..547f87c 100755 --- a/tests/run_tests.sh +++ b/tests/run_tests.sh @@ -7,6 +7,10 @@ DOCTEST=0 UNITTEST=0 INTEGRATION=0 FAILURES=0 +TESTS_RUN=0 +COVERAGE=0 +PERF_TESTS=("string_utils_test.py") + dup() { if [ $# -ne 2 ]; then @@ -38,7 +42,7 @@ make_header() { } function usage() { - echo "Usage: $0 [-a]|[-i][-u][-d]" + echo "Usage: $0 [-a]|[-i][-u][-d] [--coverage]" echo echo "Runs tests under ${ROOT}. Options control which test types:" echo @@ -67,6 +71,9 @@ while [[ $# -gt 0 ]]; do -i|--integration) INTEGRATION=1 ;; + --coverage) + COVERAGE=1 + ;; *) # unknown option echo "Argument $key was not recognized." echo @@ -82,18 +89,31 @@ if [ $(expr ${DOCTEST} + ${UNITTEST} + ${INTEGRATION}) -eq 0 ]; then exit 2 fi +if [ ${COVERAGE} -eq 1 ]; then + coverage erase +fi + +FAILED_TESTS="" if [ ${DOCTEST} -eq 1 ]; then - for doctest in $(grep -lR doctest ${ROOT}/*.py); do - BASE=$(basename ${doctest}) - BASE="${BASE} (doctest)" - make_header "${BASE}" "${CYAN}" - OUT=$( python3 ${doctest} 2>&1 ) - FAILED=$( echo "${OUT}" | grep '\*\*\*Test Failed\*\*\*' | wc -l ) - if [ $FAILED == 0 ]; then - echo "OK" - else - echo -e "${FAILED}" - FAILURES=$((FAILURES+1)) + for doctest in $(grep -lR doctest ${ROOT}/*); do + if [[ ${doctest} == *.py ]]; then + BASE=$(basename ${doctest}) + BASE="${BASE} (doctest)" + make_header "${BASE}" "${CYAN}" + if [ ${COVERAGE} -eq 1 ]; then + OUT=$( coverage run --source ${HOME}/lib --append ${doctest} 2>&1 ) + else + OUT=$( python3 ${doctest} 2>&1 ) + fi + TESTS_RUN=$((TESTS_RUN+1)) + FAILED=$( echo "${OUT}" | grep '\*\*\*Test Failed\*\*\*' | wc -l ) + if [ $FAILED == 0 ]; then + echo "OK" + else + echo -e "${FAILED}" + FAILURES=$((FAILURES+1)) + FAILED_TESTS="${FAILED_TESTS},${BASE} (python3 ${doctest})" + fi fi done fi @@ -101,33 +121,70 @@ fi if [ ${UNITTEST} -eq 1 ]; then for test in $(find ${ROOT} -name "*_test.py" -print); do BASE=$(basename ${test}) - BASE="${BASE} (unittest)" - make_header "${BASE}" "${GREEN}" - ${test} + HDR="${BASE} (unittest)" + make_header "${HDR}" "${GREEN}" + if [ ${COVERAGE} -eq 1 ]; then + coverage run --source ${HOME}/lib --append ${test} --unittests_ignore_perf + if [[ " ${PERF_TESTS[*]} " =~ " ${BASE} " ]]; then + echo "(re-running w/o coverage to record perf results)." + ${test} + fi + else + ${test} + fi if [ $? -ne 0 ]; then FAILURES=$((FAILURES+1)) + FAILED_TESTS="${FAILED_TESTS},${BASE} (python3 ${test})" fi + TESTS_RUN=$((TESTS_RUN+1)) done fi if [ ${INTEGRATION} -eq 1 ]; then for test in $(find ${ROOT} -name "*_itest.py" -print); do BASE=$(basename ${test}) - BASE="${BASE} (integration test)" - make_header "${BASE}" "${ORANGE}" - ${test} + HDR="${BASE} (integration test)" + make_header "${HDR}" "${ORANGE}" + if [ ${COVERAGE} -eq 1 ]; then + coverage run --source ${HOME}/lib --append ${test} + else + ${test} + fi if [ $? -ne 0 ]; then FAILURES=$((FAILURES+1)) + FAILED_TESTS="${FAILED_TESTS},${BASE} (python3 ${test})" fi + TESTS_RUN=$((TESTS_RUN+1)) done fi +if [ ${COVERAGE} -eq 1 ]; then + make_header "Code Coverage Report" "${GREEN}" + coverage report --omit=config-3.8.py,*_test.py,*_itest.py --sort=-cover + echo + echo "To recall this report w/o run-running the tests:" + echo + echo " $ coverage report --omit=config-3.8.py,*_test.py,*_itest.py --sort=-cover" + echo + echo "...from the 'tests' directory. Note that subsequent calls to " + echo "run_tests.sh with --coverage will klobber previous results. See:" + echo + echo " https://coverage.readthedocs.io/en/6.2/" + echo +fi + if [ ${FAILURES} -ne 0 ]; then + FAILED_TESTS=$(echo ${FAILED_TESTS} | sed 's/^,/__/g') + FAILED_TESTS=$(echo ${FAILED_TESTS} | sed 's/,/\n__/g') if [ ${FAILURES} -eq 1 ]; then - echo -e "${RED}There was ${FAILURES} failure.${NC}" + echo -e "${RED}There was ${FAILURES}/${TESTS_RUN} failure:" else - echo -e "${RED}There were ${FAILURES} failures.${NC}" + echo -e "${RED}There were ${FAILURES}/${TESTS_RUN} failures:" fi + echo "${FAILED_TESTS}" + echo -e "${NC}" + exit ${FAILURES} else - echo -e "${GREEN}Everything looks good.${NC}" + echo -e "${BLACK}${ON_GREEN}All (${TESTS_RUN}) test(s) passed.${NC}" + exit 0 fi