| #!/bin/bash |
| |
| # Usage: |
| # servo-stat DUT ... |
| # |
| # Reports the status of the servo (if any) attached to the DUT. |
| # The DUT name is the host name without the .cros, or -servo. |
| # For each named DUT, reports a line something like this: |
| # DUT ...ABCDEFG is up BOARD=swanky CHROMEOS_RELEASE_VERSION=5995.0.0 |
| # |
| # The letters are just arbitrary tags printed before any |
| # long-running operation that might time out. It allows you to see |
| # progress, and if things get hung up, you can see where. |
| |
| |
| # readlink -f $0, in case $0 is a symlink from somewhere else |
| REPO=$(dirname $(readlink -f $0))/../../../../.. |
| REPO=$(readlink -f $REPO) |
| PYTHON=$(readlink -f $REPO/chroot/usr/bin/python2.7) |
| HDCTOOLS=$(readlink -f $REPO/chroot/usr/lib/python2.7/site-packages/servo) |
| KEYFILE=$REPO |
| KEYFILE=$KEYFILE/src/third_party/chromiumos-overlay |
| KEYFILE=$KEYFILE/chromeos-base/chromeos-ssh-testkeys/files/testing_rsa |
| |
| # Need some temporary files to keep ssh happy: |
| # + Just setting StrictHostKeyChecking=no won't silence all |
| # possible errors about host keys, so we need a temporary file |
| # where host keys can be cached. |
| # + We don't want to require the user to edit or provide the |
| # standard test keys, so we use the keys from the repo. But... |
| # The file must be user-readable only, so we need a copy with |
| # the correct modes (mktemp is 600 by default). |
| |
| TMPKEYS=$(mktemp) |
| TMPHOSTS=$(mktemp) |
| |
| trap 'rm $TMPKEYS $TMPHOSTS' EXIT |
| cp $KEYFILE $TMPKEYS |
| |
| _ssh() { |
| local ssh_opts=( -n -o BatchMode=yes -o StrictHostKeyChecking=no |
| -o UserKnownHostsFile=$TMPHOSTS -i $TMPKEYS ) |
| local timeout=$1 |
| local servo=$2 |
| shift 2 |
| timeout "${timeout}" ssh "${ssh_opts[@]}" "root@${servo}" "$@" |
| } |
| |
| dut_control() { |
| local servo=$1 |
| shift |
| _ssh 90 $servo dut-control "$@" |
| } |
| |
| remote() { |
| _ssh 45 "$@" |
| } |
| |
| get_afe_host_attr() { |
| local host=$1 |
| local attr=$2 |
| local default=$3 |
| atest host stat $host | awk "/^$attr *: / {count++; print \$3} |
| END {if (count != 1) print \"$default\"}" |
| } |
| |
| get_servo() { |
| local host=$1 |
| |
| # Get the servo host from the afe. If not present, infer it from the hostname. |
| local servo_host=$(get_afe_host_attr $host servo_host ${host}-servo) |
| echo ${servo_host}.cros |
| } |
| |
| get_servo_port() { |
| local host=$1 |
| |
| # Get the servo port from the afe. If not present, default 9999. |
| get_afe_host_attr $host servo_port 9999 |
| } |
| |
| |
| |
| for H in "$@" |
| do |
| SERVO=$(get_servo $H) |
| SERVO_PORT=$(get_servo_port $H) |
| CONFIG=/var/lib/servod/config_$SERVO_PORT |
| echo -n "$H ..." |
| STATUS=() |
| |
| HAVE_SERVOD=1 |
| BOARD= |
| VERSION= |
| |
| echo -n "A" |
| if ping -c1 -w2 $SERVO >/dev/null 2>&1 |
| then |
| echo -n "B" |
| if BUTTON=$(dut_control $SERVO -p $SERVO_PORT pwr_button 2>/dev/null) |
| then |
| if [ "$BUTTON" != "pwr_button:release" ] |
| then |
| STATUS=("${STATUS[@]}" "pwr_button is '$BUTTON'") |
| else |
| echo -n "C" |
| LID=$(dut_control $SERVO -p $SERVO_PORT lid_open 2>/dev/null) |
| if [ "$LID" != "lid_open:yes" -a "$LID" != "lid_open:not_applicable" ] |
| then |
| STATUS=("${STATUS[@]}" "lid_open is '$LID'") |
| fi |
| fi |
| else |
| STATUS=("${STATUS[@]}" "not running servod") |
| HAVE_SERVOD=0 |
| fi |
| |
| echo -n "D" |
| if ! remote $SERVO true >/dev/null 2>&1 |
| then |
| STATUS=("${STATUS[@]}" "ssh is down") |
| else |
| echo -n "E" |
| VERSION=$( |
| remote $SERVO grep CHROMEOS_RELEASE_VERSION /etc/lsb-release 2>&1) |
| if [ -z "$VERSION" ] |
| then |
| STATUS=("${STATUS[@]}" "not running chromeos") |
| fi |
| fi |
| |
| if [ -n "$VERSION" ] |
| then |
| echo -n "F" |
| if remote $SERVO test -f $CONFIG |
| then |
| echo -n "G" |
| BOARD=$(remote $SERVO grep BOARD= $CONFIG) |
| fi |
| if [ $HAVE_SERVOD -eq 0 ] |
| then |
| if [ -z "$BOARD" ] |
| then |
| STATUS=("servod not configured") |
| else |
| echo -n "H" |
| JOB=$(remote $SERVO status servod | sed 's/,.*//') |
| if [ "$JOB" = "servod start/running" ] |
| then |
| STATUS=("servod failed") |
| fi |
| fi |
| fi |
| fi |
| else |
| STATUS=("${STATUS[@]}" "is down") |
| fi |
| |
| if [ "${#STATUS}" -eq 0 ] |
| then |
| STATUS=("is up") |
| fi |
| |
| if [ -n "$VERSION" ] |
| then |
| STATUS=("${STATUS[@]}" $BOARD $VERSION) |
| fi |
| echo " ${STATUS[@]}" |
| done |