X-Git-Url: https://gerrit.automotivelinux.org/gerrit/gitweb?a=blobdiff_plain;f=common%2Fscripts%2Fapplication-lifecycle.sh;h=9044a41beaa4dcb0dac36cd6756099bea417a031;hb=c382578ae3a95e9fdb3648147245c2d81bbd5a7e;hp=c03602e9fe8d379db6d9982e78ec5008385fa253;hpb=e944e4103843192d8c04b602d0309bba9bbb8f9a;p=src%2Fqa-testdefinitions.git diff --git a/common/scripts/application-lifecycle.sh b/common/scripts/application-lifecycle.sh index c03602e..9044a41 100755 --- a/common/scripts/application-lifecycle.sh +++ b/common/scripts/application-lifecycle.sh @@ -39,6 +39,21 @@ set -x return $? } +do_afm_test() +{ + set -x + if [ $SERVICE_USER -eq 1 -o $APPLICATION_USER -eq 1 ];then + su - $AGLDRIVER -c "afm-test -l $*" + else + afm-test -l $* + fi + return $? +} + +# work in tmp folder to allow different users to access files (smack) +TOPDIR=$(mktemp -d) +cd $TOPDIR + if [ ! -f index.html ] ; then wget -q $BASEURL -O index.html if [ $? -ne 0 ];then @@ -47,14 +62,11 @@ if [ ! -f index.html ] ; then fi fi +# first download all files grep -o '[a-z-]*.wgt' index.html | sort | uniq | while read wgtfile do # remove extension and the debug state - WGTNAME=$(echo $wgtfile | sed 's,.wgt$,,' | sed 's,-debug$,,' | sed 's,-test$,,' | sed 's,-coverage$,,') - SERVICE_PLATFORM=0 - SERVICE_USER=0 - APPLICATION_USER=0 echo "DEBUG: fetch $wgtfile" if [ ! -f $wgtfile ] ; then @@ -64,6 +76,19 @@ do continue fi fi + # do adapt security + chmod -R a+rwx ${TOPDIR} + chsmack -a "*" ${TOPDIR}/* +done + +inspect_wgt() { + wgtfile=$1 + WGTNAME=$2 + + export SERVICE_PLATFORM=0 + export SERVICE_USER=0 + export APPLICATION_USER=0 + CURDIR="$(pwd)" ZIPOUT="$(mktemp -d)" cd $ZIPOUT @@ -87,21 +112,60 @@ do # we are a service, now determine the scope ... grep "urn:AGL:permission::partner:scope-platform" config.xml if [ $? -eq 0 ];then - SERVICE_PLATFORM=1 + export SERVICE_PLATFORM=1 else - SERVICE_USER=1 + export SERVICE_USER=1 fi else # we are an application - APPLICATION_USER=1 + export APPLICATION_USER=1 # no other type known (yet) fi + # the file naming convention is servicename.wgt + # but some didnt respect it + export WGTSERVICENAME=$(grep 'id=.*' config.xml | sed 's,^.*id=,id=,' | cut -d= -f2 | cut -d'"' -f2) + if [ -z "$WGTSERVICENAME" ];then + echo "WARN: failed to find name in config.xml, fallback to filename" + export WGTSERVICENAME="$WGTNAME" + else + echo "DEBUG: detected service name as $WGTSERVICENAME" + fi else echo "DEBUG: fail to unzip" fi cd $CURDIR rm -r $ZIPOUT +} + +# check if WGTNAME is running +check_service_running() { + WGTNAME=$1 + RUNNING=0 + + echo "DEBUG: check_service_running with systemctl list-units -full" + systemctl list-units --full | grep "afm.*$WGTNAME--" + if [ $? -eq 0 ];then + RUNNING=1 + fi + echo "DEBUG: check_service_running with systemctl -a" + systemctl -a |grep "afm.*$WGTNAME--" + if [ $? -eq 0 ];then + if [ $RUNNING -eq 0 ];then + echo "ERROR: inconsistent results" + fi + RUNNING=1 + fi + return $RUNNING +} + +do_release_test() { + WGTNAME=$1 + wgtfile=$2 + # we need the full name (with -test, -debug etc..) for LAVA test case + WGTNAMEF=$(echo $2 | sed 's,.wgt,,') + + echo "INFO: do_release_test $WGTNAME $wgtfile" echo "DEBUG: list current pkgs" # TODO mktemp @@ -117,7 +181,7 @@ do fi echo "DEBUG: check presence of $WGTNAME" - NAMEID=$(grep id\\\":\\\"${WGTNAME}\" $LIST | cut -d\" -f4 | cut -d\\ -f1) + NAMEID=$(grep id\\\":\\\"${WGTSERVICENAME}\" $LIST | cut -d\" -f4 | cut -d\\ -f1) if [ ! -z "$NAMEID" ];then echo "DEBUG: $WGTNAME already installed as $NAMEID" # need to kill then deinstall @@ -140,11 +204,11 @@ do afm-util remove $NAMEID if [ $? -ne 0 ];then echo "ERROR: afm-util remove" - #lava-test-case afm-util-remove-$WGTNAME --result fail + #lava-test-case afm-util-remove-$WGTNAMEF --result fail journalctl -b | tail -40 #continue else - lava-test-case afm-util-remove-$WGTNAME --result pass + lava-test-case afm-util-remove-$WGTNAMEF --result pass fi else echo "DEBUG: $WGTNAME not installed" @@ -156,13 +220,13 @@ do afm-util install $wgtfile > $OUT if [ $? -ne 0 ];then echo "ERROR: afm-util install" - lava-test-case afm-util-install-$WGTNAME --result fail + lava-test-case afm-util-install-$WGTNAMEF --result fail continue else - lava-test-case afm-util-install-$WGTNAME --result pass + lava-test-case afm-util-install-$WGTNAMEF --result pass fi # message is like \"added\":\"mediaplayer@0.1\" - NAMEID=$(grep d\\\":\\\"${WGTNAME}\" $OUT | cut -d\" -f4 | cut -d\\ -f1) + NAMEID=$(grep d\\\":\\\"${WGTSERVICENAME}\" $OUT | cut -d\" -f4 | cut -d\\ -f1) if [ -z "$NAMEID" ];then echo "ERROR: Cannot get nameid" echo "DEBUG: ========== DUMPING output ==========" @@ -194,9 +258,9 @@ do do_afm_util info $NAMEID if [ $? -ne 0 ];then echo "ERROR: afm-util info" - lava-test-case afm-util-info-$WGTNAME --result fail + lava-test-case afm-util-info-$WGTNAMEF --result fail else - lava-test-case afm-util-info-$WGTNAME --result pass + lava-test-case afm-util-info-$WGTNAMEF --result pass fi echo "DEBUG: check if we see the package with systemctl list-units (before start)" @@ -208,28 +272,25 @@ do do_afm_util start $NAMEID > "rid" if [ $? -ne 0 ];then echo "ERROR: afm-util start" - lava-test-case afm-util-start-$WGTNAME --result fail + lava-test-case afm-util-start-$WGTNAMEF --result fail journalctl -an 200 continue else - lava-test-case afm-util-start-$WGTNAME --result pass + lava-test-case afm-util-start-$WGTNAMEF --result pass fi - echo "DEBUG: check if we see the package with systemctl list-units (after start)" - systemctl list-units --full | grep "afm.*$WGTNAME--" - echo "DEBUG: check if we see the package with systemctl -a (after start)" - systemctl -a |grep "afm.*$WGTNAME--" + check_service_running $WGTNAME echo "DEBUG: Get RID for $NAMEID" PSLIST="pslist" afm-util ps --all > $PSLIST if [ $? -ne 0 ];then echo "ERROR: afm-util ps" - lava-test-case afm-util-ps-$WGTNAME --result fail + lava-test-case afm-util-ps-$WGTNAMEF --result fail continue else cat $PSLIST - lava-test-case afm-util-ps-$WGTNAME --result pass + lava-test-case afm-util-ps-$WGTNAMEF --result pass fi # TODO, compare RID with the list in $PSLIST" RID="$(cat rid)" @@ -239,7 +300,7 @@ do do_afm_util start $NAMEID > "rid" if [ $? -ne 0 ];then echo "ERROR: afm-util start" - lava-test-case afm-util-start-$WGTNAME --result fail + lava-test-case afm-util-start-$WGTNAMEF --result fail continue fi RID="$(cat rid)" @@ -247,7 +308,7 @@ do if [ "$RID" == 'null' ];then echo "ERROR: RID is null, service fail to start" - lava-test-case afm-util-status-$WGTNAME --result fail + lava-test-case afm-util-status-$WGTNAMEF --result fail continue fi @@ -255,45 +316,97 @@ do do_afm_util status $RID if [ $? -ne 0 ];then echo "ERROR: afm-util status" - lava-test-case afm-util-status-$WGTNAME --result fail + lava-test-case afm-util-status-$WGTNAMEF --result fail continue else - lava-test-case afm-util-status-$WGTNAME --result pass + lava-test-case afm-util-status-$WGTNAMEF --result pass fi echo "DEBUG: kill $NAMEID ($RID)" do_afm_util kill $NAMEID if [ $? -ne 0 ];then echo "ERROR: afm-util kill" - lava-test-case afm-util-kill-$WGTNAME --result fail + lava-test-case afm-util-kill-$WGTNAMEF --result fail continue else - lava-test-case afm-util-kill-$WGTNAME --result pass + lava-test-case afm-util-kill-$WGTNAMEF --result pass fi echo "DEBUG: start2 $NAMEID" do_afm_util start $NAMEID > rid if [ $? -ne 0 ];then echo "ERROR: afm-util start2" - lava-test-case afm-util-start2-$WGTNAME --result fail + lava-test-case afm-util-start2-$WGTNAMEF --result fail journalctl -an 200 continue else - lava-test-case afm-util-start2-$WGTNAME --result pass + lava-test-case afm-util-start2-$WGTNAMEF --result pass fi RID="$(cat rid)" if [ "$RID" == 'null' ];then echo "ERROR: RID is null" continue fi - sleep 120 + sleep 10 echo "DEBUG: status2 $NAMEID ($RID)" do_afm_util status $RID if [ $? -ne 0 ];then echo "ERROR: afm-util status2" - lava-test-case afm-util-status2-$WGTNAME --result fail + lava-test-case afm-util-status2-$WGTNAMEF --result fail continue else - lava-test-case afm-util-status2-$WGTNAME --result pass + lava-test-case afm-util-status2-$WGTNAMEF --result pass + fi +} + +WGTNAMES=$(grep -o '[a-z-]*.wgt' index.html | sed 's,.wgt$,,' | sed 's,-debug$,,' | sed 's,-test$,,' | sed 's,-coverage$,,' | sort | uniq) +for WGTNAME in $WGTNAMES +do + if [ -e $WGTNAME.wgt ];then + inspect_wgt $WGTNAME.wgt $WGTNAME + do_release_test $WGTNAME $WGTNAME.wgt + pytest --show-capture=no --color=no -k "not hwrequired" /usr/lib/python?.?/site-packages/pyagl/tests/ -L + else + echo "WARN: cannot find $WGTNAME.wgt" + fi + # disabled due to SPEC-3608 + #if [ -e $WGTNAME-test.wgt ];then + # # wgt-test do not have the same permissions in the config.xml as the parent wgt + # # so keep the value from last run + # #inspect_wgt $WGTNAME-test.wgt + # check_service_running $WGTNAME + # if [ $? -eq 1 ];then + # do_afm_test $TOPDIR/$WGTNAME-test.wgt + # if [ $? -eq 0 ];then + # lava-test-case run-test-$WGTNAME --result pass + # else + # lava-test-case run-test-$WGTNAME --result fail + # fi + # else + # echo "DEBUG: $WGTNAME is not running, skipping test" + # lava-test-case run-test-$WGTNAME --result skip + # fi + #else + # echo "WARN: cannot find $WGTNAME.wgt" + #fi + if [ -e $WGTNAME-debug.wgt ];then + inspect_wgt $WGTNAME-debug.wgt $WGTNAME + do_release_test $WGTNAME $WGTNAME-debug.wgt + pytest --color=no -k "not hwrequired" /usr/lib/python?.?/site-packages/pyagl/tests/ + fi + if [ -e "$WGTNAME-coverage.wgt" ];then + gcovr-wrapper "$WGTNAME-coverage.wgt" > coverage.result + RET=$? + cat coverage.result + if [ $RET -eq 0 ];then + lava-test-case "run-test-$WGTNAME-coverage" --result pass + LINES_PERCENT=$(grep -o '^lines.*%' coverage.result | cut -d ' ' -f2 | cut -d% -f1) + lava-test-case "run-test-$WGTNAME-coverage-percentage-lines" --result pass --measurement "$LINES_PERCENT" + BRANCHES_PERCENT=$(grep -o '^branches.*%' coverage.result | cut -d ' ' -f2 | cut -d% -f1) + lava-test-case "run-test-$WGTNAME-coverage-percentage-branches" --result pass --measurement "$BRANCHES_PERCENT" + else + lava-test-case "run-test-$WGTNAME-coverage" --result fail + fi fi done +