blob: 2f7a17b00e8f770e417fb944d9947ee0c60bdb05 [file] [log] [blame]
Jesse Andrewsf6705492011-11-01 16:04:14 -07001#!/usr/bin/env bash
2
Jesse Andrews9c7c9082011-11-23 10:10:53 -08003# we will use the ``euca2ools`` cli tool that wraps the python boto
Jesse Andrews9f186342011-11-01 16:05:40 -07004# library to test ec2 compatibility
Jesse Andrewsf6705492011-11-01 16:04:14 -07005#
6
Jesse Andrewsf6705492011-11-01 16:04:14 -07007# This script exits on an error so that errors don't compound and you see
8# only the first error that occured.
9set -o errexit
10
11# Print the commands being run so that we can see the command that triggers
12# an error. It is also useful for following allowing as the install occurs.
13set -o xtrace
14
Jesse Andrewsf6705492011-11-01 16:04:14 -070015# Settings
16# ========
17
18# Use openrc + stackrc + localrc for settings
Jesse Andrews787af012011-11-01 16:44:19 -070019pushd $(cd $(dirname "$0")/.. && pwd)
Jesse Andrewsf6705492011-11-01 16:04:14 -070020source ./openrc
Jesse Andrews787af012011-11-01 16:44:19 -070021popd
Jesse Andrewsf6705492011-11-01 16:04:14 -070022
Anthony Youngabda4272011-12-16 20:16:20 +000023# Find a machine image to boot
Jesse Andrews9c7c9082011-11-23 10:10:53 -080024IMAGE=`euca-describe-images | grep machine | cut -f2 | head -n1`
Jesse Andrewsf6705492011-11-01 16:04:14 -070025
Anthony Youngabda4272011-12-16 20:16:20 +000026# Define secgroup
27SECGROUP=euca_secgroup
Jesse Andrewsf6705492011-11-01 16:04:14 -070028
Anthony Youngabda4272011-12-16 20:16:20 +000029# Add a secgroup
30euca-add-group -d description $SECGROUP
31
32# Launch it
Dean Troyer1d6e0e12011-12-23 12:45:13 -060033DEFAULT_INSTANCE_TYPE=${DEFAULT_INSTANCE_TYPE:-m1.tiny}
34INSTANCE=`euca-run-instances -g $SECGROUP -t $DEFAULT_INSTANCE_TYPE $IMAGE | grep INSTANCE | cut -f2`
Anthony Youngabda4272011-12-16 20:16:20 +000035
36# Assure it has booted within a reasonable time
Dean Troyerc3844242011-12-30 14:27:02 -060037if ! timeout $RUNNING_TIMEOUT sh -c "while ! euca-describe-instances $INSTANCE | grep -q running; do sleep 1; done"; then
Todd Willey9a3066f2011-11-05 11:02:34 -040038 echo "server didn't become active within $RUNNING_TIMEOUT seconds"
Jesse Andrewsf6705492011-11-01 16:04:14 -070039 exit 1
40fi
41
Anthony Youngabda4272011-12-16 20:16:20 +000042# Allocate floating address
43FLOATING_IP=`euca-allocate-address | cut -f2`
44
45# Release floating address
46euca-associate-address -i $INSTANCE $FLOATING_IP
47
48
49# Authorize pinging
50euca-authorize -P icmp -s 0.0.0.0/0 -t -1:-1 $SECGROUP
51
Dean Troyerc3844242011-12-30 14:27:02 -060052# Test we can ping our floating ip within ASSOCIATE_TIMEOUT seconds
53ASSOCIATE_TIMEOUT=${ASSOCIATE_TIMEOUT:-10}
54if ! timeout $ASSOCIATE_TIMEOUT sh -c "while ! ping -c1 -w1 $FLOATING_IP; do sleep 1; done"; then
55 echo "Couldn't ping server with floating ip"
Anthony Youngabda4272011-12-16 20:16:20 +000056 exit 1
57fi
58
59# Revoke pinging
60euca-revoke -P icmp -s 0.0.0.0/0 -t -1:-1 $SECGROUP
61
62# Delete group
63euca-delete-group $SECGROUP
64
65# Release floating address
66euca-disassociate-address $FLOATING_IP
67
68# Release floating address
69euca-release-address $FLOATING_IP
70
Dean Troyerc3844242011-12-30 14:27:02 -060071# Wait just a tick for everything above to complete so terminate doesn't fail
72if ! timeout $ASSOCIATE_TIMEOUT sh -c "while euca-describe-addresses | grep -q $FLOATING_IP; do sleep 1; done"; then
73 echo "Floating ip $FLOATING_IP not released within $ASSOCIATE_TIMEOUT seconds"
74 exit 1
75fi
76
Anthony Youngabda4272011-12-16 20:16:20 +000077# Terminate instance
Jesse Andrewsf6705492011-11-01 16:04:14 -070078euca-terminate-instances $INSTANCE