]> git.wh0rd.org - home.git/blame - .bin/cros-board
cros-board: use test image for VMs
[home.git] / .bin / cros-board
CommitLineData
3c347239
MF
1#!/bin/bash
2. /etc/init.d/functions.sh || exit 1
3die() { eerror "$*"; exit 1; }
4set -e
5
39055191
MF
6BASE="/mnt/host/source"
7d="${BASE}/src/scripts"
8BUILD_DIR="${BASE}/src/build"
9cd "${BASE}/src/scripts/"
3c347239 10
fb105d3a 11: "${BOARD:="$(cat .default_board 2>/dev/null)"}"
3c347239
MF
12if [[ -z ${BOARD} ]] ; then
13 die "missing BOARD"
14fi
39055191 15IMAGES="${BASE}/src/build/images/${BOARD}"
3c347239
MF
16BUILD="/build/${BOARD}"
17
fb105d3a
MF
18usage() {
19 exec cat <<EOF
20Usage: cros-board [options]
21
22Build for the board listed in \${BOARD} (current: ${BOARD}).
23Normally only builds a dev image.
24
25Options:
26 -t Build test packages & image
27 --autotest Build & install autotest packages.
28 --factory Build factory packages & image.
29 --nousepkg Force build from source.
30
31 --clean ?
32
33 -Y Write image to ${ARG_DEV} w/out prompting.
34 -y <dev> Write image to <dev> w/out prompting.
35
36 -p Pretend -- show commands that would be run.
37 -v Verbose -- send command output to stdout.
38EOF
39}
40
dd5fec28
MF
41find_first_removable() {
42 local d
43 cd /sys/block
44 for d in sd? ; do
45 if [[ $(cat "${d}/removable" 2>/dev/null) == "1" ]]; then
46 echo "/dev/${d}"
47 return 0
48 fi
49 done
50 return 0
51}
52
3c347239 53ARG_CLEAN=false
dd5fec28 54ARG_DEV="$(find_first_removable)"
3c347239
MF
55ARG_DEV_USER=false
56ARG_PRETEND=false
57ARG_NOPKG=false
b04356b4 58ARG_AUTOTEST=false
c3634e71 59ARG_FACTORY=false
3c347239
MF
60ARG_VERBOSE=false
61ARG_TEST=false
62while [[ $# -ne 0 ]] ; do
63 case $1 in
64 --clean) ARG_CLEAN=true;;
65 -p) ARG_PRETEND=true;;
eecfe1d6 66 -Y) ARG_DEV_USER=true;;
3c347239
MF
67 -y) shift; ARG_DEV=$1; ARG_DEV_USER=true;;
68 -v) ARG_VERBOSE=true;;
69 -t) ARG_TEST=true;;
70 --nousepkg) ARG_NOPKG=true;;
b04356b4 71 --autotest) ARG_AUTOTEST=true;;
c3634e71 72 --factory) ARG_FACTORY=true;;
fb105d3a 73 -h) usage;;
3c347239
MF
74 *) echo "unknown opt: $*"; exit 1;;
75 esac
76 shift
77done
78
79piperet() { set -- ${PIPESTATUS[@]/0}; [[ $# -eq 0 ]]; }
80run() {
81 set +e
3c347239 82 if ! ${ARG_PRETEND} ; then
00220d98 83 ebegin "$*"
3c347239
MF
84 local log="${IMAGES}"/log.${1##*/}
85 if ${ARG_VERBOSE} ; then
86 "$@" |& tee "${log}"
87 else
88 "$@" >& "${log}"
89 fi
90 piperet
00220d98
MF
91 eend $? || exit $?
92 else
d828d904 93 echo "$*"
3c347239 94 fi
3c347239
MF
95 set -e
96}
97
b04356b4 98tfe() { ($1 && echo $2 || echo $3); }
3c347239
MF
99
100mkdir -p "${IMAGES}"
101rm -f "${IMAGES}"/log.*
102
103einfo "Log root: ${IMAGES}/log."
104
5a4df9c9 105run ./update_chroot --toolchain_boards=${BOARD}
469b7be8 106
3c347239
MF
107if ${ARG_CLEAN} || [[ ! -d ${BUILD} ]] ; then
108 run sudo rm -rf "${BUILD}"
39055191 109 run setup_board --board=${BOARD} --skip-chroot-upgrade
ef381d05 110 if [[ $? -ne 0 ]] ; then
3c347239
MF
111 run sudo rm -rf "${BUILD}"
112 exit 1
113 fi
114fi
115
1061bc32
MF
116run ./build_packages \
117 --board=${BOARD} \
1061bc32 118 --nowithdebug \
d828d904 119 --nowithrevdeps \
39055191 120 --skip-chroot-upgrade \
ef381d05 121 --autosetgov \
b04356b4 122 $(tfe ${ARG_AUTOTEST} --{,no}withautotest) \
c3634e71 123 $(tfe ${ARG_FACTORY} --{,no}withfactory) \
b04356b4
MF
124 $(tfe ${ARG_NOPKG} --{no,}usepkg) \
125 $(tfe ${ARG_TEST} --{,no}withtest)
ef381d05 126BUILD_IMG="./build_image --board=${BOARD} --noenable_rootfs_verification $(tfe ${ARG_TEST} test base)"
3c347239
MF
127run ${BUILD_IMG}
128
f9163cb5 129IMG_TO_USB="cros flash --yes usb://${ARG_DEV} xbuddy://local/${BOARD}/latest/dev"
3c347239
MF
130if ${ARG_DEV_USER} ; then
131 run ${IMG_TO_USB}
132 sync &
133fi
134
42e1a176
MF
135cd "${IMAGES}"
136rm -rf $(ls -td1R `find -mindepth 1 -maxdepth 1 -type d` | sed -e 1d -e 2d)
137
1227e08d 138BUILD_IMG="${d}/${BUILD_IMG#./}"
3c347239
MF
139cat <<EOF
140
141### LIVE
142${IMG_TO_USB}
143
144### KVM
df8cd743 145~/chromiumos/chromite/bin/cros_vm --board=${BOARD} --start --no-display --image-path=\${HOME}/chromiumos/src/build/images/${BOARD}/latest/chromiumos_test_image.bin
dd5fec28 146#--kvm_cpu "max,vmx=on"
93639020
MF
147
148https://dev.chromium.org/chromium-os/testing/running-smoke-suite-on-a-vm-image
149
150/usr/local/autotest/bin/autologin.py
151
dd5fec28 152export CROS_USER_ID_HASH=\$(ls /home/user/)
93639020
MF
153sudo -u chronos CROS_USER_ID_HASH="${CROS_USER_ID_HASH}" crosh
154 vmc start termina # might run twice
3c347239
MF
155
156### RECOVERY
ebedbad3 157${d}/mod_image_for_recovery.sh --board=${BOARD}
91b5b449 158${IMG_TO_USB%/dev}/recovery
3c347239
MF
159
160### FACTORY
161${BUILD_IMG} --factory_install
162${IMG_TO_USB} -i factory_install_shim.bin
163
164EOF