Andy Bavier | c4a4051 | 2017-08-10 07:06:25 -0700 | [diff] [blame] | 1 | #!/usr/bin/env bash |
| 2 | # |
Matteo Scandolo | 60b640f | 2017-08-08 13:05:22 -0700 | [diff] [blame] | 3 | # Copyright 2017-present Open Networking Foundation |
| 4 | # |
| 5 | # Licensed under the Apache License, Version 2.0 (the "License"); |
| 6 | # you may not use this file except in compliance with the License. |
| 7 | # You may obtain a copy of the License at |
| 8 | # |
| 9 | # http://www.apache.org/licenses/LICENSE-2.0 |
| 10 | # |
| 11 | # Unless required by applicable law or agreed to in writing, software |
| 12 | # distributed under the License is distributed on an "AS IS" BASIS, |
| 13 | # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| 14 | # See the License for the specific language governing permissions and |
| 15 | # limitations under the License. |
| 16 | |
Zack Williams | a1f5508 | 2017-02-28 22:41:36 -0700 | [diff] [blame] | 17 | # cord-in-a-box.sh |
Andy Bavier | 99c11d3 | 2016-09-14 17:21:20 -0400 | [diff] [blame] | 18 | |
Sapan Bhatia | 01ddea6 | 2017-02-10 11:28:48 -0800 | [diff] [blame] | 19 | set -e -x |
Andy Bavier | 99c11d3 | 2016-09-14 17:21:20 -0400 | [diff] [blame] | 20 | |
Zack Williams | a1f5508 | 2017-02-28 22:41:36 -0700 | [diff] [blame] | 21 | # start time, used to name logfiles |
| 22 | START_T=$(date -u "+%Y%m%d_%H%M%SZ") |
| 23 | |
| 24 | # Paths |
Zack Williams | 0620c93 | 2017-01-25 14:36:31 -0700 | [diff] [blame] | 25 | CORDDIR=~/cord |
Andy Bavier | f55e7f9 | 2017-06-22 10:16:44 -0400 | [diff] [blame] | 26 | VMDIR=/opt/cord/build/ |
Andy Bavier | 99c11d3 | 2016-09-14 17:21:20 -0400 | [diff] [blame] | 27 | CONFIG=config/cord_in_a_box.yml |
Andy Bavier | a69ee72 | 2016-11-17 07:26:01 -0800 | [diff] [blame] | 28 | SSHCONFIG=~/.ssh/config |
Zack Williams | 1bffc16 | 2017-04-12 16:31:15 -0700 | [diff] [blame] | 29 | VAGRANT_CWD=${CORDDIR}/build/ |
Zack Williams | 03a20ec | 2017-04-12 17:39:36 -0700 | [diff] [blame] | 30 | VAGRANT_VM_PREFIX=build |
Andy Bavier | 99c11d3 | 2016-09-14 17:21:20 -0400 | [diff] [blame] | 31 | |
Zack Williams | a1f5508 | 2017-02-28 22:41:36 -0700 | [diff] [blame] | 32 | # CORD versioning |
Andy Bavier | d116510 | 2017-01-13 16:38:57 -0500 | [diff] [blame] | 33 | REPO_BRANCH="master" |
Zack Williams | a1f5508 | 2017-02-28 22:41:36 -0700 | [diff] [blame] | 34 | VERSION_STRING="CiaB Devel" |
Andy Bavier | d116510 | 2017-01-13 16:38:57 -0500 | [diff] [blame] | 35 | |
Sapan Bhatia | a94c2db | 2017-02-27 20:18:24 +0100 | [diff] [blame] | 36 | function finish { |
Sapan Bhatia | 9569209 | 2017-03-01 06:48:19 +0100 | [diff] [blame] | 37 | EXIT=$? |
Sapan Bhatia | eb7819c | 2017-03-01 15:26:17 +0100 | [diff] [blame] | 38 | python $CORDDIR/build/elk-logger/mixpanel --event FINISH --corddir $CORDDIR --finish --status $EXIT |
Sapan Bhatia | a94c2db | 2017-02-27 20:18:24 +0100 | [diff] [blame] | 39 | } |
| 40 | |
Andy Bavier | 0f07bb3 | 2017-01-17 10:20:26 -0500 | [diff] [blame] | 41 | function add_box() { |
| 42 | vagrant box list | grep $1 | grep virtualbox || vagrant box add $1 |
| 43 | vagrant box list | grep $1 | grep libvirt || vagrant mutate $1 libvirt --input-provider virtualbox |
| 44 | } |
| 45 | |
Sapan Bhatia | 01ddea6 | 2017-02-10 11:28:48 -0800 | [diff] [blame] | 46 | function run_stage { |
Sapan Bhatia | a94c2db | 2017-02-27 20:18:24 +0100 | [diff] [blame] | 47 | cd $CORDDIR |
Sapan Bhatia | eb7819c | 2017-03-01 15:26:17 +0100 | [diff] [blame] | 48 | python build/elk-logger/mixpanel --event $1-start --corddir $CORDDIR |
Sapan Bhatia | a94c2db | 2017-02-27 20:18:24 +0100 | [diff] [blame] | 49 | |
Sapan Bhatia | 01ddea6 | 2017-02-10 11:28:48 -0800 | [diff] [blame] | 50 | echo "==> "$1": Starting" |
| 51 | $1 |
| 52 | echo "==> "$1": Complete" |
Sapan Bhatia | a94c2db | 2017-02-27 20:18:24 +0100 | [diff] [blame] | 53 | |
| 54 | cd $CORDDIR |
Sapan Bhatia | eb7819c | 2017-03-01 15:26:17 +0100 | [diff] [blame] | 55 | python build/elk-logger/mixpanel --event $1-end --corddir $CORDDIR |
Sapan Bhatia | 01ddea6 | 2017-02-10 11:28:48 -0800 | [diff] [blame] | 56 | } |
| 57 | |
Andy Bavier | 99c11d3 | 2016-09-14 17:21:20 -0400 | [diff] [blame] | 58 | function cleanup_from_previous_test() { |
Andy Bavier | 99c11d3 | 2016-09-14 17:21:20 -0400 | [diff] [blame] | 59 | echo "## Cleanup ##" |
| 60 | |
Andy Bavier | a4883ba | 2016-12-21 15:46:58 -0500 | [diff] [blame] | 61 | if [ -d $CORDDIR/build ] |
| 62 | then |
| 63 | echo "Destroying all Vagrant VMs" |
| 64 | cd $CORDDIR/build |
Zack Williams | a1f5508 | 2017-02-28 22:41:36 -0700 | [diff] [blame] | 65 | for i in `seq 12`; do |
Zack Williams | 9e7249a | 2017-03-28 13:07:41 -0700 | [diff] [blame] | 66 | sudo su $USER -c "VAGRANT_CWD=$VAGRANT_CWD vagrant destroy" && break |
Zack Williams | a1f5508 | 2017-02-28 22:41:36 -0700 | [diff] [blame] | 67 | done |
Andy Bavier | a4883ba | 2016-12-21 15:46:58 -0500 | [diff] [blame] | 68 | fi |
Andy Bavier | 99c11d3 | 2016-09-14 17:21:20 -0400 | [diff] [blame] | 69 | |
Andy Bavier | 2505f59 | 2016-11-11 15:58:55 -0500 | [diff] [blame] | 70 | echo "Removing $CORDDIR" |
| 71 | cd ~ |
Andy Bavier | 99c11d3 | 2016-09-14 17:21:20 -0400 | [diff] [blame] | 72 | rm -rf $CORDDIR |
Andy Bavier | 99c11d3 | 2016-09-14 17:21:20 -0400 | [diff] [blame] | 73 | } |
| 74 | |
| 75 | function bootstrap() { |
Zack Williams | a1f5508 | 2017-02-28 22:41:36 -0700 | [diff] [blame] | 76 | |
Sapan Bhatia | 9569209 | 2017-03-01 06:48:19 +0100 | [diff] [blame] | 77 | echo "Generating build id" |
Sapan Bhatia | 77f2667 | 2017-03-13 18:30:25 +0100 | [diff] [blame] | 78 | rm -f /tmp/cord-build-version |
Sapan Bhatia | 9569209 | 2017-03-01 06:48:19 +0100 | [diff] [blame] | 79 | dd bs=18 count=1 if=/dev/urandom | base64 | tr +/ _. > /tmp/cord-build |
Andy Bavier | 99c11d3 | 2016-09-14 17:21:20 -0400 | [diff] [blame] | 80 | |
Zack Williams | a1f5508 | 2017-02-28 22:41:36 -0700 | [diff] [blame] | 81 | if [ ! -x "/usr/local/bin/repo" ] |
| 82 | then |
| 83 | echo "Installing repo..." |
| 84 | REPO_SHA256SUM="e147f0392686c40cfd7d5e6f332c6ee74c4eab4d24e2694b3b0a0c037bf51dc5" # not versioned... |
| 85 | curl -o /tmp/repo https://storage.googleapis.com/git-repo-downloads/repo |
| 86 | echo "$REPO_SHA256SUM /tmp/repo" | sha256sum -c - |
| 87 | sudo mv /tmp/repo /usr/local/bin/repo |
| 88 | sudo chmod a+x /usr/local/bin/repo |
| 89 | fi |
| 90 | |
| 91 | if [ ! -x "/usr/bin/vagrant" ] |
| 92 | then |
| 93 | echo "Installing vagrant and associated tools..." |
| 94 | VAGRANT_SHA256SUM="faff6befacc7eed3978b4b71f0dbb9c135c01d8a4d13236bda2f9ed53482d2c4" # version 1.9.3 |
| 95 | curl -o /tmp/vagrant.deb https://releases.hashicorp.com/vagrant/1.9.3/vagrant_1.9.3_x86_64.deb |
| 96 | echo "$VAGRANT_SHA256SUM /tmp/vagrant.deb" | sha256sum -c - |
| 97 | sudo apt-get update |
| 98 | sudo dpkg -i /tmp/vagrant.deb |
Zack Williams | 2f13092 | 2017-04-28 15:02:09 -0700 | [diff] [blame] | 99 | sudo apt-get -y install qemu-kvm libvirt-bin libvirt-dev curl nfs-kernel-server git build-essential python-pip ruby2.0 |
Zack Williams | a1f5508 | 2017-02-28 22:41:36 -0700 | [diff] [blame] | 100 | sudo adduser $USER libvirtd |
| 101 | sudo pip install pyparsing python-logstash mixpanel |
| 102 | fi |
| 103 | |
| 104 | echo "Installing vagrant plugins..." |
Zack Williams | 2f13092 | 2017-04-28 15:02:09 -0700 | [diff] [blame] | 105 | # FIXME: fix for vagrant-libvirt dependency issue that arose on 2017-04-28 - zdw |
| 106 | # vagrant plugin list | grep vagrant-libvirt || vagrant plugin install vagrant-libvirt --plugin-version 0.0.35 |
| 107 | if ! vagrant plugin list | grep vagrant-libvirt |
| 108 | then |
| 109 | git clone -b remove_xmlrpc_dep https://github.com/zdw/vagrant-libvirt.git ~/vagrant-libvirt |
| 110 | cd ~/vagrant-libvirt |
| 111 | gem2.0 build vagrant-libvirt.gemspec |
| 112 | vagrant plugin install vagrant-libvirt-0.0.35.gem |
| 113 | cd ~ |
| 114 | fi |
| 115 | |
Zack Williams | a1f5508 | 2017-02-28 22:41:36 -0700 | [diff] [blame] | 116 | vagrant plugin list | grep vagrant-mutate || vagrant plugin install vagrant-mutate |
| 117 | |
| 118 | add_box ubuntu/trusty64 |
| 119 | |
| 120 | echo "Creating SSH key..." |
Andy Bavier | 99c11d3 | 2016-09-14 17:21:20 -0400 | [diff] [blame] | 121 | [ -e ~/.ssh/id_rsa ] || ssh-keygen -t rsa -N "" -f ~/.ssh/id_rsa |
Andy Bavier | 99c11d3 | 2016-09-14 17:21:20 -0400 | [diff] [blame] | 122 | |
Andy Bavier | 99c11d3 | 2016-09-14 17:21:20 -0400 | [diff] [blame] | 123 | if [ ! -d "$CORDDIR" ] |
| 124 | then |
Zack Williams | a1f5508 | 2017-02-28 22:41:36 -0700 | [diff] [blame] | 125 | echo "Downloading CORD/XOS..." |
| 126 | |
| 127 | if [ ! -e "~/.gitconfig" ] |
| 128 | then |
| 129 | echo "No ~/.gitconfig, setting testing defaults" |
| 130 | git config --global user.name 'Test User' |
| 131 | git config --global user.email 'test@null.com' |
| 132 | git config --global color.ui false |
| 133 | fi |
| 134 | |
| 135 | # make sure we can find gerrit.opencord.org as DNS failures will fail the build |
| 136 | dig +short gerrit.opencord.org || (echo "ERROR: gerrit.opencord.org can't be looked up in DNS" && exit 1) |
| 137 | |
Andy Bavier | 99c11d3 | 2016-09-14 17:21:20 -0400 | [diff] [blame] | 138 | mkdir $CORDDIR && cd $CORDDIR |
Matteo Scandolo | 4d7d166 | 2017-05-30 11:20:57 -0700 | [diff] [blame] | 139 | repo init -u https://gerrit.opencord.org/manifest -b $REPO_BRANCH |
Andy Bavier | 99c11d3 | 2016-09-14 17:21:20 -0400 | [diff] [blame] | 140 | repo sync |
| 141 | |
Zack Williams | dae7ff6 | 2016-11-14 15:20:06 -0700 | [diff] [blame] | 142 | # check out gerrit branches using repo |
| 143 | for gerrit_branch in ${GERRIT_BRANCHES[@]}; do |
Zack Williams | a1f5508 | 2017-02-28 22:41:36 -0700 | [diff] [blame] | 144 | echo "Checking out opencord gerrit branch: $gerrit_branch" |
Zack Williams | dae7ff6 | 2016-11-14 15:20:06 -0700 | [diff] [blame] | 145 | repo download ${gerrit_branch/:/ } |
| 146 | done |
Andy Bavier | 99c11d3 | 2016-09-14 17:21:20 -0400 | [diff] [blame] | 147 | fi |
| 148 | |
Sapan Bhatia | 868e001 | 2017-02-15 22:14:11 -0800 | [diff] [blame] | 149 | exec > >(tee -i $CORDDIR/install.out) |
| 150 | exec 2>&1 |
| 151 | |
Sapan Bhatia | 9569209 | 2017-03-01 06:48:19 +0100 | [diff] [blame] | 152 | # Start tracking failures from this point |
| 153 | trap finish EXIT |
| 154 | |
Andy Bavier | 99c11d3 | 2016-09-14 17:21:20 -0400 | [diff] [blame] | 155 | } |
| 156 | |
| 157 | function cloudlab_setup() { |
Andy Bavier | 8b4ed1f | 2017-02-13 17:06:58 -0800 | [diff] [blame] | 158 | |
Andy Bavier | 46dfda6 | 2017-03-02 05:40:08 -0500 | [diff] [blame] | 159 | # Don't do anything if not a CloudLab node |
| 160 | [ ! -d /usr/local/etc/emulab ] && return |
| 161 | |
Andy Bavier | 8b4ed1f | 2017-02-13 17:06:58 -0800 | [diff] [blame] | 162 | # The watchdog will sometimes reset groups, turn it off |
| 163 | if [ -e /usr/local/etc/emulab/watchdog ] |
| 164 | then |
| 165 | sudo /usr/bin/perl -w /usr/local/etc/emulab/watchdog stop |
| 166 | sudo mv /usr/local/etc/emulab/watchdog /usr/local/etc/emulab/watchdog-disabled |
| 167 | fi |
| 168 | |
Zack Williams | f4e6522 | 2017-03-01 14:22:37 -0700 | [diff] [blame] | 169 | # Mount extra space, if haven't already |
| 170 | if [ ! -d /mnt/extra ] |
Andy Bavier | 99c11d3 | 2016-09-14 17:21:20 -0400 | [diff] [blame] | 171 | then |
Zack Williams | f4e6522 | 2017-03-01 14:22:37 -0700 | [diff] [blame] | 172 | # for NVME SSD on Utah Cloudlab, not supported by mkextrafs |
| 173 | if $(df | grep -q nvme0n1p1) && [ -e /usr/testbed/bin/mkextrafs ] |
Andy Bavier | 2505f59 | 2016-11-11 15:58:55 -0500 | [diff] [blame] | 174 | then |
Zack Williams | f4e6522 | 2017-03-01 14:22:37 -0700 | [diff] [blame] | 175 | sudo mkdir -p /mnt/extra |
| 176 | |
| 177 | # set partition type of 4th partition to Linux, ignore errors |
| 178 | echo -e "t\n4\n82\np\nw\nq" | sudo fdisk /dev/nvme0n1 || true |
| 179 | |
| 180 | sudo mkfs.ext4 /dev/nvme0n1p4 |
| 181 | echo "/dev/nvme0n1p4 /mnt/extra/ ext4 defaults 0 0" | sudo tee -a /etc/fstab |
| 182 | sudo mount /mnt/extra |
| 183 | mount | grep nvme0n1p4 || (echo "ERROR: NVME mkfs/mount failed, exiting!" && exit 1) |
| 184 | |
| 185 | elif [ -e /usr/testbed/bin/mkextrafs ] # if on Clemson/Wisconsin Cloudlab |
| 186 | then |
| 187 | sudo mkdir -p /mnt/extra |
| 188 | |
| 189 | # Sometimes this command fails on the first try |
| 190 | sudo /usr/testbed/bin/mkextrafs -r /dev/sdb -qf "/mnt/extra/" || sudo /usr/testbed/bin/mkextrafs -r /dev/sdb -qf "/mnt/extra/" |
| 191 | |
| 192 | # Check that the mount succeeded (sometimes mkextrafs succeeds but device not mounted) |
| 193 | mount | grep sdb || (echo "ERROR: mkextrafs failed, exiting!" && exit 1) |
Andy Bavier | 2505f59 | 2016-11-11 15:58:55 -0500 | [diff] [blame] | 194 | fi |
Andy Bavier | 99c11d3 | 2016-09-14 17:21:20 -0400 | [diff] [blame] | 195 | fi |
Zack Williams | f4e6522 | 2017-03-01 14:22:37 -0700 | [diff] [blame] | 196 | |
| 197 | # replace /var/lib/libvirt/images with a symlink |
| 198 | [ -d /var/lib/libvirt/images/ ] && [ ! -h /var/lib/libvirt/images ] && sudo rmdir /var/lib/libvirt/images |
| 199 | sudo mkdir -p /mnt/extra/libvirt_images |
| 200 | |
| 201 | if [ ! -e /var/lib/libvirt/images ] |
| 202 | then |
| 203 | sudo ln -s /mnt/extra/libvirt_images /var/lib/libvirt/images |
| 204 | fi |
Andy Bavier | 99c11d3 | 2016-09-14 17:21:20 -0400 | [diff] [blame] | 205 | } |
| 206 | |
Sapan Bhatia | 01ddea6 | 2017-02-10 11:28:48 -0800 | [diff] [blame] | 207 | function elk_up() { |
Sapan Bhatia | 01ddea6 | 2017-02-10 11:28:48 -0800 | [diff] [blame] | 208 | |
| 209 | cd $CORDDIR |
Sapan Bhatia | 01ddea6 | 2017-02-10 11:28:48 -0800 | [diff] [blame] | 210 | sudo chmod +x build/elk-logger/logstash_tail |
Zack Williams | 49af5e6 | 2017-03-24 18:02:56 -0700 | [diff] [blame] | 211 | |
| 212 | build/elk-logger/logstash_tail --file install.out --hostport 10.100.198.201:5617 & |
Sapan Bhatia | 01ddea6 | 2017-02-10 11:28:48 -0800 | [diff] [blame] | 213 | } |
| 214 | |
Andy Bavier | 2505f59 | 2016-11-11 15:58:55 -0500 | [diff] [blame] | 215 | function vagrant_vms_up() { |
Zack Williams | a1f5508 | 2017-02-28 22:41:36 -0700 | [diff] [blame] | 216 | |
| 217 | echo "Bringing up CORD-in-a-Box Vagrant VM's..." |
Andy Bavier | 99c11d3 | 2016-09-14 17:21:20 -0400 | [diff] [blame] | 218 | cd $CORDDIR/build |
| 219 | |
Zack Williams | 9e7249a | 2017-03-28 13:07:41 -0700 | [diff] [blame] | 220 | sudo su $USER -c "VAGRANT_CWD=$VAGRANT_CWD vagrant up corddev prod --provider libvirt" |
Andy Bavier | a69ee72 | 2016-11-17 07:26:01 -0800 | [diff] [blame] | 221 | |
| 222 | # This is a workaround for a weird issue with ARP cache timeout breaking 'vagrant ssh' |
| 223 | # It allows SSH'ing to the machine via 'ssh corddev' |
Zack Williams | 9e7249a | 2017-03-28 13:07:41 -0700 | [diff] [blame] | 224 | sudo su $USER -c "VAGRANT_CWD=$VAGRANT_CWD vagrant ssh-config corddev prod > $SSHCONFIG" |
Andy Bavier | 2505f59 | 2016-11-11 15:58:55 -0500 | [diff] [blame] | 225 | |
Andy Bavier | a2acd2a | 2017-06-19 09:57:32 -0400 | [diff] [blame] | 226 | # copy host SSH keypair to corddev |
Andy Bavier | 2505f59 | 2016-11-11 15:58:55 -0500 | [diff] [blame] | 227 | scp ~/.ssh/id_rsa* corddev:.ssh |
| 228 | ssh corddev "chmod go-r ~/.ssh/id_rsa" |
Andy Bavier | 99c11d3 | 2016-09-14 17:21:20 -0400 | [diff] [blame] | 229 | } |
| 230 | |
| 231 | function install_head_node() { |
| 232 | cd $CORDDIR/build |
| 233 | |
Andy Bavier | a69ee72 | 2016-11-17 07:26:01 -0800 | [diff] [blame] | 234 | # SSH config saved earlier allows us to connect to VM without running 'vagrant' |
Andy Bavier | f55e7f9 | 2017-06-22 10:16:44 -0400 | [diff] [blame] | 235 | ssh corddev "cd $VMDIR; ./gradlew -PdeployConfig=$VMDIR/$CONFIG fetch" |
| 236 | ssh corddev "cd $VMDIR; ./gradlew -PdeployConfig=$VMDIR/$CONFIG buildImages" |
| 237 | ssh corddev "cd $VMDIR; ping -c 3 prod; ./gradlew -PdeployConfig=$VMDIR/$CONFIG -PtargetReg=10.100.198.201:5000 publish" |
| 238 | ssh corddev "cd $VMDIR; ./gradlew -PdeployConfig=$VMDIR/$CONFIG deploy" |
Andy Bavier | 99c11d3 | 2016-09-14 17:21:20 -0400 | [diff] [blame] | 239 | } |
| 240 | |
| 241 | function set_up_maas_user() { |
Andy Bavier | 2505f59 | 2016-11-11 15:58:55 -0500 | [diff] [blame] | 242 | # Set up MAAS user on server to restart nodes via libvirt |
| 243 | grep maas /etc/passwd || sudo useradd -m maas |
Andy Bavier | 99c11d3 | 2016-09-14 17:21:20 -0400 | [diff] [blame] | 244 | sudo adduser maas libvirtd |
| 245 | |
Andy Bavier | 2505f59 | 2016-11-11 15:58:55 -0500 | [diff] [blame] | 246 | # Copy generated public key to maas user's authorized_keys |
| 247 | sudo su maas -c "mkdir -p ~/.ssh" |
| 248 | sudo cp $HOME/.ssh/id_rsa.pub ~maas/.ssh/authorized_keys |
| 249 | sudo chown maas:maas ~maas/.ssh/authorized_keys |
Andy Bavier | 99c11d3 | 2016-09-14 17:21:20 -0400 | [diff] [blame] | 250 | |
Andy Bavier | 2505f59 | 2016-11-11 15:58:55 -0500 | [diff] [blame] | 251 | # Copy generated private key to maas user's home dir in prod VM |
| 252 | scp $HOME/.ssh/id_rsa prod:/tmp |
| 253 | ssh prod "sudo mkdir -p ~maas/.ssh" |
| 254 | ssh prod "sudo cp /tmp/id_rsa ~maas/.ssh/id_rsa" |
| 255 | ssh prod "sudo chown -R maas:maas ~maas/.ssh" |
| 256 | } |
Srikanth Vavilapalli | b1c4da0 | 2016-11-17 15:24:28 -0600 | [diff] [blame] | 257 | |
Andy Bavier | 0f07bb3 | 2017-01-17 10:20:26 -0500 | [diff] [blame] | 258 | function turn_off_learning () { |
| 259 | NET=$1 |
| 260 | BRIDGE=`sudo virsh net-info $NET|grep "Bridge:"|awk '{print $2}'` |
| 261 | sudo brctl setageing $BRIDGE 0 |
| 262 | sudo brctl stp $BRIDGE off |
| 263 | } |
| 264 | |
| 265 | function leaf_spine_up() { |
| 266 | cd $CORDDIR/build |
| 267 | |
| 268 | if [[ $FABRIC -ne 0 ]] |
| 269 | then |
Zack Williams | 9e7249a | 2017-03-28 13:07:41 -0700 | [diff] [blame] | 270 | sudo su $USER -c "VAGRANT_CWD=$VAGRANT_CWD FABRIC=$FABRIC vagrant up leaf-1 leaf-2 spine-1 spine-2 --provider libvirt" |
Andy Bavier | 0f07bb3 | 2017-01-17 10:20:26 -0500 | [diff] [blame] | 271 | else |
| 272 | # Linux bridging seems to be having issues with two spine switches |
Zack Williams | 9e7249a | 2017-03-28 13:07:41 -0700 | [diff] [blame] | 273 | sudo su $USER -c "VAGRANT_CWD=$VAGRANT_CWD FABRIC=$FABRIC vagrant up leaf-1 leaf-2 spine-1 --provider libvirt" |
Andy Bavier | 0f07bb3 | 2017-01-17 10:20:26 -0500 | [diff] [blame] | 274 | fi |
| 275 | |
| 276 | # Turn off MAC learning on "links" -- i.e., bridges created by libvirt. |
| 277 | # Without this, sometimes packets are dropped because the bridges |
| 278 | # think they are not local -- this needs further investigation. |
| 279 | # A better solution might be to replace the bridges with UDP tunnels, but this |
| 280 | # is not supported with the version of libvirt available on Ubuntu 14.04. |
| 281 | turn_off_learning head-node-leaf-1 |
| 282 | turn_off_learning compute-node-1-leaf-1 |
| 283 | turn_off_learning compute-node-2-leaf-2 |
| 284 | turn_off_learning compute-node-3-leaf-2 |
| 285 | turn_off_learning leaf-1-spine-1 |
| 286 | turn_off_learning leaf-1-spine-2 |
| 287 | turn_off_learning leaf-2-spine-1 |
| 288 | turn_off_learning leaf-2-spine-2 |
| 289 | } |
| 290 | |
Andy Bavier | 99c11d3 | 2016-09-14 17:21:20 -0400 | [diff] [blame] | 291 | function add_compute_node() { |
Srikanth Vavilapalli | b1c4da0 | 2016-11-17 15:24:28 -0600 | [diff] [blame] | 292 | echo add_compute_node: $1 $2 |
Andy Bavier | 2505f59 | 2016-11-11 15:58:55 -0500 | [diff] [blame] | 293 | |
Andy Bavier | 99c11d3 | 2016-09-14 17:21:20 -0400 | [diff] [blame] | 294 | cd $CORDDIR/build |
Zack Williams | 9e7249a | 2017-03-28 13:07:41 -0700 | [diff] [blame] | 295 | sudo su $USER -c "VAGRANT_CWD=$VAGRANT_CWD vagrant up $1 --provider libvirt" |
Andy Bavier | 99c11d3 | 2016-09-14 17:21:20 -0400 | [diff] [blame] | 296 | |
Andy Bavier | 2505f59 | 2016-11-11 15:58:55 -0500 | [diff] [blame] | 297 | # Set up power cycling for the compute node and wait for it to be provisioned |
Andy Bavier | f55e7f9 | 2017-06-22 10:16:44 -0400 | [diff] [blame] | 298 | ssh prod "cd $VMDIR/ansible; ansible-playbook maas-provision.yml --extra-vars \"maas_user=maas vagrant_name=$2\"" |
Andy Bavier | 99c11d3 | 2016-09-14 17:21:20 -0400 | [diff] [blame] | 299 | |
| 300 | echo "" |
Andy Bavier | 0f07bb3 | 2017-01-17 10:20:26 -0500 | [diff] [blame] | 301 | echo "$1 is fully provisioned!" |
| 302 | } |
| 303 | |
| 304 | function initialize_fabric() { |
| 305 | echo "Initializing fabric" |
Andy Bavier | f55e7f9 | 2017-06-22 10:16:44 -0400 | [diff] [blame] | 306 | ssh prod "cd $VMDIR/platform-install; ansible-playbook -i /etc/maas/ansible/pod-inventory cord-refresh-fabric.yml" |
Andy Bavier | 0f07bb3 | 2017-01-17 10:20:26 -0500 | [diff] [blame] | 307 | |
| 308 | echo "Fabric ping test" |
Andy Bavier | f55e7f9 | 2017-06-22 10:16:44 -0400 | [diff] [blame] | 309 | ssh prod "cd $VMDIR/platform-install; ansible-playbook -i /etc/maas/ansible/pod-inventory cord-fabric-pingtest.yml" |
Andy Bavier | 99c11d3 | 2016-09-14 17:21:20 -0400 | [diff] [blame] | 310 | } |
| 311 | |
| 312 | function run_e2e_test () { |
| 313 | cd $CORDDIR/build |
| 314 | |
Andy Bavier | 2505f59 | 2016-11-11 15:58:55 -0500 | [diff] [blame] | 315 | # User has been added to the lbvirtd group, but su $USER to be safe |
Andy Bavier | f55e7f9 | 2017-06-22 10:16:44 -0400 | [diff] [blame] | 316 | ssh corddev "cd $VMDIR; ./gradlew -PdeployConfig=$VMDIR/$CONFIG postDeployTests" |
Andy Bavier | 99c11d3 | 2016-09-14 17:21:20 -0400 | [diff] [blame] | 317 | } |
| 318 | |
| 319 | function run_diagnostics() { |
Andy Bavier | f55e7f9 | 2017-06-22 10:16:44 -0400 | [diff] [blame] | 320 | ssh corddev "cd $VMDIR; ./gradlew -PdeployConfig=$VMDIR/$CONFIG PIrunDiag" |
Andy Bavier | 99c11d3 | 2016-09-14 17:21:20 -0400 | [diff] [blame] | 321 | } |
| 322 | |
| 323 | # Parse options |
Zack Williams | dae7ff6 | 2016-11-14 15:20:06 -0700 | [diff] [blame] | 324 | GERRIT_BRANCHES= |
Andy Bavier | 99c11d3 | 2016-09-14 17:21:20 -0400 | [diff] [blame] | 325 | RUN_TEST=0 |
Andy Bavier | 5c2e4fa | 2016-10-31 13:50:52 -0400 | [diff] [blame] | 326 | SETUP_ONLY=0 |
Andy Bavier | 99c11d3 | 2016-09-14 17:21:20 -0400 | [diff] [blame] | 327 | DIAGNOSTICS=0 |
| 328 | CLEANUP=0 |
Andy Bavier | 0f07bb3 | 2017-01-17 10:20:26 -0500 | [diff] [blame] | 329 | FABRIC=0 |
Srikanth Vavilapalli | b1c4da0 | 2016-11-17 15:24:28 -0600 | [diff] [blame] | 330 | #By default, cord-in-a-box creates 1 compute node. If more than one compute is |
| 331 | #needed, use -n option |
| 332 | NUM_COMPUTE_NODES=1 |
Andy Bavier | 99c11d3 | 2016-09-14 17:21:20 -0400 | [diff] [blame] | 333 | |
Andy Bavier | 0f07bb3 | 2017-01-17 10:20:26 -0500 | [diff] [blame] | 334 | while getopts "b:cdfhn:stv" opt; do |
Andy Bavier | 99c11d3 | 2016-09-14 17:21:20 -0400 | [diff] [blame] | 335 | case ${opt} in |
Zack Williams | dae7ff6 | 2016-11-14 15:20:06 -0700 | [diff] [blame] | 336 | b ) GERRIT_BRANCHES+=("$OPTARG") |
Andy Bavier | 99c11d3 | 2016-09-14 17:21:20 -0400 | [diff] [blame] | 337 | ;; |
| 338 | c ) CLEANUP=1 |
| 339 | ;; |
| 340 | d ) DIAGNOSTICS=1 |
| 341 | ;; |
Andy Bavier | 0f07bb3 | 2017-01-17 10:20:26 -0500 | [diff] [blame] | 342 | f ) FABRIC=1 |
| 343 | ;; |
Andy Bavier | 99c11d3 | 2016-09-14 17:21:20 -0400 | [diff] [blame] | 344 | h ) echo "Usage:" |
| 345 | echo " $0 install OpenStack and prep XOS and ONOS VMs [default]" |
Zack Williams | dae7ff6 | 2016-11-14 15:20:06 -0700 | [diff] [blame] | 346 | echo " $0 -b <project:changeset/revision> checkout a changesets from gerrit. Can" |
| 347 | echo " be used multiple times." |
Andy Bavier | 99c11d3 | 2016-09-14 17:21:20 -0400 | [diff] [blame] | 348 | echo " $0 -c cleanup from previous test" |
| 349 | echo " $0 -d run diagnostic collector" |
Andy Bavier | 0f07bb3 | 2017-01-17 10:20:26 -0500 | [diff] [blame] | 350 | echo " $0 -f use ONOS fabric (EXPERIMENTAL)" |
Andy Bavier | 99c11d3 | 2016-09-14 17:21:20 -0400 | [diff] [blame] | 351 | echo " $0 -h display this help message" |
Zack Williams | a9e76ec | 2017-01-20 16:17:35 -0700 | [diff] [blame] | 352 | echo " $0 -n # number of compute nodes to setup. Currently max 2 nodes can be supported" |
Andy Bavier | 5c2e4fa | 2016-10-31 13:50:52 -0400 | [diff] [blame] | 353 | echo " $0 -s run initial setup phase only (don't start building CORD)" |
Andy Bavier | 99c11d3 | 2016-09-14 17:21:20 -0400 | [diff] [blame] | 354 | echo " $0 -t do install, bring up cord-pod configuration, run E2E test" |
Andy Bavier | d116510 | 2017-01-13 16:38:57 -0500 | [diff] [blame] | 355 | echo " $0 -v print CiaB version and exit" |
Andy Bavier | 99c11d3 | 2016-09-14 17:21:20 -0400 | [diff] [blame] | 356 | exit 0 |
| 357 | ;; |
Srikanth Vavilapalli | b1c4da0 | 2016-11-17 15:24:28 -0600 | [diff] [blame] | 358 | n ) NUM_COMPUTE_NODES=$OPTARG |
| 359 | ;; |
Andy Bavier | 5c2e4fa | 2016-10-31 13:50:52 -0400 | [diff] [blame] | 360 | s ) SETUP_ONLY=1 |
| 361 | ;; |
Andy Bavier | 99c11d3 | 2016-09-14 17:21:20 -0400 | [diff] [blame] | 362 | t ) RUN_TEST=1 |
| 363 | ;; |
Andy Bavier | d116510 | 2017-01-13 16:38:57 -0500 | [diff] [blame] | 364 | v ) echo "$VERSION_STRING ($REPO_BRANCH branch)" |
| 365 | exit 0 |
| 366 | ;; |
Andy Bavier | 99c11d3 | 2016-09-14 17:21:20 -0400 | [diff] [blame] | 367 | \? ) echo "Invalid option: -$OPTARG" |
| 368 | exit 1 |
| 369 | ;; |
| 370 | esac |
| 371 | done |
| 372 | |
| 373 | # What to do |
| 374 | if [[ $CLEANUP -eq 1 ]] |
| 375 | then |
Sapan Bhatia | 3f454b3 | 2017-03-01 05:24:19 +0100 | [diff] [blame] | 376 | cleanup_from_previous_test |
Andy Bavier | 99c11d3 | 2016-09-14 17:21:20 -0400 | [diff] [blame] | 377 | fi |
| 378 | |
Andy Bavier | d116510 | 2017-01-13 16:38:57 -0500 | [diff] [blame] | 379 | echo "" |
| 380 | echo "Preparing to install $VERSION_STRING ($REPO_BRANCH branch)" |
| 381 | echo "" |
| 382 | |
Sapan Bhatia | a94c2db | 2017-02-27 20:18:24 +0100 | [diff] [blame] | 383 | bootstrap |
Sapan Bhatia | 01ddea6 | 2017-02-10 11:28:48 -0800 | [diff] [blame] | 384 | run_stage cloudlab_setup |
Sapan Bhatia | 01ddea6 | 2017-02-10 11:28:48 -0800 | [diff] [blame] | 385 | run_stage vagrant_vms_up |
Zack Williams | 49af5e6 | 2017-03-24 18:02:56 -0700 | [diff] [blame] | 386 | run_stage elk_up |
Andy Bavier | 5c2e4fa | 2016-10-31 13:50:52 -0400 | [diff] [blame] | 387 | |
| 388 | if [[ $SETUP_ONLY -ne 0 ]] |
| 389 | then |
| 390 | echo "Finished build environment setup, exiting..." |
| 391 | exit 0 |
| 392 | fi |
| 393 | |
Sapan Bhatia | 01ddea6 | 2017-02-10 11:28:48 -0800 | [diff] [blame] | 394 | run_stage install_head_node |
| 395 | run_stage set_up_maas_user |
| 396 | run_stage leaf_spine_up |
Srikanth Vavilapalli | b1c4da0 | 2016-11-17 15:24:28 -0600 | [diff] [blame] | 397 | |
Andy Bavier | 0f07bb3 | 2017-01-17 10:20:26 -0500 | [diff] [blame] | 398 | if [[ $NUM_COMPUTE_NODES -gt 3 ]] |
Srikanth Vavilapalli | b1c4da0 | 2016-11-17 15:24:28 -0600 | [diff] [blame] | 399 | then |
Andy Bavier | 0f07bb3 | 2017-01-17 10:20:26 -0500 | [diff] [blame] | 400 | echo "currently max only three compute nodes can be supported..." |
| 401 | NUM_COMPUTE_NODES=3 |
Srikanth Vavilapalli | b1c4da0 | 2016-11-17 15:24:28 -0600 | [diff] [blame] | 402 | fi |
| 403 | |
Sapan Bhatia | 01ddea6 | 2017-02-10 11:28:48 -0800 | [diff] [blame] | 404 | echo "==> Adding compute nodes: Starting" |
Srikanth Vavilapalli | b1c4da0 | 2016-11-17 15:24:28 -0600 | [diff] [blame] | 405 | for i in `seq 1 $NUM_COMPUTE_NODES`; |
| 406 | do |
| 407 | echo adding the compute node: compute-node-$i |
Zack Williams | 03a20ec | 2017-04-12 17:39:36 -0700 | [diff] [blame] | 408 | add_compute_node compute-node-$i ${VAGRANT_VM_PREFIX}_compute-node-$i |
Srikanth Vavilapalli | b1c4da0 | 2016-11-17 15:24:28 -0600 | [diff] [blame] | 409 | done |
Sapan Bhatia | 01ddea6 | 2017-02-10 11:28:48 -0800 | [diff] [blame] | 410 | echo "==> Adding compute nodes: Complete" |
Andy Bavier | 99c11d3 | 2016-09-14 17:21:20 -0400 | [diff] [blame] | 411 | |
Zack Williams | 4fd3dcc | 2017-02-08 20:46:14 -0700 | [diff] [blame] | 412 | # run diagnostics both before/after the fabric/e2e tests |
| 413 | if [[ $DIAGNOSTICS -eq 1 ]] |
| 414 | then |
| 415 | run_diagnostics |
| 416 | fi |
| 417 | |
| 418 | |
Andy Bavier | 0f07bb3 | 2017-01-17 10:20:26 -0500 | [diff] [blame] | 419 | if [[ $FABRIC -ne 0 ]] |
| 420 | then |
Sapan Bhatia | 01ddea6 | 2017-02-10 11:28:48 -0800 | [diff] [blame] | 421 | run_stage initialize_fabric |
Andy Bavier | 0f07bb3 | 2017-01-17 10:20:26 -0500 | [diff] [blame] | 422 | fi |
| 423 | |
Andy Bavier | 99c11d3 | 2016-09-14 17:21:20 -0400 | [diff] [blame] | 424 | if [[ $RUN_TEST -eq 1 ]] |
| 425 | then |
Sapan Bhatia | 01ddea6 | 2017-02-10 11:28:48 -0800 | [diff] [blame] | 426 | run_stage run_e2e_test |
Andy Bavier | 99c11d3 | 2016-09-14 17:21:20 -0400 | [diff] [blame] | 427 | fi |
| 428 | |
| 429 | if [[ $DIAGNOSTICS -eq 1 ]] |
| 430 | then |
Sapan Bhatia | 01ddea6 | 2017-02-10 11:28:48 -0800 | [diff] [blame] | 431 | run_stage run_diagnostics |
Andy Bavier | 99c11d3 | 2016-09-14 17:21:20 -0400 | [diff] [blame] | 432 | fi |
| 433 | |
| 434 | exit 0 |