| Sean Dague | d093121 | 2012-10-04 16:06:44 -0400 | [diff] [blame] | 1 | # lib/tempest | 
|  | 2 |  | 
|  | 3 | # Dependencies: | 
|  | 4 | # ``functions`` file | 
| Attila Fazekas | 2aa3517 | 2012-12-05 20:03:40 +0100 | [diff] [blame] | 5 | # ``lib/nova`` service is runing | 
| Sean Dague | d093121 | 2012-10-04 16:06:44 -0400 | [diff] [blame] | 6 | # <list other global vars that are assumed to be defined> | 
| Attila Fazekas | 65c0846 | 2012-12-07 14:20:51 +0100 | [diff] [blame] | 7 | # - ``DEST`` | 
|  | 8 | # - ``ADMIN_PASSWORD`` | 
|  | 9 | # - ``DEFAULT_IMAGE_NAME`` | 
|  | 10 | # - ``S3_SERVICE_PORT`` | 
|  | 11 | # - ``SERVICE_HOST`` | 
|  | 12 | # - ``BASE_SQL_CONN`` ``lib/database`` declares | 
| Attila Fazekas | 2aa3517 | 2012-12-05 20:03:40 +0100 | [diff] [blame] | 13 | # Optional Dependencies: | 
| Attila Fazekas | 65c0846 | 2012-12-07 14:20:51 +0100 | [diff] [blame] | 14 | # IDENTITY_USE_SSL, IDENTITY_HOST, IDENTITY_PORT, IDENTITY_PATH | 
| Attila Fazekas | 2aa3517 | 2012-12-05 20:03:40 +0100 | [diff] [blame] | 15 | # ALT_* (similar vars exists in keystone_data.sh) | 
| Attila Fazekas | 65c0846 | 2012-12-07 14:20:51 +0100 | [diff] [blame] | 16 | # ``OS_USERNAME`` | 
|  | 17 | # ``IMAGE_PORT``, ``IMAGE_HOST`` | 
|  | 18 | # ``LIVE_MIGRATION_AVAILABLE`` | 
|  | 19 | # ``USE_BLOCK_MIGRATION_FOR_LIVE_MIGRATION`` | 
|  | 20 | # ``DEFAULT_INSTANCE_TYPE`` | 
|  | 21 | # ``DEFAULT_INSTANCE_USER`` | 
| Sean Dague | d093121 | 2012-10-04 16:06:44 -0400 | [diff] [blame] | 22 | # ``stack.sh`` calls the entry points in this order: | 
|  | 23 | # | 
| Attila Fazekas | 2aa3517 | 2012-12-05 20:03:40 +0100 | [diff] [blame] | 24 | # install_tempest | 
|  | 25 | # configure_tempest | 
|  | 26 | # init_tempest | 
|  | 27 | ## start_tempest | 
|  | 28 | ## stop_tempest | 
|  | 29 | ## cleanup_tempest | 
| Sean Dague | d093121 | 2012-10-04 16:06:44 -0400 | [diff] [blame] | 30 |  | 
|  | 31 | # Save trace setting | 
|  | 32 | XTRACE=$(set +o | grep xtrace) | 
|  | 33 | set +o xtrace | 
|  | 34 |  | 
| Sean Dague | d093121 | 2012-10-04 16:06:44 -0400 | [diff] [blame] | 35 | # Defaults | 
|  | 36 | # -------- | 
|  | 37 |  | 
|  | 38 | # <define global variables here that belong to this project> | 
|  | 39 |  | 
|  | 40 | # Set up default directories | 
| Attila Fazekas | 2aa3517 | 2012-12-05 20:03:40 +0100 | [diff] [blame] | 41 | NOVA_SOURCE_DIR=$DEST/nova | 
| Sean Dague | d093121 | 2012-10-04 16:06:44 -0400 | [diff] [blame] | 42 | TEMPEST_DIR=$DEST/tempest | 
| Attila Fazekas | 2aa3517 | 2012-12-05 20:03:40 +0100 | [diff] [blame] | 43 | TEMPEST_CONF_DIR=$TEMPEST_DIR/etc | 
|  | 44 | TEMPEST_CONF=$TEMPEST_CONF_DIR/tempest.conf | 
|  | 45 |  | 
|  | 46 | BUILD_INTERVAL=3 | 
|  | 47 | BUILD_TIMEOUT=400 | 
| Sean Dague | d093121 | 2012-10-04 16:06:44 -0400 | [diff] [blame] | 48 |  | 
|  | 49 | # Entry Points | 
|  | 50 | # ------------ | 
|  | 51 |  | 
|  | 52 |  | 
|  | 53 | # configure_tempest() - Set config files, create data dirs, etc | 
|  | 54 | function configure_tempest() { | 
| Attila Fazekas | 65c0846 | 2012-12-07 14:20:51 +0100 | [diff] [blame] | 55 | local image_lines | 
|  | 56 | local images | 
|  | 57 | local num_images | 
|  | 58 | local image_uuid | 
|  | 59 | local image_uuid_alt | 
| Attila Fazekas | 2aa3517 | 2012-12-05 20:03:40 +0100 | [diff] [blame] | 60 | local errexit | 
| Attila Fazekas | 65c0846 | 2012-12-07 14:20:51 +0100 | [diff] [blame] | 61 | local password | 
|  | 62 | local line | 
|  | 63 | local flavors | 
|  | 64 | local flavors_ref | 
|  | 65 | local flavor_lines | 
| Maru Newby | a5c774e | 2012-12-10 10:40:01 +0000 | [diff] [blame] | 66 | local public_network_id | 
|  | 67 | local tenant_networks_reachable | 
| Attila Fazekas | 2aa3517 | 2012-12-05 20:03:40 +0100 | [diff] [blame] | 68 |  | 
|  | 69 | #TODO(afazekas): | 
| Sean Dague | d093121 | 2012-10-04 16:06:44 -0400 | [diff] [blame] | 70 | # sudo python setup.py deploy | 
| Attila Fazekas | 2aa3517 | 2012-12-05 20:03:40 +0100 | [diff] [blame] | 71 |  | 
|  | 72 | # This function exits on an error so that errors don't compound and you see | 
|  | 73 | # only the first error that occured. | 
|  | 74 | errexit=$(set +o | grep errexit) | 
|  | 75 | set -o errexit | 
|  | 76 |  | 
|  | 77 | #Save IFS | 
|  | 78 | ifs=$IFS | 
|  | 79 |  | 
|  | 80 | # Glance should already contain images to be used in tempest | 
|  | 81 | # testing. Here we simply look for images stored in Glance | 
|  | 82 | # and set the appropriate variables for use in the tempest config | 
|  | 83 | # We ignore ramdisk and kernel images, look for the default image | 
| Attila Fazekas | 65c0846 | 2012-12-07 14:20:51 +0100 | [diff] [blame] | 84 | # ``DEFAULT_IMAGE_NAME``. If not found, we set the ``image_uuid`` to the | 
|  | 85 | # first image returned and set ``image_uuid_alt`` to the second, | 
| Attila Fazekas | 2aa3517 | 2012-12-05 20:03:40 +0100 | [diff] [blame] | 86 | # if there is more than one returned... | 
|  | 87 | # ... Also ensure we only take active images, so we don't get snapshots in process | 
| Attila Fazekas | 65c0846 | 2012-12-07 14:20:51 +0100 | [diff] [blame] | 88 | image_lines=`glance image-list` | 
| Attila Fazekas | 2aa3517 | 2012-12-05 20:03:40 +0100 | [diff] [blame] | 89 | IFS=$'\n\r' | 
| Attila Fazekas | 65c0846 | 2012-12-07 14:20:51 +0100 | [diff] [blame] | 90 | images="" | 
|  | 91 | for line in $image_lines; do | 
| Attila Fazekas | 2aa3517 | 2012-12-05 20:03:40 +0100 | [diff] [blame] | 92 | if [ -z $DEFAULT_IMAGE_NAME ]; then | 
| Attila Fazekas | 65c0846 | 2012-12-07 14:20:51 +0100 | [diff] [blame] | 93 | images="$images `echo $line | grep -v "^\(ID\|+--\)" | grep -v "\(aki\|ari\)" | grep 'active' | cut -d' ' -f2`" | 
| Attila Fazekas | 2aa3517 | 2012-12-05 20:03:40 +0100 | [diff] [blame] | 94 | else | 
| Attila Fazekas | 65c0846 | 2012-12-07 14:20:51 +0100 | [diff] [blame] | 95 | images="$images `echo $line | grep -v "^\(ID\|+--\)" | grep -v "\(aki\|ari\)" | grep 'active' | grep "$DEFAULT_IMAGE_NAME" | cut -d' ' -f2`" | 
| Attila Fazekas | 2aa3517 | 2012-12-05 20:03:40 +0100 | [diff] [blame] | 96 | fi | 
|  | 97 | done | 
|  | 98 | # Create array of image UUIDs... | 
|  | 99 | IFS=" " | 
| Attila Fazekas | 65c0846 | 2012-12-07 14:20:51 +0100 | [diff] [blame] | 100 | images=($images) | 
|  | 101 | num_images=${#images[*]} | 
|  | 102 | echo "Found $num_images images" | 
|  | 103 | if [[ $num_images -eq 0 ]]; then | 
| Attila Fazekas | 2aa3517 | 2012-12-05 20:03:40 +0100 | [diff] [blame] | 104 | echo "Found no valid images to use!" | 
|  | 105 | exit 1 | 
|  | 106 | fi | 
| Attila Fazekas | 65c0846 | 2012-12-07 14:20:51 +0100 | [diff] [blame] | 107 | image_uuid=${images[0]} | 
|  | 108 | image_uuid_alt=$image_uuid | 
|  | 109 | if [[ $num_images -gt 1 ]]; then | 
|  | 110 | image_uuid_alt=${images[1]} | 
| Attila Fazekas | 2aa3517 | 2012-12-05 20:03:40 +0100 | [diff] [blame] | 111 | fi | 
|  | 112 |  | 
|  | 113 | # Create tempest.conf from tempest.conf.sample | 
|  | 114 | # copy every time, because the image UUIDS are going to change | 
|  | 115 | cp $TEMPEST_CONF.sample $TEMPEST_CONF | 
|  | 116 |  | 
|  | 117 | IDENTITY_USE_SSL=${IDENTITY_USE_SSL:-False} | 
|  | 118 | IDENTITY_HOST=${IDENTITY_HOST:-127.0.0.1} | 
|  | 119 | IDENTITY_PORT=${IDENTITY_PORT:-5000} | 
|  | 120 | # TODO(jaypipes): This is dumb and needs to be removed | 
|  | 121 | # from the Tempest configuration file entirely... | 
|  | 122 | IDENTITY_PATH=${IDENTITY_PATH:-tokens} | 
|  | 123 |  | 
| Attila Fazekas | 65c0846 | 2012-12-07 14:20:51 +0100 | [diff] [blame] | 124 | password=${ADMIN_PASSWORD:-secrete} | 
| Attila Fazekas | 2aa3517 | 2012-12-05 20:03:40 +0100 | [diff] [blame] | 125 |  | 
|  | 126 | # See files/keystone_data.sh where alt_demo user | 
|  | 127 | # and tenant are set up... | 
|  | 128 | ALT_USERNAME=${ALT_USERNAME:-alt_demo} | 
|  | 129 | ALT_TENANT_NAME=${ALT_TENANT_NAME:-alt_demo} | 
|  | 130 |  | 
|  | 131 | # Check Nova for existing flavors and, if set, look for the | 
| Attila Fazekas | 65c0846 | 2012-12-07 14:20:51 +0100 | [diff] [blame] | 132 | # ``DEFAULT_INSTANCE_TYPE`` and use that. Otherwise, just use the first flavor. | 
|  | 133 | flavor_lines=`nova flavor-list` | 
|  | 134 | IFS=$'\r\n' | 
|  | 135 | flavors="" | 
|  | 136 | for line in $flavor_lines; do | 
| Attila Fazekas | 2aa3517 | 2012-12-05 20:03:40 +0100 | [diff] [blame] | 137 | if [ -z $DEFAULT_INSTANCE_TYPE ]; then | 
| Attila Fazekas | 65c0846 | 2012-12-07 14:20:51 +0100 | [diff] [blame] | 138 | flavors="$flavors `echo $line | grep -v "^\(|\s*ID\|+--\)" | cut -d' ' -f2`" | 
| Attila Fazekas | 2aa3517 | 2012-12-05 20:03:40 +0100 | [diff] [blame] | 139 | else | 
| Attila Fazekas | 65c0846 | 2012-12-07 14:20:51 +0100 | [diff] [blame] | 140 | flavors="$flavors `echo $line | grep -v "^\(|\s*ID\|+--\)" | grep "$DEFAULT_INSTANCE_TYPE" | cut -d' ' -f2`" | 
| Attila Fazekas | 2aa3517 | 2012-12-05 20:03:40 +0100 | [diff] [blame] | 141 | fi | 
|  | 142 | done | 
|  | 143 |  | 
|  | 144 | IFS=" " | 
| Attila Fazekas | 65c0846 | 2012-12-07 14:20:51 +0100 | [diff] [blame] | 145 | flavors=($flavors) | 
|  | 146 | num_flavors=${#flavors[*]} | 
|  | 147 | echo "Found $num_flavors flavors" | 
|  | 148 | if [[ $num_flavors -eq 0 ]]; then | 
| Attila Fazekas | 2aa3517 | 2012-12-05 20:03:40 +0100 | [diff] [blame] | 149 | echo "Found no valid flavors to use!" | 
|  | 150 | exit 1 | 
|  | 151 | fi | 
| Attila Fazekas | 65c0846 | 2012-12-07 14:20:51 +0100 | [diff] [blame] | 152 | flavor_ref=${flavors[0]} | 
|  | 153 | flavor_ref_alt=$flavor_ref | 
|  | 154 | if [[ $num_flavors -gt 1 ]]; then | 
|  | 155 | flavor_ref_alt=${flavors[1]} | 
| Attila Fazekas | 2aa3517 | 2012-12-05 20:03:40 +0100 | [diff] [blame] | 156 | fi | 
|  | 157 |  | 
| Maru Newby | a5c774e | 2012-12-10 10:40:01 +0000 | [diff] [blame] | 158 | if [ "$Q_USE_NAMESPACE" != "False" ]; then | 
|  | 159 | tenant_networks_reachable=false | 
|  | 160 | else | 
|  | 161 | tenant_networks_reachable=true | 
|  | 162 | fi | 
|  | 163 |  | 
|  | 164 | if is_service_enabled q-l3; then | 
|  | 165 | public_network_id=$(quantum net-list | grep $PUBLIC_NETWORK_NAME | \ | 
|  | 166 | awk '{print $2}') | 
|  | 167 | fi | 
|  | 168 |  | 
| Attila Fazekas | 2aa3517 | 2012-12-05 20:03:40 +0100 | [diff] [blame] | 169 | # Timeouts | 
|  | 170 | iniset $TEMPEST_CONF compute build_timeout $BUILD_TIMEOUT | 
|  | 171 | iniset $TEMPEST_CONF volume build_timeout $BUILD_TIMEOUT | 
|  | 172 | iniset $TEMPEST_CONF boto build_timeout $BUILD_TIMEOUT | 
|  | 173 | iniset $TEMPEST_CONF compute build_interval $BUILD_INTERVAL | 
|  | 174 | iniset $TEMPEST_CONF volume build_interval $BUILD_INTERVAL | 
|  | 175 | iniset $TEMPEST_CONF boto build_interval $BUILD_INTERVAL | 
|  | 176 | iniset $TEMPEST_CONF boto http_socket_timeout 5 | 
|  | 177 |  | 
|  | 178 | iniset $TEMPEST_CONF identity use_ssl $IDENTITY_USE_SSL | 
|  | 179 | iniset $TEMPEST_CONF identity host $IDENTITY_HOST | 
|  | 180 | iniset $TEMPEST_CONF identity port $IDENTITY_PORT | 
|  | 181 | iniset $TEMPEST_CONF identity path $IDENTITY_PATH | 
|  | 182 |  | 
| Attila Fazekas | 65c0846 | 2012-12-07 14:20:51 +0100 | [diff] [blame] | 183 | iniset $TEMPEST_CONF compute password "$password" | 
| Attila Fazekas | 2aa3517 | 2012-12-05 20:03:40 +0100 | [diff] [blame] | 184 | iniset $TEMPEST_CONF compute alt_username $ALT_USERNAME | 
| Attila Fazekas | 65c0846 | 2012-12-07 14:20:51 +0100 | [diff] [blame] | 185 | iniset $TEMPEST_CONF compute alt_password "$password" | 
| Attila Fazekas | 2aa3517 | 2012-12-05 20:03:40 +0100 | [diff] [blame] | 186 | iniset $TEMPEST_CONF compute alt_tenant_name $ALT_TENANT_NAME | 
|  | 187 | iniset $TEMPEST_CONF compute resize_available False | 
|  | 188 | iniset $TEMPEST_CONF compute change_password_available False | 
|  | 189 | iniset $TEMPEST_CONF compute compute_log_level ERROR | 
|  | 190 | #Skip until #1074039 is fixed | 
|  | 191 | iniset $TEMPEST_CONF compute run_ssh False | 
|  | 192 | iniset $TEMPEST_CONF compute ssh_user ${DEFAULT_INSTANCE_USER:-$OS_USERNAME} | 
|  | 193 | iniset $TEMPEST_CONF compute network_for_ssh private | 
|  | 194 | iniset $TEMPEST_CONF compute ip_version_for_ssh 4 | 
|  | 195 | iniset $TEMPEST_CONF compute ssh_timeout 4 | 
| Attila Fazekas | 65c0846 | 2012-12-07 14:20:51 +0100 | [diff] [blame] | 196 | iniset $TEMPEST_CONF compute image_ref $image_uuid | 
|  | 197 | iniset $TEMPEST_CONF compute image_ref_alt $image_uuid_alt | 
|  | 198 | iniset $TEMPEST_CONF compute flavor_ref $flavor_ref | 
|  | 199 | iniset $TEMPEST_CONF compute flavor_ref_alt $flavor_ref_alt | 
| Attila Fazekas | 2aa3517 | 2012-12-05 20:03:40 +0100 | [diff] [blame] | 200 | iniset $TEMPEST_CONF compute source_dir $NOVA_SOURCE_DIR | 
|  | 201 | iniset $TEMPEST_CONF compute live_migration_available ${LIVE_MIGRATION_AVAILABLE:-False} | 
|  | 202 | iniset $TEMPEST_CONF compute use_block_migration_for_live_migration	${USE_BLOCK_MIGRATION_FOR_LIVE_MIGRATION:-False} | 
|  | 203 | # Inherited behavior, might be wrong | 
|  | 204 | iniset $TEMPEST_CONF compute bin_dir $NOVA_BIN_DIR | 
|  | 205 | # TODO(jaypipes): Create the key file here... right now, no whitebox | 
|  | 206 | # tests actually use a key. | 
|  | 207 | iniset $TEMPEST_CONF compute path_to_private_key $TEMPEST_DIR/id_rsa | 
|  | 208 | iniset $TEMPEST_CONF compute db_uri $BASE_SQL_CONN/nova | 
|  | 209 |  | 
|  | 210 | # image | 
|  | 211 | iniset $TEMPEST_CONF image host ${IMAGE_HOST:-127.0.0.1} | 
|  | 212 | iniset $TEMPEST_CONF image port ${IMAGE_PORT:-9292} | 
| Attila Fazekas | 65c0846 | 2012-12-07 14:20:51 +0100 | [diff] [blame] | 213 | iniset $TEMPEST_CONF image password "$password" | 
| Attila Fazekas | 2aa3517 | 2012-12-05 20:03:40 +0100 | [diff] [blame] | 214 |  | 
|  | 215 | # identity-admin | 
| Attila Fazekas | 65c0846 | 2012-12-07 14:20:51 +0100 | [diff] [blame] | 216 | iniset $TEMPEST_CONF "identity-admin" password "$password" | 
| Attila Fazekas | 2aa3517 | 2012-12-05 20:03:40 +0100 | [diff] [blame] | 217 |  | 
|  | 218 | # compute admin | 
| Attila Fazekas | 65c0846 | 2012-12-07 14:20:51 +0100 | [diff] [blame] | 219 | iniset $TEMPEST_CONF "compute-admin" password "$password" | 
| Attila Fazekas | 2aa3517 | 2012-12-05 20:03:40 +0100 | [diff] [blame] | 220 |  | 
| Maru Newby | a5c774e | 2012-12-10 10:40:01 +0000 | [diff] [blame] | 221 | # network admin | 
|  | 222 | iniset $TEMPEST_CONF "network-admin" password "$password" | 
|  | 223 |  | 
| Attila Fazekas | 2aa3517 | 2012-12-05 20:03:40 +0100 | [diff] [blame] | 224 | # network | 
|  | 225 | iniset $TEMPEST_CONF network api_version 2.0 | 
| Maru Newby | a5c774e | 2012-12-10 10:40:01 +0000 | [diff] [blame] | 226 | iniset $TEMPEST_CONF network password "$password" | 
|  | 227 | iniset $TEMPEST_CONF network tenant_networks_reachable "$tenant_networks_reachable" | 
|  | 228 | iniset $TEMPEST_CONF network public_network_id "$public_network_id" | 
| Attila Fazekas | 2aa3517 | 2012-12-05 20:03:40 +0100 | [diff] [blame] | 229 |  | 
|  | 230 | #boto | 
|  | 231 | iniset $TEMPEST_CONF boto ec2_url "http://$SERVICE_HOST:8773/services/Cloud" | 
|  | 232 | iniset $TEMPEST_CONF boto s3_url "http://$SERVICE_HOST:${S3_SERVICE_PORT:-3333}" | 
|  | 233 |  | 
|  | 234 | echo "Created tempest configuration file:" | 
|  | 235 | cat $TEMPEST_CONF | 
|  | 236 |  | 
|  | 237 | # Restore IFS | 
|  | 238 | IFS=$ifs | 
|  | 239 | #Restore errexit | 
|  | 240 | $errexit | 
| Sean Dague | d093121 | 2012-10-04 16:06:44 -0400 | [diff] [blame] | 241 | } | 
|  | 242 |  | 
|  | 243 |  | 
|  | 244 | # install_tempest() - Collect source and prepare | 
|  | 245 | function install_tempest() { | 
|  | 246 | git_clone $TEMPEST_REPO $TEMPEST_DIR $TEMPEST_BRANCH | 
| Jeremy Stanley | 9a352da | 2012-11-28 17:22:39 +0000 | [diff] [blame] | 247 |  | 
|  | 248 | # Tempest doesn't satisfy its dependencies on its own, so | 
|  | 249 | # install them here instead. | 
| jiajun xu | d75bc1f | 2012-12-04 08:51:35 +0800 | [diff] [blame] | 250 | pip_install -r $TEMPEST_DIR/tools/pip-requires | 
| Sean Dague | d093121 | 2012-10-04 16:06:44 -0400 | [diff] [blame] | 251 | } | 
|  | 252 |  | 
| Sean Dague | d093121 | 2012-10-04 16:06:44 -0400 | [diff] [blame] | 253 | # Restore xtrace | 
|  | 254 | $XTRACE |