blob: ae3198f941b542bc421a712aef41be11ee18a8b6 [file] [log] [blame]
John Garbuttfd1c87e2012-02-24 14:52:54 +00001#!/usr/bin/env bash
2
3# **aggregates.sh**
4
5# This script demonstrates how to use host aggregates:
6# * Create an Aggregate
7# * Updating Aggregate details
8# * Testing Aggregate metadata
9# * Testing Aggregate delete
Joe Gordonb7ef5392012-08-01 16:13:42 -070010# * Testing General Aggregates (https://blueprints.launchpad.net/nova/+spec/general-host-aggregates)
11# * Testing add/remove hosts (with one host)
John Garbuttfd1c87e2012-02-24 14:52:54 +000012
13echo "**************************************************"
14echo "Begin DevStack Exercise: $0"
15echo "**************************************************"
16
17# This script exits on an error so that errors don't compound and you see
Joe Gordonb7ef5392012-08-01 16:13:42 -070018# only the first error that occurred.
John Garbuttfd1c87e2012-02-24 14:52:54 +000019set -o errexit
20
21# Print the commands being run so that we can see the command that triggers
22# an error. It is also useful for following allowing as the install occurs.
23set -o xtrace
24
25
26# Settings
27# ========
28
29# Keep track of the current directory
30EXERCISE_DIR=$(cd $(dirname "$0") && pwd)
31TOP_DIR=$(cd $EXERCISE_DIR/..; pwd)
32
33# Import common functions
34source $TOP_DIR/functions
35
36# Import configuration
37source $TOP_DIR/openrc
38
39# Import exercise configuration
40source $TOP_DIR/exerciserc
41
Dean Troyerda85cda2013-02-15 11:07:14 -060042# Test as the admin user
43. openrc admin admin
John Garbuttfd1c87e2012-02-24 14:52:54 +000044
45
46# Create an aggregate
47# ===================
48
49AGGREGATE_NAME=test_aggregate_$RANDOM
Joe Gordonb7ef5392012-08-01 16:13:42 -070050AGGREGATE2_NAME=test_aggregate_$RANDOM
John Garbuttfd1c87e2012-02-24 14:52:54 +000051AGGREGATE_A_ZONE=nova
52
53exit_if_aggregate_present() {
54 aggregate_name=$1
55
Dean Troyerda85cda2013-02-15 11:07:14 -060056 if [ $(nova aggregate-list | grep -c " $aggregate_name ") == 0 ]; then
John Garbuttfd1c87e2012-02-24 14:52:54 +000057 echo "SUCCESS $aggregate_name not present"
58 else
59 echo "ERROR found aggregate: $aggregate_name"
60 exit -1
61 fi
62}
63
64exit_if_aggregate_present $AGGREGATE_NAME
65
Dean Troyerda85cda2013-02-15 11:07:14 -060066AGGREGATE_ID=$(nova aggregate-create $AGGREGATE_NAME $AGGREGATE_A_ZONE | grep " $AGGREGATE_NAME " | get_field 1)
67AGGREGATE2_ID=$(nova aggregate-create $AGGREGATE2_NAME $AGGREGATE_A_ZONE | grep " $AGGREGATE2_NAME " | get_field 1)
John Garbuttfd1c87e2012-02-24 14:52:54 +000068
69# check aggregate created
70nova aggregate-list | grep -q " $AGGREGATE_NAME " || die "Aggregate $AGGREGATE_NAME not created"
71
72
73# Ensure creating a duplicate fails
74# =================================
75
76if nova aggregate-create $AGGREGATE_NAME $AGGREGATE_A_ZONE; then
77 echo "ERROR could create duplicate aggregate"
78 exit -1
79fi
80
81
82# Test aggregate-update (and aggregate-details)
83# =============================================
84AGGREGATE_NEW_NAME=test_aggregate_$RANDOM
85
86nova aggregate-update $AGGREGATE_ID $AGGREGATE_NEW_NAME
87nova aggregate-details $AGGREGATE_ID | grep $AGGREGATE_NEW_NAME
88nova aggregate-details $AGGREGATE_ID | grep $AGGREGATE_A_ZONE
89
90nova aggregate-update $AGGREGATE_ID $AGGREGATE_NAME $AGGREGATE_A_ZONE
91nova aggregate-details $AGGREGATE_ID | grep $AGGREGATE_NAME
92nova aggregate-details $AGGREGATE_ID | grep $AGGREGATE_A_ZONE
93
94
95# Test aggregate-set-metadata
96# ===========================
97META_DATA_1_KEY=asdf
98META_DATA_2_KEY=foo
99META_DATA_3_KEY=bar
100
Joe Gordon5c1bedd2012-12-12 12:03:19 +0000101#ensure no additional metadata is set
102nova aggregate-details $AGGREGATE_ID | egrep "{u'availability_zone': u'$AGGREGATE_A_ZONE'}|{}"
John Garbuttfd1c87e2012-02-24 14:52:54 +0000103
104nova aggregate-set-metadata $AGGREGATE_ID ${META_DATA_1_KEY}=123
105nova aggregate-details $AGGREGATE_ID | grep $META_DATA_1_KEY
106nova aggregate-details $AGGREGATE_ID | grep 123
107
108nova aggregate-set-metadata $AGGREGATE_ID ${META_DATA_2_KEY}=456
109nova aggregate-details $AGGREGATE_ID | grep $META_DATA_1_KEY
110nova aggregate-details $AGGREGATE_ID | grep $META_DATA_2_KEY
111
112nova aggregate-set-metadata $AGGREGATE_ID $META_DATA_2_KEY ${META_DATA_3_KEY}=789
113nova aggregate-details $AGGREGATE_ID | grep $META_DATA_1_KEY
114nova aggregate-details $AGGREGATE_ID | grep $META_DATA_3_KEY
115
116nova aggregate-details $AGGREGATE_ID | grep $META_DATA_2_KEY && die "ERROR metadata was not cleared"
117
118nova aggregate-set-metadata $AGGREGATE_ID $META_DATA_3_KEY $META_DATA_1_KEY
Joe Gordon5c1bedd2012-12-12 12:03:19 +0000119nova aggregate-details $AGGREGATE_ID | egrep "{u'availability_zone': u'$AGGREGATE_A_ZONE'}|{}"
John Garbuttfd1c87e2012-02-24 14:52:54 +0000120
121
122# Test aggregate-add/remove-host
123# ==============================
124if [ "$VIRT_DRIVER" == "xenserver" ]; then
Joe Gordonb7ef5392012-08-01 16:13:42 -0700125 echo "TODO(johngarbutt) add tests for add/remove host from pool aggregate"
John Garbuttfd1c87e2012-02-24 14:52:54 +0000126fi
Dean Troyerda85cda2013-02-15 11:07:14 -0600127FIRST_HOST=$(nova host-list | grep compute | get_field 1 | head -1)
Joe Gordonb7ef5392012-08-01 16:13:42 -0700128# Make sure can add two aggregates to same host
Mate Lakat178b8402012-09-05 10:42:10 +0100129nova aggregate-add-host $AGGREGATE_ID $FIRST_HOST
130nova aggregate-add-host $AGGREGATE2_ID $FIRST_HOST
131if nova aggregate-add-host $AGGREGATE2_ID $FIRST_HOST; then
Joe Gordonb7ef5392012-08-01 16:13:42 -0700132 echo "ERROR could add duplicate host to single aggregate"
133 exit -1
134fi
Mate Lakat178b8402012-09-05 10:42:10 +0100135nova aggregate-remove-host $AGGREGATE2_ID $FIRST_HOST
136nova aggregate-remove-host $AGGREGATE_ID $FIRST_HOST
John Garbuttfd1c87e2012-02-24 14:52:54 +0000137
138# Test aggregate-delete
139# =====================
140nova aggregate-delete $AGGREGATE_ID
Joe Gordonb7ef5392012-08-01 16:13:42 -0700141nova aggregate-delete $AGGREGATE2_ID
John Garbuttfd1c87e2012-02-24 14:52:54 +0000142exit_if_aggregate_present $AGGREGATE_NAME
143
John Garbuttfd1c87e2012-02-24 14:52:54 +0000144set +o xtrace
145echo "**************************************************"
146echo "End DevStack Exercise: $0"
147echo "**************************************************"