Jesse Andrews | 8b3eb5f | 2011-11-05 16:05:14 -0700 | [diff] [blame] | 1 | #!/usr/bin/env bash |
| 2 | |
Anthony Young | e28f775 | 2011-11-09 11:48:09 -0800 | [diff] [blame] | 3 | # Make sure that we have the proper version of ubuntu (only works on oneiric) |
| 4 | if ! egrep -q "oneiric" /etc/lsb-release; then |
Anthony Young | 593e9aa | 2011-11-09 12:42:08 -0800 | [diff] [blame] | 5 | echo "This script only works with ubuntu oneiric." |
Jesse Andrews | e3c47a3 | 2011-11-07 10:44:43 -0800 | [diff] [blame] | 6 | exit 1 |
Jesse Andrews | 8b3eb5f | 2011-11-05 16:05:14 -0700 | [diff] [blame] | 7 | fi |
| 8 | |
Jesse Andrews | 8b3eb5f | 2011-11-05 16:05:14 -0700 | [diff] [blame] | 9 | # Keep track of the current directory |
| 10 | TOOLS_DIR=$(cd $(dirname "$0") && pwd) |
| 11 | TOP_DIR=`cd $TOOLS_DIR/..; pwd` |
| 12 | |
Jesse Andrews | 53d7533 | 2011-11-06 07:54:11 -0800 | [diff] [blame] | 13 | cd $TOP_DIR |
| 14 | |
| 15 | # Source params |
| 16 | source ./stackrc |
| 17 | |
| 18 | # Ubuntu distro to install |
| 19 | DIST_NAME=${DIST_NAME:-oneiric} |
| 20 | |
Jesse Andrews | e3c47a3 | 2011-11-07 10:44:43 -0800 | [diff] [blame] | 21 | # Configure how large the VM should be |
| 22 | GUEST_SIZE=${GUEST_SIZE:-10G} |
| 23 | |
Jesse Andrews | 228f246 | 2011-11-05 17:36:14 -0700 | [diff] [blame] | 24 | # exit on error to stop unexpected errors |
| 25 | set -o errexit |
| 26 | set -o xtrace |
| 27 | |
Jesse Andrews | 8b3eb5f | 2011-11-05 16:05:14 -0700 | [diff] [blame] | 28 | # Abort if localrc is not set |
| 29 | if [ ! -e $TOP_DIR/localrc ]; then |
| 30 | echo "You must have a localrc with ALL necessary passwords defined before proceeding." |
| 31 | echo "See stack.sh for required passwords." |
| 32 | exit 1 |
| 33 | fi |
| 34 | |
| 35 | # Install deps if needed |
Jesse Andrews | 2679303 | 2011-11-11 13:56:29 -0800 | [diff] [blame] | 36 | DEPS="kvm libvirt-bin kpartx cloud-utils curl" |
Anthony Young | 8326fd2 | 2011-11-15 13:03:19 -0800 | [diff] [blame] | 37 | apt-get install -y --force-yes $DEPS || true # allow this to fail gracefully for concurrent builds |
Jesse Andrews | 8b3eb5f | 2011-11-05 16:05:14 -0700 | [diff] [blame] | 38 | |
| 39 | # Where to store files and instances |
Jesse Andrews | d7326d2 | 2011-11-20 10:02:26 -0800 | [diff] [blame] | 40 | WORK_DIR=${WORK_DIR:-/opt/uecstack} |
Jesse Andrews | 8b3eb5f | 2011-11-05 16:05:14 -0700 | [diff] [blame] | 41 | |
| 42 | # Where to store images |
Jesse Andrews | 228f246 | 2011-11-05 17:36:14 -0700 | [diff] [blame] | 43 | image_dir=$WORK_DIR/images/$DIST_NAME |
| 44 | mkdir -p $image_dir |
Jesse Andrews | 8b3eb5f | 2011-11-05 16:05:14 -0700 | [diff] [blame] | 45 | |
Jesse Andrews | d7326d2 | 2011-11-20 10:02:26 -0800 | [diff] [blame] | 46 | # Start over with a clean base image, if desired |
| 47 | if [ $CLEAN_BASE ]; then |
| 48 | rm -f $image_dir/disk |
Jesse Andrews | 8b3eb5f | 2011-11-05 16:05:14 -0700 | [diff] [blame] | 49 | fi |
| 50 | |
Jesse Andrews | d7326d2 | 2011-11-20 10:02:26 -0800 | [diff] [blame] | 51 | # Get the base image if it does not yet exist |
| 52 | if [ ! -e $image_dir/disk ]; then |
| 53 | $TOOLS_DIR/get_uec_image.sh -r $GUEST_SIZE $DIST_NAME $image_dir/disk $image_dir/kernel |
| 54 | fi |
Jesse Andrews | 8b3eb5f | 2011-11-05 16:05:14 -0700 | [diff] [blame] | 55 | |
Jesse Andrews | d7326d2 | 2011-11-20 10:02:26 -0800 | [diff] [blame] | 56 | # Copy over dev environment if COPY_ENV is set. |
| 57 | # This will also copy over your current devstack. |
| 58 | if [ $COPY_ENV ]; then |
| 59 | cd $TOOLS_DIR |
| 60 | ./copy_dev_environment_to_uec.sh $image_dir/disk |
| 61 | fi |
| 62 | |
| 63 | # Option to warm the base image with software requirements. |
| 64 | if [ $WARM_CACHE ]; then |
| 65 | cd $TOOLS_DIR |
| 66 | ./warm_apts_and_pips_for_uec.sh $image_dir/disk |
| 67 | fi |
Jesse Andrews | 8b3eb5f | 2011-11-05 16:05:14 -0700 | [diff] [blame] | 68 | |
| 69 | # Name of our instance, used by libvirt |
| 70 | GUEST_NAME=${GUEST_NAME:-devstack} |
| 71 | |
| 72 | # Mop up after previous runs |
| 73 | virsh destroy $GUEST_NAME || true |
| 74 | |
| 75 | # Where this vm is stored |
Jesse Andrews | 228f246 | 2011-11-05 17:36:14 -0700 | [diff] [blame] | 76 | vm_dir=$WORK_DIR/instances/$GUEST_NAME |
Jesse Andrews | 8b3eb5f | 2011-11-05 16:05:14 -0700 | [diff] [blame] | 77 | |
| 78 | # Create vm dir and remove old disk |
Jesse Andrews | 228f246 | 2011-11-05 17:36:14 -0700 | [diff] [blame] | 79 | mkdir -p $vm_dir |
| 80 | rm -f $vm_dir/disk |
Jesse Andrews | 8b3eb5f | 2011-11-05 16:05:14 -0700 | [diff] [blame] | 81 | |
| 82 | # Create a copy of the base image |
Jesse Andrews | f5a7691 | 2011-11-05 17:47:50 -0700 | [diff] [blame] | 83 | qemu-img create -f qcow2 -b $image_dir/disk $vm_dir/disk |
Jesse Andrews | 8b3eb5f | 2011-11-05 16:05:14 -0700 | [diff] [blame] | 84 | |
| 85 | # Back to devstack |
| 86 | cd $TOP_DIR |
| 87 | |
| 88 | GUEST_NETWORK=${GUEST_NETWORK:-1} |
| 89 | GUEST_RECREATE_NET=${GUEST_RECREATE_NET:-yes} |
| 90 | GUEST_IP=${GUEST_IP:-192.168.$GUEST_NETWORK.50} |
| 91 | GUEST_CIDR=${GUEST_CIDR:-$GUEST_IP/24} |
| 92 | GUEST_NETMASK=${GUEST_NETMASK:-255.255.255.0} |
| 93 | GUEST_GATEWAY=${GUEST_GATEWAY:-192.168.$GUEST_NETWORK.1} |
| 94 | GUEST_MAC=${GUEST_MAC:-"02:16:3e:07:69:`printf '%02X' $GUEST_NETWORK`"} |
| 95 | GUEST_RAM=${GUEST_RAM:-1524288} |
| 96 | GUEST_CORES=${GUEST_CORES:-1} |
| 97 | |
| 98 | # libvirt.xml configuration |
Jesse Andrews | 228f246 | 2011-11-05 17:36:14 -0700 | [diff] [blame] | 99 | NET_XML=$vm_dir/net.xml |
Anthony Young | 8b47cdf | 2011-11-09 23:36:18 -0800 | [diff] [blame] | 100 | NET_NAME=${NET_NAME:-devstack-$GUEST_NETWORK} |
Jesse Andrews | 8b3eb5f | 2011-11-05 16:05:14 -0700 | [diff] [blame] | 101 | cat > $NET_XML <<EOF |
| 102 | <network> |
Anthony Young | 8b47cdf | 2011-11-09 23:36:18 -0800 | [diff] [blame] | 103 | <name>$NET_NAME</name> |
Jesse Andrews | 8b3eb5f | 2011-11-05 16:05:14 -0700 | [diff] [blame] | 104 | <bridge name="stackbr%d" /> |
| 105 | <forward/> |
Jesse Andrews | a628262 | 2011-11-05 18:39:33 -0700 | [diff] [blame] | 106 | <ip address="$GUEST_GATEWAY" netmask="$GUEST_NETMASK"> |
| 107 | <dhcp> |
Jesse Andrews | 02cc96c | 2011-11-06 10:29:10 -0800 | [diff] [blame] | 108 | <range start='192.168.$GUEST_NETWORK.2' end='192.168.$GUEST_NETWORK.127' /> |
Jesse Andrews | a628262 | 2011-11-05 18:39:33 -0700 | [diff] [blame] | 109 | </dhcp> |
| 110 | </ip> |
Jesse Andrews | 8b3eb5f | 2011-11-05 16:05:14 -0700 | [diff] [blame] | 111 | </network> |
| 112 | EOF |
| 113 | |
| 114 | if [[ "$GUEST_RECREATE_NET" == "yes" ]]; then |
Anthony Young | 8b47cdf | 2011-11-09 23:36:18 -0800 | [diff] [blame] | 115 | virsh net-destroy $NET_NAME || true |
Jesse Andrews | dca8900 | 2011-11-06 10:33:33 -0800 | [diff] [blame] | 116 | # destroying the network isn't enough to delete the leases |
Anthony Young | 8b47cdf | 2011-11-09 23:36:18 -0800 | [diff] [blame] | 117 | rm -f /var/lib/libvirt/dnsmasq/$NET_NAME.leases |
Jesse Andrews | 228f246 | 2011-11-05 17:36:14 -0700 | [diff] [blame] | 118 | virsh net-create $vm_dir/net.xml |
Jesse Andrews | 8b3eb5f | 2011-11-05 16:05:14 -0700 | [diff] [blame] | 119 | fi |
| 120 | |
| 121 | # libvirt.xml configuration |
Jesse Andrews | 228f246 | 2011-11-05 17:36:14 -0700 | [diff] [blame] | 122 | LIBVIRT_XML=$vm_dir/libvirt.xml |
Jesse Andrews | 8b3eb5f | 2011-11-05 16:05:14 -0700 | [diff] [blame] | 123 | cat > $LIBVIRT_XML <<EOF |
| 124 | <domain type='kvm'> |
| 125 | <name>$GUEST_NAME</name> |
| 126 | <memory>$GUEST_RAM</memory> |
| 127 | <os> |
Jesse Andrews | 228f246 | 2011-11-05 17:36:14 -0700 | [diff] [blame] | 128 | <type>hvm</type> |
Jesse Andrews | f5a7691 | 2011-11-05 17:47:50 -0700 | [diff] [blame] | 129 | <kernel>$image_dir/kernel</kernel> |
Jesse Andrews | 438ea57 | 2011-11-05 22:33:49 -0700 | [diff] [blame] | 130 | <cmdline>root=/dev/vda ro console=ttyS0 init=/usr/lib/cloud-init/uncloud-init ds=nocloud-net;s=http://192.168.$GUEST_NETWORK.1:4567/ ubuntu-pass=ubuntu</cmdline> |
Jesse Andrews | 8b3eb5f | 2011-11-05 16:05:14 -0700 | [diff] [blame] | 131 | </os> |
| 132 | <features> |
| 133 | <acpi/> |
| 134 | </features> |
| 135 | <clock offset='utc'/> |
| 136 | <vcpu>$GUEST_CORES</vcpu> |
| 137 | <devices> |
| 138 | <disk type='file'> |
| 139 | <driver type='qcow2'/> |
Jesse Andrews | 228f246 | 2011-11-05 17:36:14 -0700 | [diff] [blame] | 140 | <source file='$vm_dir/disk'/> |
Jesse Andrews | 8b3eb5f | 2011-11-05 16:05:14 -0700 | [diff] [blame] | 141 | <target dev='vda' bus='virtio'/> |
| 142 | </disk> |
| 143 | |
| 144 | <interface type='network'> |
Anthony Young | 72eab22 | 2011-11-09 23:38:18 -0800 | [diff] [blame] | 145 | <source network='$NET_NAME'/> |
Jesse Andrews | 8b3eb5f | 2011-11-05 16:05:14 -0700 | [diff] [blame] | 146 | </interface> |
| 147 | |
| 148 | <!-- The order is significant here. File must be defined first --> |
| 149 | <serial type="file"> |
Jesse Andrews | 228f246 | 2011-11-05 17:36:14 -0700 | [diff] [blame] | 150 | <source path='$vm_dir/console.log'/> |
Jesse Andrews | 8b3eb5f | 2011-11-05 16:05:14 -0700 | [diff] [blame] | 151 | <target port='1'/> |
| 152 | </serial> |
| 153 | |
| 154 | <console type='pty' tty='/dev/pts/2'> |
| 155 | <source path='/dev/pts/2'/> |
| 156 | <target port='0'/> |
| 157 | </console> |
| 158 | |
| 159 | <serial type='pty'> |
| 160 | <source path='/dev/pts/2'/> |
| 161 | <target port='0'/> |
| 162 | </serial> |
| 163 | |
| 164 | <graphics type='vnc' port='-1' autoport='yes' keymap='en-us' listen='0.0.0.0'/> |
| 165 | </devices> |
| 166 | </domain> |
| 167 | EOF |
| 168 | |
Jesse Andrews | d7ce7af | 2011-11-05 22:47:28 -0700 | [diff] [blame] | 169 | |
Jesse Andrews | e49f751 | 2011-11-05 22:34:45 -0700 | [diff] [blame] | 170 | rm -rf $vm_dir/uec |
Jesse Andrews | 9ed6bbd | 2011-11-05 22:28:46 -0700 | [diff] [blame] | 171 | cp -r $TOOLS_DIR/uec $vm_dir/uec |
| 172 | |
Jesse Andrews | d7ce7af | 2011-11-05 22:47:28 -0700 | [diff] [blame] | 173 | # set metadata |
| 174 | cat > $vm_dir/uec/meta-data<<EOF |
| 175 | hostname: $GUEST_NAME |
Jesse Andrews | e3c47a3 | 2011-11-07 10:44:43 -0800 | [diff] [blame] | 176 | instance-id: i-hop |
| 177 | instance-type: m1.ignore |
Jesse Andrews | 7306f3b | 2011-11-05 23:13:34 -0700 | [diff] [blame] | 178 | local-hostname: $GUEST_NAME.local |
Jesse Andrews | d7ce7af | 2011-11-05 22:47:28 -0700 | [diff] [blame] | 179 | EOF |
| 180 | |
Anthony Young | 2838f12 | 2011-11-10 13:04:40 -0800 | [diff] [blame] | 181 | # set user-data |
Jesse Andrews | 63cb923 | 2011-11-05 23:16:53 -0700 | [diff] [blame] | 182 | cat > $vm_dir/uec/user-data<<EOF |
Jesse Andrews | 446a330 | 2011-11-05 23:36:29 -0700 | [diff] [blame] | 183 | #!/bin/bash |
Jesse Andrews | b17c4f3 | 2011-11-06 09:25:55 -0800 | [diff] [blame] | 184 | # hostname needs to resolve for rabbit |
Jesse Andrews | 6e3a4c5 | 2011-11-06 09:35:13 -0800 | [diff] [blame] | 185 | sed -i "s/127.0.0.1/127.0.0.1 \`hostname\`/" /etc/hosts |
Jesse Andrews | 446a330 | 2011-11-05 23:36:29 -0700 | [diff] [blame] | 186 | apt-get update |
Jesse Andrews | c7f72ad | 2011-11-06 08:00:28 -0800 | [diff] [blame] | 187 | apt-get install git sudo -y |
Anthony Young | 760ddde | 2011-11-10 13:46:52 -0800 | [diff] [blame] | 188 | # Disable byobu |
Jesse Andrews | d7326d2 | 2011-11-20 10:02:26 -0800 | [diff] [blame] | 189 | sudo apt-get remove -y byobu |
Anthony Young | b225682 | 2011-11-10 12:57:59 -0800 | [diff] [blame] | 190 | EOF |
| 191 | |
| 192 | # Setup stack user with our key |
Jesse Andrews | d7326d2 | 2011-11-20 10:02:26 -0800 | [diff] [blame] | 193 | if [[ -e ~/.ssh/id_rsa.pub ]]; then |
Anthony Young | b766128 | 2011-11-10 13:09:25 -0800 | [diff] [blame] | 194 | PUB_KEY=`cat ~/.ssh/id_rsa.pub` |
Anthony Young | 2838f12 | 2011-11-10 13:04:40 -0800 | [diff] [blame] | 195 | cat >> $vm_dir/uec/user-data<<EOF |
Anthony Young | b225682 | 2011-11-10 12:57:59 -0800 | [diff] [blame] | 196 | mkdir -p /opt/stack |
Anthony Young | 331ae29 | 2011-12-21 11:55:35 -0800 | [diff] [blame] | 197 | if [ ! -d /opt/stack/devstack ]; then |
| 198 | git clone https://github.com/cloudbuilders/devstack.git /opt/stack/devstack |
| 199 | cd /opt/stack/devstack |
| 200 | cat > localrc <<LOCAL_EOF |
| 201 | ROOTSLEEP=0 |
| 202 | `cat $TOP_DIR/localrc` |
| 203 | LOCAL_EOF |
| 204 | fi |
Anthony Young | ff7771e | 2011-11-10 13:33:31 -0800 | [diff] [blame] | 205 | useradd -U -G sudo -s /bin/bash -d /opt/stack -m stack |
Anthony Young | b225682 | 2011-11-10 12:57:59 -0800 | [diff] [blame] | 206 | echo stack:pass | chpasswd |
| 207 | mkdir -p /opt/stack/.ssh |
Anthony Young | b766128 | 2011-11-10 13:09:25 -0800 | [diff] [blame] | 208 | echo "$PUB_KEY" > /opt/stack/.ssh/authorized_keys |
Anthony Young | b225682 | 2011-11-10 12:57:59 -0800 | [diff] [blame] | 209 | chown -R stack /opt/stack |
| 210 | chmod 700 /opt/stack/.ssh |
| 211 | chmod 600 /opt/stack/.ssh/authorized_keys |
| 212 | |
| 213 | grep -q "^#includedir.*/etc/sudoers.d" /etc/sudoers || |
| 214 | echo "#includedir /etc/sudoers.d" >> /etc/sudoers |
| 215 | ( umask 226 && echo "stack ALL=(ALL) NOPASSWD:ALL" \ |
| 216 | > /etc/sudoers.d/50_stack_sh ) |
| 217 | EOF |
| 218 | fi |
| 219 | |
| 220 | # Run stack.sh |
Anthony Young | 2838f12 | 2011-11-10 13:04:40 -0800 | [diff] [blame] | 221 | cat >> $vm_dir/uec/user-data<<EOF |
Anthony Young | 331ae29 | 2011-12-21 11:55:35 -0800 | [diff] [blame] | 222 | su -c "cd /opt/stack/devstack && ./stack.sh" stack |
Jesse Andrews | 63cb923 | 2011-11-05 23:16:53 -0700 | [diff] [blame] | 223 | EOF |
| 224 | |
Jesse Andrews | ee34f62 | 2011-11-05 22:41:57 -0700 | [diff] [blame] | 225 | # (re)start a metadata service |
Jesse Andrews | 3ce79aa | 2011-11-05 22:52:20 -0700 | [diff] [blame] | 226 | ( |
| 227 | pid=`lsof -iTCP@192.168.$GUEST_NETWORK.1:4567 -n | awk '{print $2}' | tail -1` |
Jesse Andrews | 9645b0c | 2011-11-05 23:05:33 -0700 | [diff] [blame] | 228 | [ -z "$pid" ] || kill -9 $pid |
Jesse Andrews | 3ce79aa | 2011-11-05 22:52:20 -0700 | [diff] [blame] | 229 | ) |
Jesse Andrews | f504e28 | 2011-11-05 22:29:35 -0700 | [diff] [blame] | 230 | cd $vm_dir/uec |
| 231 | python meta.py 192.168.$GUEST_NETWORK.1:4567 & |
Jesse Andrews | 9ed6bbd | 2011-11-05 22:28:46 -0700 | [diff] [blame] | 232 | |
Jesse Andrews | 8b3eb5f | 2011-11-05 16:05:14 -0700 | [diff] [blame] | 233 | # Create the instance |
Jesse Andrews | 63fa7ab | 2011-11-05 18:49:36 -0700 | [diff] [blame] | 234 | virsh create $vm_dir/libvirt.xml |
Jesse Andrews | 8b3eb5f | 2011-11-05 16:05:14 -0700 | [diff] [blame] | 235 | |
| 236 | # Tail the console log till we are done |
| 237 | WAIT_TILL_LAUNCH=${WAIT_TILL_LAUNCH:-1} |
| 238 | if [ "$WAIT_TILL_LAUNCH" = "1" ]; then |
Jesse Andrews | 228f246 | 2011-11-05 17:36:14 -0700 | [diff] [blame] | 239 | set +o xtrace |
Jesse Andrews | 8b3eb5f | 2011-11-05 16:05:14 -0700 | [diff] [blame] | 240 | # Done creating the container, let's tail the log |
| 241 | echo |
| 242 | echo "=============================================================" |
| 243 | echo " -- YAY! --" |
| 244 | echo "=============================================================" |
| 245 | echo |
| 246 | echo "We're done launching the vm, about to start tailing the" |
| 247 | echo "stack.sh log. It will take a second or two to start." |
| 248 | echo |
| 249 | echo "Just CTRL-C at any time to stop tailing." |
Jesse Andrews | d7326d2 | 2011-11-20 10:02:26 -0800 | [diff] [blame] | 250 | echo |
| 251 | |
| 252 | if ! timeout 60 sh -c "while [ ! -s /var/lib/libvirt/dnsmasq/$NET_NAME.leases ]; do sleep 1; done"; then |
| 253 | echo "Your instance failed to acquire an IP address" |
| 254 | exit 1 |
| 255 | fi |
| 256 | |
| 257 | ip=`cat /var/lib/libvirt/dnsmasq/$NET_NAME.leases | cut -d " " -f3` |
| 258 | echo "#############################################################" |
| 259 | echo " -- This is your instance's IP: --" |
| 260 | echo " $ip" |
| 261 | echo "#############################################################" |
| 262 | |
| 263 | sleep 2 |
Jesse Andrews | 8b3eb5f | 2011-11-05 16:05:14 -0700 | [diff] [blame] | 264 | |
Jesse Andrews | 228f246 | 2011-11-05 17:36:14 -0700 | [diff] [blame] | 265 | while [ ! -e "$vm_dir/console.log" ]; do |
Jesse Andrews | 8b3eb5f | 2011-11-05 16:05:14 -0700 | [diff] [blame] | 266 | sleep 1 |
| 267 | done |
| 268 | |
Jesse Andrews | 228f246 | 2011-11-05 17:36:14 -0700 | [diff] [blame] | 269 | tail -F $vm_dir/console.log & |
Jesse Andrews | 8b3eb5f | 2011-11-05 16:05:14 -0700 | [diff] [blame] | 270 | |
| 271 | TAIL_PID=$! |
| 272 | |
| 273 | function kill_tail() { |
| 274 | kill $TAIL_PID |
| 275 | exit 1 |
| 276 | } |
| 277 | |
| 278 | # Let Ctrl-c kill tail and exit |
| 279 | trap kill_tail SIGINT |
| 280 | |
Jesse Andrews | 8b3eb5f | 2011-11-05 16:05:14 -0700 | [diff] [blame] | 281 | echo "Waiting stack.sh to finish..." |
Jesse Andrews | d55a515 | 2011-11-06 08:16:42 -0800 | [diff] [blame] | 282 | while ! egrep -q '^stack.sh (completed|failed)' $vm_dir/console.log ; do |
Jesse Andrews | 8b3eb5f | 2011-11-05 16:05:14 -0700 | [diff] [blame] | 283 | sleep 1 |
| 284 | done |
| 285 | |
| 286 | set -o xtrace |
| 287 | |
| 288 | kill $TAIL_PID |
| 289 | |
Jesse Andrews | 228f246 | 2011-11-05 17:36:14 -0700 | [diff] [blame] | 290 | if ! grep -q "^stack.sh completed in" $vm_dir/console.log; then |
Jesse Andrews | 8b3eb5f | 2011-11-05 16:05:14 -0700 | [diff] [blame] | 291 | exit 1 |
| 292 | fi |
Jesse Andrews | d7326d2 | 2011-11-20 10:02:26 -0800 | [diff] [blame] | 293 | |
| 294 | set +o xtrace |
Jesse Andrews | 8b3eb5f | 2011-11-05 16:05:14 -0700 | [diff] [blame] | 295 | echo "" |
| 296 | echo "Finished - Zip-a-dee Doo-dah!" |
| 297 | fi |