~popey/+junk/phablet-flash-wrapper

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
#!/bin/bash
#
# * Installs click packages in $CLICKS
# * Runs each app in turn 
# * Takes screenshot of each app
# * Looks for all-white and all-black screenshots and moves to issues folder
#
# Requirements
#
# * Device already flashed with Ubuntu for Phones
# * Network connection on device enabled
# * Subdirectory of where this script is, containing click packages to test
#
# ToDo
# * Check internet access (cause of webapp fails)
# * Supress OSK between runs

TARGETUSER="phablet"
TARGET="/home/$TARGETUSER"
CLICKS="clicks/"
DATESTAMP=`date +%Y%m%d`-`date +%H%M%S`
LOGDIR=`pwd`/$DATESTAMP
FBDEV=fb0
CONVERTOPTS="-alpha off -depth 8 -size 768x1280"

function pause {
    echo ":: Wait $1"
    sleep $1
}

function wait_for_device {
  echo -n ":: Waiting for device to come back ."
  STATE="unknown"
  while [ "$STATE" ==  "unknown" ];
  do
    echo -n "."
    STATE=`adb get-state`
    sleep 15
  done
  echo " "
}

function screen_grab {
  adb shell "kill -SIGSTOP \$(pidof unity8)"
  adb pull /dev/$FBDEV $LOGDIR/fb
  adb shell "kill -SIGCONT \$(pidof unity8)"
  convert $CONVERTOPTS rgba:$LOGDIR/fb[0] $LOGDIR/$LAUNCH.png
}

mkdir -p $LOGDIR/issues

adb shell system-image-cli -i 2>&1 | tee -a $LOGDIR/info.log
adb push $CLICKS $TARGET/$CLICKS 2>&1 | tee -a $LOGDIR/push.log
for PACKAGE in $(ls $CLICKS)
do
  adb shell click install --force-missing-framework --user=phablet $TARGET/$CLICKS/$PACKAGE 2>&1 | tee -a $LOGDIR/install.log
done

echo "::: Rebooting" 2>&1 | tee -a $LOGDIR/info.log
adb reboot
wait_for_device
read -p "Wait for launcher to appear, then unlock the screen, then press enter here"

echo "::: Kill powerd"
pause 5
adb shell stop powerd

echo "::: Stop Maliit"
adb shell sudo -u phablet -i stop maliit-server

pause 10
for APP in $(adb shell ls /home/phablet/.local/share/applications/*.desktop | tr -d '\r')
do
  LAUNCH=`basename $APP | sed 's/.desktop//'`
  echo "::: Starting app $APP" 2>&1 | tee -a $LOGDIR/info.log
  echo adb shell sudo -u phablet -i start application APP_ID=$LAUNCH 
  adb shell sudo -u phablet -i start application APP_ID=$LAUNCH 2>&1 | tee -a $LOGDIR/$LAUNCH.log
  pause 10
  echo "::: Take screenshot" 2>&1 | tee -a $LOGDIR/info.log
  screen_grab
  echo "::: Stopping app $APP" 2>&1 | tee -a $LOGDIR/info.log
  adb shell sudo -u phablet -i upstart-app-stop $LAUNCH
  echo "::: Pull upstart log for $APP" 2>&1 | tee -a $LOGDIR/info.log
  adb pull /home/phablet/.cache/upstart/application-click-$LAUNCH.log $LOGDIR
  COLOR=`convert $LOGDIR/$LAUNCH.png -gravity center -crop 70x70%+0+0 -scale 1x1\! -depth 8 txt:- | tail -1 | awk '{print $3}'`
  echo $COLOR
  if [ "$COLOR" == "#FFFFFF" ] || [ "$COLOR" == "#000000" ]; then
    echo "::: Possible problem with $APP" 2>&1 | tee -a $LOGDIR/info.log
    mv $LOGDIR/application-click-$LAUNCH.log $LOGDIR/issues
    mv $LOGDIR/$LAUNCH.png $LOGDIR/issues
  fi
done
echo "::: Rebooting" 2>&1 | tee -a $LOGDIR/info.log
adb reboot