blob: a165d55bb3dce6239f39ddc7927001344080bc1e [file] [log] [blame]
Vishvananda Ishaya75bbd752012-01-19 23:28:46 +00001#!/usr/bin/env bash
2
3# we will use the ``euca2ools`` cli tool that wraps the python boto
4# library to test ec2 compatibility
Dean Troyer489bd2a2012-03-02 10:44:29 -06005
6echo "**************************************************"
7echo "Begin DevStack Exercise: $0"
8echo "**************************************************"
Vishvananda Ishaya75bbd752012-01-19 23:28:46 +00009
10# This script exits on an error so that errors don't compound and you see
11# only the first error that occured.
12set -o errexit
13
14# Print the commands being run so that we can see the command that triggers
15# an error. It is also useful for following allowing as the install occurs.
16set -o xtrace
17
18# Settings
19# ========
20
Dean Troyer0bd24102012-03-08 00:33:54 -060021# Keep track of the current directory
22EXERCISE_DIR=$(cd $(dirname "$0") && pwd)
23TOP_DIR=$(cd $EXERCISE_DIR/..; pwd)
Dean Troyer489bd2a2012-03-02 10:44:29 -060024
25# Import common functions
Dean Troyer0bd24102012-03-08 00:33:54 -060026source $TOP_DIR/functions
Dean Troyer489bd2a2012-03-02 10:44:29 -060027
Dean Troyer0bd24102012-03-08 00:33:54 -060028# Import EC2 configuration
29source $TOP_DIR/eucarc
Vishvananda Ishaya75bbd752012-01-19 23:28:46 +000030
Dean Troyer51fb4542012-03-09 22:21:59 -060031# Import exercise configuration
32source $TOP_DIR/exerciserc
33
Vishvananda Ishaya75bbd752012-01-19 23:28:46 +000034# Remove old certificates
Dean Troyer0bd24102012-03-08 00:33:54 -060035rm -f $TOP_DIR/cacert.pem
36rm -f $TOP_DIR/cert.pem
37rm -f $TOP_DIR/pk.pem
Vishvananda Ishaya75bbd752012-01-19 23:28:46 +000038
39# Get Certificates
Dean Troyer0bd24102012-03-08 00:33:54 -060040nova x509-get-root-cert $TOP_DIR/cacert.pem
41nova x509-create-cert $TOP_DIR/pk.pem $TOP_DIR/cert.pem
Vishvananda Ishaya75bbd752012-01-19 23:28:46 +000042
43# Max time to wait for image to be registered
44REGISTER_TIMEOUT=${REGISTER_TIMEOUT:-15}
45
46BUCKET=testbucket
47IMAGE=bundle.img
48truncate -s 5M /tmp/$IMAGE
49euca-bundle-image -i /tmp/$IMAGE
Dean Troyer489bd2a2012-03-02 10:44:29 -060050die_if_error "Failure bundling image $IMAGE"
Vishvananda Ishaya75bbd752012-01-19 23:28:46 +000051
52
53euca-upload-bundle -b $BUCKET -m /tmp/$IMAGE.manifest.xml
Dean Troyer489bd2a2012-03-02 10:44:29 -060054die_if_error "Failure uploading bundle $IMAGE to $BUCKET"
55
Vishvananda Ishaya75bbd752012-01-19 23:28:46 +000056AMI=`euca-register $BUCKET/$IMAGE.manifest.xml | cut -f2`
Dean Troyer489bd2a2012-03-02 10:44:29 -060057die_if_not_set AMI "Failure registering $BUCKET/$IMAGE"
Vishvananda Ishaya75bbd752012-01-19 23:28:46 +000058
59# Wait for the image to become available
Chmouel Boudjnah77b0e1d2012-02-29 16:55:43 +000060if ! timeout $REGISTER_TIMEOUT sh -c "while euca-describe-images | grep $AMI | grep -q available; do sleep 1; done"; then
Vishvananda Ishaya75bbd752012-01-19 23:28:46 +000061 echo "Image $AMI not available within $REGISTER_TIMEOUT seconds"
62 exit 1
63fi
Dean Troyer80756ea2012-02-01 18:01:01 -060064
65# Clean up
66euca-deregister $AMI
Dean Troyer489bd2a2012-03-02 10:44:29 -060067die_if_error "Failure deregistering $AMI"
68
69set +o xtrace
70echo "**************************************************"
71echo "End DevStack Exercise: $0"
72echo "**************************************************"