| #!/bin/bash |
| # Copyright (c) 2015 The Chromium OS Authors. All rights reserved. |
| # Use of this source code is governed by a BSD-style license that can be |
| # found in the LICENSE file. |
| |
| SCRIPT_DIR=$(dirname $(readlink -f $0)) |
| cd ${SCRIPT_DIR}/.. |
| |
| LOGDIR=logs/stable-version |
| ASSIGN_STABLE=site_utils/stable_images/assign_stable_images.py |
| OPTIONS=() |
| |
| # STATUS is part hack, part safety valve. The cron job that invokes |
| # this script may be installed and enabled on both a primary and backup |
| # server. We skip running on the backup, but really, the backup |
| # shouldn't have invoked this script in the first place... |
| # |
| # If we're not invoked on an autotest server at all, we assume this is |
| # for testing, and invoke a dry run instead. |
| # |
| SERVER_STATUS=$(cli/atest server list $(hostname) 2>&1 | |
| awk '/^Status *:/ { print $NF }') |
| if [ "${SERVER_STATUS}" = "primary" ]; then |
| mkdir -p ${LOGDIR} |
| NOTIFY=( |
| chromeos-infra-eng@grotations.appspotmail.com |
| ) |
| else |
| if [ -n "${SERVER_STATUS}" ]; then |
| # must be backup |
| exit 0 |
| fi |
| OPTIONS=( --dry-run ) |
| NOTIFY=( ${LOGNAME}@google.com ) |
| fi |
| |
| # Redirect onto a log file. For debug purposes, skip redirection if |
| # there's a command line argument (we ignore what the argument is), or |
| # if there's no log directory. |
| # |
| TAG=$(date '+%Y-%W') |
| if [ $# -eq 0 -a -d ${LOGDIR} ]; then |
| LOGFILE="update-${TAG}.log" |
| exec >>${LOGDIR}/${LOGFILE} 2>&1 |
| fi |
| |
| trap 'rm -f ${TMPFILE}' EXIT |
| TMPFILE=$(mktemp) |
| |
| date |
| $ASSIGN_STABLE "${OPTIONS[@]}" 2>&1 | tee ${TMPFILE} |
| echo |
| |
| # If we have a log directory, clean it up, and send e-mail notification. |
| # The log files change name each week, so by throwing out all but the |
| # most recent 14 files, we keep about 3 months of history, plus this |
| # week's log. |
| # |
| if [ -d ${LOGDIR} ]; then |
| SUBJECT="Stable version update summary ${TAG}" |
| site_utils/gmail_lib.py -s "${SUBJECT}" "${NOTIFY[@]}" <${TMPFILE} |
| rm -f $(ls -r ${LOGDIR}/update-*.log | sed '1,14 d') |
| fi |