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