X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=development%2Fautotests%2Frun-tests.sh;h=25d29340e8414e8567f4ea826c458dd6926abc3b;hb=cb3922093016875404aedc6d1fcf2e088944b5c9;hp=80201083a102f9f0dfa79cad25dd82ad3c04bf4c;hpb=9e9874c0ab7f778243e556cc1bc4c23bc2ec1e83;p=lyx.git diff --git a/development/autotests/run-tests.sh b/development/autotests/run-tests.sh index 80201083a1..25d29340e8 100755 --- a/development/autotests/run-tests.sh +++ b/development/autotests/run-tests.sh @@ -4,7 +4,8 @@ # Tests are identified as having a file name of *-in.txt # For failed tests, the collected output is kept in the corresponding folder -export LYX_EXE=../../../src/lyx +export LYX_ROOT=../../.. +export LYX_EXE=$LYX_ROOT/src/lyx if [ "$XVKBD_HACKED" != "" ]; then export XVKBD_EXE=${XVKBD:-./xvkbd/xvkbd}; @@ -14,10 +15,24 @@ if [ "$XVKBD_HACKED" != "" ]; then fi fi +if [ "$(which wmctrl)" == "" ]; then + echo "You need to install wmctrl first, try:" + echo " sudo apt-get install wmctrl" + exit -1; +fi + +if [ "$(which pcregrep)" == "" ]; then + echo "You need to install pcregrep first, try:" + echo " sudo apt-get install pcregrep" + exit -1; +fi + +PROGRAM_SUFFIX=$(grep -e '#define PACKAGE ' ../../config.h | sed -e 's/#define PACKAGE "lyx\(.*\)"/\1/') + export XVKBD_EXE=../$XVKBD_EXE export KEYTEST=../keytest.py LYX_HOME=out-home -export LYX_USERDIR=$(pwd)/$LYX_HOME/.lyx +export LYX_USERDIR=$(pwd)/$LYX_HOME/.lyx$PROGRAM_SUFFIX # Create locale links export LOCALE_DIR=../locale @@ -38,7 +53,7 @@ if [ ! -d ../../locale ]; then fi if [ "$#" -eq 0 ]; then - TESTS=$(ls *-in.txt | sed -e 's/hello-world-in.txt\|first-time-in.txt//') + TESTS=$(ls *-in.txt *-in.sh | sed -e 's/hello-world-in.txt\|first-time-in.txt\|export-in.sh//') rm -rf out-*; else TESTS=$* @@ -48,11 +63,11 @@ echo if [ ! -d $LYX_HOME ]; then mkdir -p $LYX_HOME -# mkdir -p $LYX_USERDIR + mkdir -p $LYX_USERDIR # cp preferences $LYX_USERDIR cd $LYX_HOME echo "Initializing testing environment . . ." - if ! ../single-test.sh "../first-time-in.txt" > keytest-log.txt 2>&1; then + if ! ../single-test.sh "../first-time-in.txt" > test-log.txt 2>&1; then echo "Some error occurred: check $(pwd)" exit -1; fi @@ -63,21 +78,37 @@ fi ./stop_autotests.tcl & pid=$! +function stop_button() { + kill $pid + wait $pid > /dev/null 2>&1 +} + echo "Running test cases . . ." failed=0 -for t in $(echo "$TESTS" | sed -e 's/-in.txt//g'); do - printf "%40s: " $t - if [ ! -f "$t-in.txt" ]; then - echo "ERROR: File not found: $t-in.txt" +for tf in $(echo "$TESTS"); do + t=$(echo $tf | sed -e 's/-in.txt//g' | sed -e 's/-in.sh//g') + printf "%40s: " $tf + if [ -f "$t-in.txt" ]; then + cmd="../single-test.sh ../$t-in.txt"; + elif [ -f "$t-in.sh" ]; then + if [ ! -x "$t-in.sh" ]; then + echo "ERROR: $t-in.sh is not executable" + stop_button + exit -1; + fi + cmd="../$tf"; + else + echo "ERROR: File not found: $t-in.txt or $t-in.sh" + stop_button exit -1; fi rm -rf "out-$t" mkdir "out-$t" cd "out-$t" - if ../single-test.sh "../$t-in.txt" > keytest-log.txt 2>&1; then + if $cmd > test-log.txt 2>&1; then echo Ok cd .. - rm -rf "out-$t"; + if [ "$V" != "" ]; then rm -rf "out-$t"; fi else echo FAILED cd .. @@ -85,8 +116,7 @@ for t in $(echo "$TESTS" | sed -e 's/-in.txt//g'); do fi; done -kill $pid -wait $pid > /dev/null 2>&1 +stop_button echo if [ $failed -eq 0 ]; then