return $?
}
+do_afm_test()
+{
+set -x
+ if [ $SERVICE_USER -eq 1 -o $APPLICATION_USER -eq 1 ];then
+ su - $AGLDRIVER -c "aft-test $*"
+ else
+ afm-test -l $*
+ fi
+ return $?
+}
+
if [ ! -f index.html ] ; then
wget -q $BASEURL -O index.html
if [ $? -ne 0 ];then
fi
fi
+WGTNAME="$(grep -o '[a-z-]*.wgt' index.html | sed 's,.wgt$,,' | sed 's,-debug$,,' | sed 's,-coverage$,,' | sed 's,-test$,,' | uniq)"
+
grep -o '[a-z-]*.wgt' index.html | sort | uniq |
while read wgtfile
do
- WGTNAME=$(echo $wgtfile | sed 's,.wgt$,,')
- SERVICE_PLATFORM=0
- SERVICE_USER=0
- APPLICATION_USER=0
+ # remove extension and the debug state
+ #export WGTNAME=$(echo $wgtfile | sed 's,.wgt$,,' | sed 's,-debug$,,' | sed 's,-coverage$,,' | sed 's,-test$,,')
echo "DEBUG: fetch $wgtfile"
if [ ! -f $wgtfile ] ; then
continue
fi
fi
+done
+
+echo "$WGTNAME"
+
+inspectwgt()
+{
+
+ wgtfile=$1
+ CURDIR="$(pwd)"
+ ZIPOUT="$(mktemp -d)"
+ cd $ZIPOUT
echo "DEBUG: analyse wgt file"
- unzip $wgtfile
+ unzip $CURDIR/$wgtfile
if [ $? -ne 0 ];then
# TODO Do not fail yet, busybox unzip seems to "fail with success" when checking CRC
echo "ERROR: cannot unzip $wgtfile"
# 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
else
echo "DEBUG: fail to unzip"
fi
+ cd $CURDIR
+ rm -r $ZIPOUT
+
+}
+
+# cases:
+# a) (release).wgt -> lifecycle
+# b) -test.wgt -> run afm-test $wgt
+# later: c) -coverage wgt -> install coverage AND run afm-test $wgt
+for RUNIT in runrelease runtest ; do
+
+ SERVICE_PLATFORM=0
+ SERVICE_USER=0
+ APPLICATION_USER=0
+
+ if [ x"runrelease" = x"$RUNIT" ] ; then
+ eval wgtfile="${WGTNAME}.wgt"
+ inspectwgt $wgtfile
+
echo "DEBUG: list current pkgs"
# TODO mktemp
LIST='list'
fi
echo "DEBUG: check presence of $WGTNAME"
- NAMEID=$(grep id\\\":\\\"${WGTNAME} $LIST | cut -d\" -f4 | cut -d\\ -f1)
+ NAMEID=$(grep id\\\":\\\"${WGTNAME}\" $LIST | cut -d\" -f4 | cut -d\\ -f1)
if [ ! -z "$NAMEID" ];then
echo "DEBUG: $WGTNAME already installed as $NAMEID"
# need to kill then deinstall
lava-test-case afm-util-install-$WGTNAME --result pass
fi
# message is like \"added\":\"mediaplayer@0.1\"
- NAMEID=$(grep d\\\":\\\"${WGTNAME} $OUT | cut -d\" -f4 | cut -d\\ -f1)
+ NAMEID=$(grep d\\\":\\\"${WGTNAME}\" $OUT | cut -d\" -f4 | cut -d\\ -f1)
if [ -z "$NAMEID" ];then
echo "ERROR: Cannot get nameid"
+ echo "DEBUG: ========== DUMPING output =========="
+ cat $OUT
+ echo "DEBUG: ========== END DUMP =========="
continue
fi
echo "DEBUG: $WGTNAME is installed as $NAMEID"
fi
echo "DEBUG: check if we see the package with systemctl list-units (before start)"
- systemctl list-units --full | grep "afm.*$WGTNAME"
+ systemctl list-units --full | grep "afm.*$WGTNAME--"
echo "DEBUG: check if we see the package with systemctl -a (before start)"
- systemctl -a |grep "afm.*$WGTNAME"
+ systemctl -a |grep "afm.*$WGTNAME--"
echo "DEBUG: start $NAMEID"
do_afm_util start $NAMEID > "rid"
if [ $? -ne 0 ];then
echo "ERROR: afm-util start"
lava-test-case afm-util-start-$WGTNAME --result fail
+ journalctl -an 200
continue
else
lava-test-case afm-util-start-$WGTNAME --result pass
fi
echo "DEBUG: check if we see the package with systemctl list-units (after start)"
- systemctl list-units --full | grep "afm.*$WGTNAME"
+ 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"
+ systemctl -a |grep "afm.*$WGTNAME--"
echo "DEBUG: Get RID for $NAMEID"
PSLIST="pslist"
if [ $? -ne 0 ];then
echo "ERROR: afm-util start2"
lava-test-case afm-util-start2-$WGTNAME --result fail
+ journalctl -an 200
continue
else
lava-test-case afm-util-start2-$WGTNAME --result pass
else
lava-test-case afm-util-status2-$WGTNAME --result pass
fi
+ fi
+ if [ x"runtest" = x"$RUNIT" ] ; then
+ eval wgtfile="${WGTNAME}-test.wgt"
+ inspectwgt $wgtfile
+ afm-test -l $wgtfile
+ journalctl -b | grep ${WGTNAME}-test
+ ( journalctl -b | grep ${WGTNAME}-test | grep ERROR ) || true
+ fi
+
done