| Index: sync_build_test.sh
|
| diff --git a/sync_build_test.sh b/sync_build_test.sh
|
| deleted file mode 100755
|
| index b7dad2747e46aa128d5bba69320e6d12cb153e53..0000000000000000000000000000000000000000
|
| --- a/sync_build_test.sh
|
| +++ /dev/null
|
| @@ -1,750 +0,0 @@
|
| -#!/bin/bash
|
| -
|
| -# Copyright (c) 2010 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 to sync your checkout, build a Chromium OS image, and test it all
|
| -# with one command. Can also check out a new Chromium OS checkout and
|
| -# perform a subset of the above operations.
|
| -#
|
| -# Here are some example runs:
|
| -#
|
| -# sync_build_test.sh
|
| -# syncs, recreates local repo and chroot, builds, and masters an
|
| -# image in the checkout based on your current directory, or if you
|
| -# are not in a checkout, based on the top level directory the script
|
| -# is run from.
|
| -#
|
| -# sync_build_test.sh --image_to_usb=/dev/sdb -i
|
| -# same as above but then images USB device /dev/sdb with the image.
|
| -# Also prompt the user in advance of the steps we'll take to make
|
| -# sure they agrees.
|
| -#
|
| -# sync_build_test.sh --top=~/foo --nosync --remote 192.168.1.2
|
| -# builds and masters an image in ~/foo, and live updates the machine
|
| -# at 192.168.1.2 with that image.
|
| -#
|
| -# sync_build_test.sh --top=~/newdir --test "Pam BootPerfServer" \
|
| -# --remote=192.168.1.2
|
| -# creates a new checkout in ~/newdir, builds and masters an image
|
| -# which is live updated to 192.168.1.2 and then runs
|
| -# two tests (Pam and BootPerfServer) against that machine.
|
| -#
|
| -# sync_build_test.sh --grab_buildbot=LATEST --test Pam --remote=192.168.1.2
|
| -# grabs the latest build from the buildbot, properly modifies it,
|
| -# reimages 192.168.1.2, and runs the given test on it.
|
| -#
|
| -# Environment variables that may be useful:
|
| -# BUILDBOT_URI - default value for --buildbot_uri
|
| -# CHROMIUM_REPO - default value for --repo
|
| -# CHRONOS_PASSWD - default value for --chronos_passwd
|
| -#
|
| -
|
| -# --- BEGIN COMMON.SH BOILERPLATE ---
|
| -# Load common CrOS utilities. Inside the chroot this file is installed in
|
| -# /usr/lib/crosutils. Outside the chroot we find it relative to the script's
|
| -# location.
|
| -find_common_sh() {
|
| - local common_paths=(/usr/lib/crosutils $(dirname "$(readlink -f "$0")"))
|
| - local path
|
| -
|
| - SCRIPT_ROOT=
|
| - for path in "${common_paths[@]}"; do
|
| - if [ -r "${path}/common.sh" ]; then
|
| - SCRIPT_ROOT=${path}
|
| - break
|
| - fi
|
| - done
|
| -}
|
| -
|
| -find_common_sh
|
| -. "${SCRIPT_ROOT}/common.sh" || (echo "Unable to load common.sh" && exit 1)
|
| -# --- END COMMON.SH BOILERPLATE ---
|
| -
|
| -. "${SCRIPT_ROOT}/remote_access.sh"
|
| -
|
| -DEFINE_string board "" "Board setting"
|
| -DEFINE_boolean build ${FLAGS_TRUE} \
|
| - "Build all code (but not necessarily master image)"
|
| -DEFINE_boolean build_autotest ${FLAGS_FALSE} "Build autotest"
|
| -DEFINE_string buildbot_uri "${BUILDBOT_URI}" \
|
| - "Base URI to buildbot build location which contains LATEST file"
|
| -DEFINE_string chrome_gold ${FLAGS_TRUE} \
|
| - "Build Chrome using gold if it is installed and supported."
|
| -DEFINE_string chrome_root "" \
|
| - "The root of your chrome browser source. Should contain a 'src' subdir. \
|
| -If this is set, chrome browser will be built from source."
|
| -DEFINE_string chronos_passwd "${CHRONOS_PASSWD}" \
|
| - "Use this as the chronos user passwd (defaults to \$CHRONOS_PASSWD)"
|
| -DEFINE_string chroot "" "Chroot to build/use"
|
| -DEFINE_boolean enable_rootfs_verification ${FLAGS_FALSE} \
|
| - "Enable rootfs verification when building image"
|
| -DEFINE_boolean force_make_chroot ${FLAGS_FALSE} "Run make_chroot indep of sync"
|
| -DEFINE_string grab_buildbot "" \
|
| - "Instead of building, grab this full image.zip URI generated by the \
|
| -buildbot"
|
| -DEFINE_boolean ignore_remote_test_failures ${FLAGS_FALSE} \
|
| - "Ignore any remote tests that failed and don't return failure"
|
| -DEFINE_boolean image_to_live ${FLAGS_FALSE} \
|
| - "Put the resulting image on live instance (requires --remote)"
|
| -DEFINE_boolean image_to_vm ${FLAGS_FALSE} "Create a VM image"
|
| -DEFINE_string image_to_usb "" \
|
| - "Treat this device as USB and put the image on it after build"
|
| -# You can set jobs > 1 but then your build may break and you may need
|
| -# to retry. Setting it to 1 is best for non-interactive sessions.
|
| -DEFINE_integer jobs -1 "Concurrent build jobs"
|
| -DEFINE_boolean master ${FLAGS_TRUE} "Master an image from built code"
|
| -DEFINE_boolean minilayout ${FLAGS_FALSE} "Use minimal code checkout"
|
| -DEFINE_boolean mod_image_for_test ${FLAGS_FALSE} "Modify the image for testing"
|
| -DEFINE_boolean official ${FLAGS_FALSE} "Sync/Build/Test official Chrome OS"
|
| -DEFINE_boolean oldchromebinary ${FLAGS_TRUE} "Always use chrome binary package"
|
| -DEFINE_string repo "${CHROMIUMOS_REPO}" "gclient repo for chromiumos"
|
| -DEFINE_boolean sync ${FLAGS_TRUE} "Sync the checkout"
|
| -DEFINE_string test "" \
|
| - "Test the built image with the given params to run_remote_tests"
|
| -DEFINE_string top "" \
|
| - "Root directory of your checkout (defaults to determining from your cwd)"
|
| -DEFINE_string vm_options "--no_graphics" "VM options"
|
| -DEFINE_boolean withdev ${FLAGS_TRUE} "Build development packages"
|
| -DEFINE_boolean usepkg ${FLAGS_TRUE} "Use binary packages"
|
| -DEFINE_boolean unittest ${FLAGS_TRUE} "Run unit tests"
|
| -DEFINE_boolean yes ${FLAGS_FALSE} "Reply yes to all prompts" y
|
| -
|
| -# Returns a heuristic indicating if we believe this to be a google internal
|
| -# development environment.
|
| -# Returns:
|
| -# 0 if so, 1 otherwise
|
| -function is_google_environment() {
|
| - hostname | egrep -q .google.com\$
|
| - return $?
|
| -}
|
| -
|
| -
|
| -# Validates parameters and sets "intelligent" defaults based on other
|
| -# parameters.
|
| -function validate_and_set_param_defaults() {
|
| - TMP=$(mktemp -d "/tmp/sync_build_test.XXXX")
|
| -
|
| - if [[ -z "${FLAGS_top}" ]]; then
|
| - local test_dir=$(pwd)
|
| - while [[ "${test_dir}" != "/" ]]; do
|
| - if [[ -d "${test_dir}/src/platform/dev" ]]; then
|
| - FLAGS_top="${test_dir}"
|
| - break
|
| - fi
|
| - test_dir=$(dirname "${test_dir}")
|
| - done
|
| - fi
|
| -
|
| - if [[ -z "${FLAGS_top}" ]]; then
|
| - # Use the top directory based on where this script runs from
|
| - FLAGS_top=${GCLIENT_ROOT}
|
| - fi
|
| -
|
| - # Canonicalize any symlinks
|
| - if [[ -d "${FLAGS_top}" ]]; then
|
| - FLAGS_top=$(readlink -f "${FLAGS_top}")
|
| - fi
|
| -
|
| - if [[ -z "${FLAGS_chroot}" ]]; then
|
| - FLAGS_chroot="${FLAGS_top}/chroot"
|
| - fi
|
| -
|
| - # If chroot does not exist, force making it
|
| - if [[ ! -d "${FLAGS_chroot}" ]]; then
|
| - FLAGS_force_make_chroot=${FLAGS_TRUE}
|
| - fi
|
| - # If chrome_root option passed, set as option for ./enter_chroot
|
| - if [[ -n "${FLAGS_chrome_root}" ]]; then
|
| - chroot_options="--chrome_root=${FLAGS_chrome_root}"
|
| - fi
|
| -
|
| - if [[ -n "${FLAGS_test}" ]]; then
|
| - # If you specify that tests should be run, we assume the image
|
| - # is modified to run tests.
|
| - FLAGS_mod_image_for_test=${FLAGS_TRUE}
|
| - if [[ -n "${FLAGS_remote}" ]]; then
|
| - # If you specify that tests should be run, we assume you want
|
| - # to live update the image.
|
| - FLAGS_image_to_live=${FLAGS_TRUE}
|
| - else
|
| - # Otherwise we assume you want to run the VM tests.
|
| - FLAGS_image_to_vm=${FLAGS_TRUE}
|
| - fi
|
| - fi
|
| -
|
| - # If they gave us a remote host, then we assume they want us to do a live
|
| - # update.
|
| - if [[ -n "${FLAGS_remote}" ]]; then
|
| - FLAGS_image_to_live=${FLAGS_TRUE}
|
| - remote_access_init
|
| - fi
|
| -
|
| - # Figure out board.
|
| - if [[ -z "${FLAGS_board}" ]]; then
|
| - if [[ -n "${FLAGS_remote}" ]]; then
|
| - learn_board
|
| - else
|
| - get_default_board
|
| - [[ -z "${DEFAULT_BOARD}" ]] && DEFAULT_BOARD="x86-generic"
|
| - FLAGS_board="${DEFAULT_BOARD}"
|
| - fi
|
| - fi
|
| -
|
| - if [[ ${FLAGS_build} -eq ${FLAGS_TRUE} ]]; then
|
| - if [[ -n "${FLAGS_chrome_root}" ]]; then
|
| - if [ ! -d "${FLAGS_chrome_root}" ]; then
|
| - die "Cannot find ${FLAGS_chrome_root} (tildes not expanded)"
|
| - fi
|
| - if [ ! -d "${FLAGS_chrome_root}/src/third_party/cros" ]; then
|
| - die "You need to add .gclient lines for Chrome on Chrome OS"
|
| - fi
|
| - fi
|
| - fi
|
| -
|
| - # Grabbing a buildbot build is exclusive with syncing and building
|
| - if [[ -n "${FLAGS_grab_buildbot}" ]]; then
|
| - if [[ "${FLAGS_grab_buildbot}" == "LATEST" ]]; then
|
| - if [[ -z "${FLAGS_buildbot_uri}" ]]; then
|
| - die "--grab_buildbot=LATEST requires --buildbot_uri or setting \
|
| -BUILDBOT_URI"
|
| - exit 1
|
| - fi
|
| - fi
|
| - FLAGS_sync=${FLAGS_FALSE}
|
| - FLAGS_build=${FLAGS_FALSE}
|
| - FLAGS_unittest=${FLAGS_FALSE}
|
| - FLAGS_master=${FLAGS_FALSE}
|
| - fi
|
| -
|
| - if [[ ${FLAGS_image_to_live} -eq ${FLAGS_TRUE} ]]; then
|
| - if [[ ${FLAGS_mod_image_for_test} -eq ${FLAGS_FALSE} ]]; then
|
| - warn "You have specified to live reimage a machine with"
|
| - warn "an image that is not modified for test (so it cannot be"
|
| - warn "later live reimaged)"
|
| - fi
|
| - if [[ -n "${FLAGS_image_to_usb}" ]]; then
|
| - warn "You have specified to both live reimage a machine and"
|
| - warn "write a USB image. Is this what you wanted?"
|
| - fi
|
| - if [[ -z "${FLAGS_remote}" ]]; then
|
| - die "Please specify --remote with --image_to_live"
|
| - fi
|
| - fi
|
| -
|
| - if [[ ${FLAGS_mod_image_for_test} -eq ${FLAGS_TRUE} ]]; then
|
| - # Override any specified chronos password with the test one
|
| - FLAGS_chronos_passwd="test0000"
|
| - # If you're modding for test, you also want developer packages.
|
| - FLAGS_withdev=${FLAGS_TRUE}
|
| - fi
|
| -
|
| - if [[ -n "${FLAGS_image_to_usb}" ]]; then
|
| - local device=${FLAGS_image_to_usb#/dev/}
|
| - if [[ -z "${device}" ]]; then
|
| - die "Expected --image_to_usb option of /dev/* format"
|
| - fi
|
| - local is_removable=$(cat /sys/block/${device}/removable)
|
| - if [[ "${is_removable}" != "1" ]]; then
|
| - die "Could not verify that ${device} for image_to_usb is removable"
|
| - fi
|
| - fi
|
| -}
|
| -
|
| -function has_board_directory() {
|
| - [[ -d "${FLAGS_top}/chroot/build/${FLAGS_board}" ]]
|
| -}
|
| -
|
| -# Prints a description of what we are doing or did
|
| -function describe_steps() {
|
| - if [[ ${FLAGS_sync} -eq ${FLAGS_TRUE} ]]; then
|
| - local is_official=""
|
| - [ ${FLAGS_official} -eq ${FLAGS_TRUE} ] && is_official=" (official)"
|
| - info " * Sync client (repo sync)${is_official} (disable using --nosync)"
|
| - fi
|
| - if [[ ${FLAGS_force_make_chroot} -eq ${FLAGS_TRUE} ]]; then
|
| - info " * Rebuild chroot (make_chroot) in ${FLAGS_chroot}"
|
| - fi
|
| - local set_passwd=${FLAGS_FALSE}
|
| - if ! has_board_directory; then
|
| - info " * Setup new board ${FLAGS_board} (setup_board)"
|
| - fi
|
| - if [[ ${FLAGS_build} -eq ${FLAGS_TRUE} ]]; then
|
| - local extra_build=""
|
| - if [[ ${FLAGS_withdev} -eq ${FLAGS_TRUE} ]]; then
|
| - extra_build=" with dev packages"
|
| - fi
|
| - if [[ ${FLAGS_oldchromebinary} -eq ${FLAGS_TRUE} ]]; then
|
| - extra_build=" (but pull Chrome binary)"
|
| - fi
|
| - info " * Build packages${extra_build} (build_packages) \
|
| -(disable using --nobuild)"
|
| - set_passwd=${FLAGS_TRUE}
|
| - if [[ ${FLAGS_build_autotest} -eq ${FLAGS_TRUE} ]]; then
|
| - info " * Cross-build autotest client tests (build_autotest)"
|
| - fi
|
| - if [[ -n "${FLAGS_chrome_root}" ]]; then
|
| - info " * After Chrome builds in build_packages, building Chrome from \
|
| -sources at ${FLAGS_chrome_root}"
|
| - fi
|
| - fi
|
| - if [[ ${FLAGS_master} -eq ${FLAGS_TRUE} ]]; then
|
| - info " * Master image (build_image) (disable using --nomaster)"
|
| - fi
|
| - if [[ -n "${FLAGS_grab_buildbot}" ]]; then
|
| - if [[ "${FLAGS_grab_buildbot}" == "LATEST" ]]; then
|
| - info " * Grab latest buildbot image under ${FLAGS_buildbot_uri}"
|
| - else
|
| - info " * Grab buildbot image zip at URI ${FLAGS_grab_buildbot}"
|
| - fi
|
| - fi
|
| - if [[ ${FLAGS_unittest} -eq ${FLAGS_TRUE} ]]; then
|
| - info " * Run cros_run_unit_tests to run all unit tests \
|
| -(disable using --nounittest)"
|
| - fi
|
| - if [[ ${FLAGS_mod_image_for_test} -eq ${FLAGS_TRUE} ]]; then
|
| - if [[ -n "${FLAGS_grab_buildbot}" ]]; then
|
| - info " * Use the prebuilt image modded for test (rootfs_test.image)"
|
| - info " * Install prebuilt cross-compiled autotests in chroot"
|
| - else
|
| - info " * Make image able to run tests (mod_image_for_test)"
|
| - fi
|
| - set_passwd=${FLAGS_TRUE}
|
| - else
|
| - info " * Not modifying image for test (enable using --mod_image_for_test)"
|
| - fi
|
| - if [[ ${set_passwd} -eq ${FLAGS_TRUE} ]]; then
|
| - if [[ -n "${FLAGS_chronos_passwd}" ]]; then
|
| - info " * Set chronos password to ${FLAGS_chronos_passwd}"
|
| - else
|
| - info " * Set chronos password randomly"
|
| - fi
|
| - fi
|
| - if [[ -n "${FLAGS_image_to_usb}" ]]; then
|
| - info " * Write the image to USB device ${FLAGS_image_to_usb}"
|
| - fi
|
| - if [[ ${FLAGS_image_to_live} -eq ${FLAGS_TRUE} ]]; then
|
| - info " * Reimage live test Chromium OS instance at ${FLAGS_remote}"
|
| - fi
|
| - if [[ ${FLAGS_image_to_vm} -eq ${FLAGS_TRUE} ]]; then
|
| - info " * Copy off a separate VM image"
|
| - fi
|
| - if [[ -n "${FLAGS_test}" ]]; then
|
| - if [[ -n "${FLAGS_remote}" ]]; then
|
| - info " * Run (and build) tests (${FLAGS_test}) on machine at \
|
| -${FLAGS_remote}"
|
| - else
|
| - info " * Start a VM locally and run (and build) tests (${FLAGS_test}) \
|
| -on it"
|
| - fi
|
| - else
|
| - info " * Not running any autotests (pass --test=suite_Smoke for instance \
|
| -to change)"
|
| - fi
|
| -}
|
| -
|
| -# Prompt user Y/N to continue
|
| -function prompt_to_continue() {
|
| - if [ ${FLAGS_yes} -eq ${FLAGS_TRUE} ]; then
|
| - info "Continuing without prompting since you passed --yes"
|
| - return
|
| - fi
|
| - echo ""
|
| - read -p "Are you sure (y/N)? " SURE
|
| - echo "(Pass -y to skip this prompt)"
|
| - echo ""
|
| - # Get just the first character
|
| - if [[ "${SURE:0:1}" != "y" ]]; then
|
| - die "Ok, better safe than sorry."
|
| - fi
|
| -}
|
| -
|
| -# Get user's permission on steps to take
|
| -function interactive() {
|
| - echo ""
|
| - info "Planning these steps on ${FLAGS_top} for ${FLAGS_board}:"
|
| - describe_steps
|
| - prompt_to_continue
|
| -}
|
| -
|
| -# Changes to a directory relative to the top/root directory of
|
| -# the checkout.
|
| -# Arguments:
|
| -# $1 - relative path
|
| -function chdir_relative() {
|
| - local dir=$1
|
| - info "Running: cd ${dir}"
|
| - # Allow use of .. before the innermost directory of FLAGS_top exists
|
| - if [[ "${dir}" == ".." ]]; then
|
| - dir=$(dirname "${FLAGS_top}")
|
| - else
|
| - dir="${FLAGS_top}/${dir}"
|
| - fi
|
| - cd "${dir}"
|
| -}
|
| -
|
| -
|
| -function info_div {
|
| - info "#############################################################"
|
| -}
|
| -
|
| -# Describe to the user that a phase is running (and make it obviously when
|
| -# scrolling through lots of output).
|
| -# Arguments:
|
| -# $1 - phase description
|
| -function describe_phase() {
|
| - local desc="$1"
|
| - echo ""
|
| - info_div
|
| - info "${desc}"
|
| -}
|
| -
|
| -function cleanup() {
|
| - [ -n "${TMP}" ] && rm -rf "${TMP}"
|
| - cleanup_remote_access
|
| -}
|
| -
|
| -# Called when there is a failure and we exit early
|
| -function failure() {
|
| - trap - EXIT
|
| - # Clear these out just in case.
|
| - export GSDCURL_USERNAME=""
|
| - export GSDCURL_PASSWORD=""
|
| - describe_phase "Failure during: ${LAST_PHASE}"
|
| - show_duration
|
| - info_div
|
| - cleanup
|
| -}
|
| -
|
| -
|
| -# Runs a phase, describing it first, and also updates the sudo timeout
|
| -# afterwards.
|
| -# Arguments:
|
| -# $1 - phase description
|
| -# $2.. - command/params to run
|
| -function run_phase() {
|
| - local desc="$1"
|
| - shift
|
| - LAST_PHASE="${desc}"
|
| - describe_phase "${desc}"
|
| - local line="Running: "
|
| - line+=$@
|
| - info "${line}"
|
| - info_div
|
| - echo ""
|
| - "$@"
|
| - sudo true
|
| -}
|
| -
|
| -
|
| -# Runs a phase, similar to run_phase, but runs within the chroot.
|
| -# Arguments:
|
| -# $1 - phase description
|
| -# $2.. - command/params to run in chroot
|
| -function run_phase_in_chroot() {
|
| - local desc="$1"
|
| - shift
|
| - run_phase "${desc}" ./enter_chroot.sh "--chroot=${FLAGS_chroot}" \
|
| - ${chroot_options} -- "$@"
|
| -}
|
| -
|
| -
|
| -# Record start time.
|
| -function set_start_time() {
|
| - START_TIME=$(date '+%s')
|
| -}
|
| -
|
| -
|
| -# Display duration
|
| -function show_duration() {
|
| - local current_time=$(date '+%s')
|
| - local duration=$((${current_time} - ${START_TIME}))
|
| - local minutes_duration=$((${duration} / 60))
|
| - local seconds_duration=$((${duration} % 60))
|
| - info "$(printf "Total time: %d:%02ds\n" "${minutes_duration}" \
|
| - "${seconds_duration}")"
|
| -}
|
| -
|
| -# Runs repo init on a new checkout directory.
|
| -function config_new_repo_checkout() {
|
| - mkdir -p "${FLAGS_top}"
|
| - cd "${FLAGS_top}"
|
| - local minilayout=""
|
| - [ ${FLAGS_minilayout} -eq ${FLAGS_TRUE} ] && minilayout="-m minilayout.xml"
|
| - local git_uri="http://git.chromium.org/git/manifest"
|
| - if [ ${FLAGS_official} -eq ${FLAGS_TRUE} ]; then
|
| - git_uri="ssh://git@gitrw.chromium.org:9222/manifest-internal"
|
| - fi
|
| - repo init -u "${git_uri}" ${minilayout}
|
| -}
|
| -
|
| -# Configures/initializes a new checkout
|
| -function config_new_checkout() {
|
| - info "Checking out ${FLAGS_top}"
|
| - config_new_repo_checkout
|
| -}
|
| -
|
| -# Runs gclient sync, setting up .chromeos_dev and preparing for
|
| -# local repo setup
|
| -function sync() {
|
| - # cd to the directory below
|
| - chdir_relative .
|
| - run_phase "Synchronizing client" repo sync
|
| - # Change to a directory that is definitely a git repo
|
| - chdir_relative src/third_party/chromiumos-overlay
|
| - git cl config "file://$(pwd)/../../../codereview.settings"
|
| - chdir_relative .
|
| -}
|
| -
|
| -
|
| -# Downloads a buildbot image
|
| -function grab_buildbot() {
|
| - read -p "Username [${LOGNAME}]: " GSDCURL_USERNAME
|
| - export GSDCURL_USERNAME
|
| - read -s -p "Password: " GSDCURL_PASSWORD
|
| - export GSDCURL_PASSWORD
|
| - CURL="${SCRIPTS_DIR}/bin/cros_gsdcurl.py"
|
| - if [[ "${FLAGS_grab_buildbot}" == "LATEST" ]]; then
|
| - local latest=$(${CURL} "${FLAGS_buildbot_uri}/LATEST")
|
| - if [[ -z "${latest}" ]]; then
|
| - die "Error finding latest."
|
| - fi
|
| - FLAGS_grab_buildbot="${FLAGS_buildbot_uri}/${latest}/image.zip"
|
| - fi
|
| - local dl_dir="${TMP}/image"
|
| - mkdir -p "${dl_dir}"
|
| -
|
| - info "Grabbing image from ${FLAGS_grab_buildbot} to ${dl_dir}"
|
| - run_phase "Downloading image" ${CURL} "${FLAGS_grab_buildbot}" \
|
| - -o "${dl_dir}/image.zip"
|
| - # Clear out the credentials so they can't be used later.
|
| - export GSDCURL_USERNAME=""
|
| - export GSDCURL_PASSWORD=""
|
| -
|
| - cd "${dl_dir}"
|
| - unzip image.zip
|
| - local image_basename=$(basename "$(dirname "${FLAGS_grab_buildbot}")")
|
| - local image_base_dir="${FLAGS_top}/src/build/images/${FLAGS_board}"
|
| - local image_dir="${image_base_dir}/${image_basename}"
|
| - info "Copying in build image to ${image_dir}"
|
| - rm -rf "${image_dir}"
|
| - mkdir -p "${image_dir}"
|
| - if [[ ${FLAGS_mod_image_for_test} -eq ${FLAGS_TRUE} ]]; then
|
| - run_phase "Installing buildbot test modified image" \
|
| - mv chromiumos_test_image.bin "${image_dir}/chromiumos_image.bin"
|
| - FLAGS_mod_image_for_test=${FLAGS_FALSE}
|
| - else
|
| - run_phase "Installing buildbot base image" \
|
| - mv chromiumos_base_image.bin "${image_dir}/chromiumos_image.bin"
|
| - fi
|
| -
|
| - if [[ -n "${FLAGS_test}" ]]; then
|
| - if [[ ! -d "${FLAGS_top}/chroot/build/${FLAGS_board}" ]]; then
|
| - die "To run tests on a buildbot image, run setup_board first."
|
| - fi
|
| - if [[ -e "autotest.tgz" || -e "autotest.tar.bz2" ]]; then
|
| - # pull in autotest
|
| - local dir="${FLAGS_chroot}/build/${FLAGS_board}/usr/local"
|
| - local tar_args="xzf"
|
| - local tar_name="${dl_dir}/autotest.tgz"
|
| - if [[ -e "autotest.tar.bz2" ]]; then
|
| - tar_args="xjf"
|
| - tar_name="${dl_dir}/autotest.tar.bz2"
|
| - fi
|
| - sudo rm -rf "${dir}/autotest"
|
| - # Expand in temp directory as current user, then move it as
|
| - # root to keep local user ownership
|
| - run_phase "Unpacking buildbot autotest cross-compiled binaries" \
|
| - tar ${tar_args} "${tar_name}"
|
| - run_phase "Installing buildbot autotest cross-compiled binaries" \
|
| - sudo mv autotest ${dir}
|
| - fi
|
| - fi
|
| - chdir_relative .
|
| - run_phase "Removing downloaded image" rm -rf "${dl_dir}"
|
| -}
|
| -
|
| -
|
| -function main() {
|
| - assert_outside_chroot
|
| - assert_not_root_user
|
| -
|
| - # Parse command line
|
| - FLAGS "$@" || exit 1
|
| - eval set -- "${FLAGS_ARGV}"
|
| -
|
| - # Die on any errors.
|
| - set -e
|
| -
|
| - validate_and_set_param_defaults
|
| -
|
| - # Cache up sudo status
|
| - sudo true
|
| -
|
| - interactive
|
| -
|
| - set_start_time
|
| - trap failure EXIT
|
| -
|
| - local withdev_param=""
|
| - if [[ ${FLAGS_withdev} -eq ${FLAGS_TRUE} ]]; then
|
| - withdev_param="--withdev"
|
| - fi
|
| -
|
| - local jobs_param=""
|
| - if [[ ${FLAGS_jobs} -gt 1 ]]; then
|
| - jobs_param="--jobs=${FLAGS_jobs}"
|
| - fi
|
| -
|
| - local board_param="--board=${FLAGS_board}"
|
| -
|
| - if [[ ! -e "${FLAGS_top}" ]]; then
|
| - config_new_checkout
|
| - fi
|
| -
|
| - if [[ ${FLAGS_sync} -eq ${FLAGS_TRUE} ]]; then
|
| - sync
|
| - fi
|
| -
|
| - if [[ -n "${FLAGS_grab_buildbot}" ]]; then
|
| - grab_buildbot
|
| - fi
|
| -
|
| - if [[ ${FLAGS_force_make_chroot} -eq ${FLAGS_TRUE} ]]; then
|
| - chdir_relative src/scripts
|
| - run_phase "Replacing chroot" ./make_chroot --replace \
|
| - "--chroot=${FLAGS_chroot}" ${jobs_param}
|
| - fi
|
| -
|
| - if [[ ${FLAGS_build} -eq ${FLAGS_TRUE} ]]; then
|
| - # It's necessary to enable localaccount for BVT tests to pass.
|
| - chdir_relative src/scripts
|
| - run_phase "Enable local account" \
|
| - ./enable_localaccount.sh chronos "${FLAGS_chroot}"
|
| -
|
| - local pkg_param=""
|
| - if [[ ${FLAGS_usepkg} -eq ${FLAGS_FALSE} ]]; then
|
| - pkg_param="--nousepkg"
|
| - fi
|
| -
|
| - chdir_relative src/scripts
|
| - # Only setup board target if the directory does not exist
|
| - if ! has_board_directory; then
|
| - run_phase_in_chroot "Setting up board target" \
|
| - ./setup_board ${pkg_param} "${board_param}"
|
| - fi
|
| - local build_autotest_param=""
|
| - if [[ ${FLAGS_build_autotest} -eq ${FLAGS_TRUE} ]]; then
|
| - build_autotest_param="--withautotest"
|
| - fi
|
| - if [[ ${FLAGS_oldchromebinary} -eq ${FLAGS_TRUE} ]]; then
|
| - pkg_param="${pkg_param} --oldchromebinary"
|
| - fi
|
| -
|
| - run_phase_in_chroot "Building packages" \
|
| - ./build_packages "${board_param}" \
|
| - ${withdev_param} ${build_autotest_param} \
|
| - ${pkg_param}
|
| - fi
|
| -
|
| - if [[ ${FLAGS_chrome_root} ]]; then
|
| - chdir_relative src/scripts
|
| - # You can always pass USE=gold, the ebuild will only really use
|
| - # gold if x86 and the binaries are found.
|
| - local chrome_use=""
|
| - if [ ${FLAGS_chrome_gold} -eq ${FLAGS_TRUE} ]; then
|
| - chrome_use="${chrome_use} gold"
|
| - fi
|
| - if [ ${FLAGS_official} -eq ${FLAGS_TRUE} ]; then
|
| - chrome_use="${chrome_use} internal"
|
| - fi
|
| - [ -z "${FLAGS_test}" ] && chrome_use="${chrome_use} -build_tests"
|
| - run_phase_in_chroot "Building Chromium browser" env \
|
| - BOARD="${FLAGS_board}" USE="${chrome_use}" FEATURES="-usersandbox" \
|
| - CHROME_ORIGIN=LOCAL_SOURCE emerge-${FLAGS_board} chromeos-chrome
|
| - fi
|
| -
|
| - if [[ ${FLAGS_unittest} -eq ${FLAGS_TRUE} ]] && \
|
| - [[ "${FLAGS_board}" == "x86-generic" ]] ; then
|
| - chdir_relative src/scripts
|
| - run_phase_in_chroot "Running unit tests" ./cros_run_unit_tests \
|
| - ${board_param}
|
| - fi
|
| -
|
| - if [[ ${FLAGS_master} -eq ${FLAGS_TRUE} ]]; then
|
| - chdir_relative src/scripts
|
| - if [[ -n "${FLAGS_chronos_passwd}" ]]; then
|
| - run_phase_in_chroot "Setting default chronos password" \
|
| - sh -c "echo '${FLAGS_chronos_passwd}' | \
|
| - ~/trunk/src/scripts/set_shared_user_password.sh"
|
| - fi
|
| - local other_params="--enable_rootfs_verification"
|
| - if [[ ${FLAGS_enable_rootfs_verification} -eq ${FLAGS_FALSE} ]]; then
|
| - other_params="--noenable_rootfs_verification"
|
| - fi
|
| - run_phase_in_chroot "Mastering image" ./build_image \
|
| - "${board_param}" --replace ${withdev_param} \
|
| - ${jobs_param} ${other_params}
|
| - fi
|
| -
|
| - if [[ ${FLAGS_mod_image_for_test} -eq ${FLAGS_TRUE} ]]; then
|
| - chdir_relative src/scripts
|
| - run_phase_in_chroot "Modifying image for test" \
|
| - "./mod_image_for_test.sh" "${board_param}" --yes
|
| - fi
|
| -
|
| - if [[ -n "${FLAGS_image_to_usb}" ]]; then
|
| - chdir_relative src/scripts
|
| - run_phase "Installing image to USB" \
|
| - ./image_to_usb.sh --yes "--to=${FLAGS_image_to_usb}" "${board_param}"
|
| - fi
|
| -
|
| - if [[ ${FLAGS_image_to_live} -eq ${FLAGS_TRUE} ]]; then
|
| - chdir_relative src/scripts
|
| - run_phase "Re-imaging live Chromium OS machine ${FLAGS_remote}" \
|
| - ./image_to_live.sh "--remote=${FLAGS_remote}" --update_known_hosts
|
| - fi
|
| -
|
| - if [[ ${FLAGS_image_to_vm} -eq ${FLAGS_TRUE} ]]; then
|
| - chdir_relative src/scripts
|
| - run_phase_in_chroot "Creating VM image from existing image" \
|
| - ./image_to_vm.sh "--board=${FLAGS_board}"
|
| - fi
|
| -
|
| - if [[ -n "${FLAGS_test}" ]]; then
|
| - chdir_relative src/scripts
|
| - if [[ -z "${FLAGS_remote}" ]]; then
|
| - # Launch remote machine and run tests. We need first to
|
| - # figure out what IP to use.
|
| - if ! run_phase "Running VM tests locally" \
|
| - ./bin/cros_run_vm_test "--board=${FLAGS_board}" \
|
| - "--test_case=${FLAGS_test}" ${FLAGS_vm_options}; then
|
| - if [[ ${FLAGS_ignore_remote_test_failures} -eq ${FLAGS_FALSE} ]]; then
|
| - die "VM tests failed and --ignore_remote_test_failures not passed"
|
| - fi
|
| - fi
|
| - else
|
| - # We purposefully do not quote FLAGS_test below as we expect it may
|
| - # have multiple parameters
|
| - if ! run_phase "Running tests on Chromium OS machine ${FLAGS_remote}" \
|
| - ./run_remote_tests.sh "--remote=${FLAGS_remote}" ${FLAGS_test} \
|
| - "${board_param}" --build; then
|
| - if [[ ${FLAGS_ignore_remote_test_failures} -eq ${FLAGS_FALSE} ]]; then
|
| - die "Remote tests failed and --ignore_remote_test_failures not passed"
|
| - fi
|
| - fi
|
| - fi
|
| - fi
|
| -
|
| - trap cleanup EXIT
|
| - echo ""
|
| - info_div
|
| - info "Successfully used ${FLAGS_top} to:"
|
| - describe_steps
|
| - show_duration
|
| - info_div
|
| -}
|
| -
|
| -main "$@"
|
| -
|
|
|