Make devstack functions support grenade

'grenade' test job runs two versions of devstack - 'base' and 'target'.
And all devstack functions should be error-proof running more than one
time - 'grenade' needs twice. Therefore, make lots of devstack
functions check for results of previous runs such as presence of
resources that are going to be created.

Change-Id: I4232382d3c944666bbf0916a3f285b84f6ff9d64
This commit is contained in:
vponomaryov 2016-04-14 15:08:53 +03:00
parent 53364e07a3
commit d706a595ea

View File

@ -118,9 +118,6 @@ function set_cinder_quotas {
# configure_manila - Set config files, create data dirs, etc # configure_manila - Set config files, create data dirs, etc
function configure_manila { function configure_manila {
setup_develop $MANILA_DIR
setup_develop $MANILACLIENT_DIR
if [[ ! -d $MANILA_CONF_DIR ]]; then if [[ ! -d $MANILA_CONF_DIR ]]; then
sudo mkdir -p $MANILA_CONF_DIR sudo mkdir -p $MANILA_CONF_DIR
fi fi
@ -265,7 +262,12 @@ function configure_manila_ui {
function create_manila_service_keypair { function create_manila_service_keypair {
nova keypair-add $MANILA_SERVICE_KEYPAIR_NAME --pub-key $MANILA_PATH_TO_PUBLIC_KEY if is_service_enabled nova; then
local keypair_exists=$( nova keypair-list | grep " $MANILA_SERVICE_KEYPAIR_NAME " )
if [[ -z $keypair_exists ]]; then
nova keypair-add $MANILA_SERVICE_KEYPAIR_NAME --pub-key $MANILA_PATH_TO_PUBLIC_KEY
fi
fi
} }
@ -281,12 +283,15 @@ function create_service_share_servers {
if [[ $share_driver == $generic_driver ]]; then if [[ $share_driver == $generic_driver ]]; then
if [[ $(trueorfalse False driver_handles_share_servers) == False ]]; then if [[ $(trueorfalse False driver_handles_share_servers) == False ]]; then
vm_name='manila_service_share_server_'$BE vm_name='manila_service_share_server_'$BE
nova boot $vm_name \ local vm_exists=$( nova list --all-tenants | grep " $vm_name " )
--flavor $MANILA_SERVICE_VM_FLAVOR_NAME \ if [[ -z $vm_exists ]]; then
--image $MANILA_SERVICE_IMAGE_NAME \ nova boot $vm_name \
--nic net-id=$private_net_id \ --flavor $MANILA_SERVICE_VM_FLAVOR_NAME \
--security-groups $MANILA_SERVICE_SECGROUP \ --image $MANILA_SERVICE_IMAGE_NAME \
--key-name $MANILA_SERVICE_KEYPAIR_NAME --nic net-id=$private_net_id \
--security-groups $MANILA_SERVICE_SECGROUP \
--key-name $MANILA_SERVICE_KEYPAIR_NAME
fi
vm_id=$(nova show $vm_name | grep ' id ' | get_field 2) vm_id=$(nova show $vm_name | grep ' id ' | get_field 2)
@ -297,8 +302,15 @@ function create_service_share_servers {
if is_service_enabled neutron; then if is_service_enabled neutron; then
if [ $created_admin_network == false ]; then if [ $created_admin_network == false ]; then
project_id=$(openstack project show $SERVICE_PROJECT_NAME -c id -f value) project_id=$(openstack project show $SERVICE_PROJECT_NAME -c id -f value)
admin_net_id=$(neutron net-create --tenant-id $project_id admin_net | grep ' id ' | get_field 2) local admin_net_id=$( neutron net-list --all-tenants | grep " admin_net " | get_field 1 )
admin_subnet_id=$(neutron subnet-create --tenant-id $project_id --ip_version 4 --no-gateway --name admin_subnet --subnetpool None $admin_net_id $FIXED_RANGE | grep ' id ' | get_field 2) if [[ -z $admin_net_id ]]; then
admin_net_id=$(neutron net-create --tenant-id $project_id admin_net | grep ' id ' | get_field 2)
fi
local admin_subnet_id=$( neutron subnet-list --all-tenants | grep " admin_subnet " | get_field 1 )
if [[ -z $admin_subnet_id ]]; then
admin_subnet_id=$(neutron subnet-create --tenant-id $project_id --ip_version 4 --no-gateway --name admin_subnet --subnetpool None $admin_net_id $FIXED_RANGE | grep ' id ' | get_field 2)
fi
created_admin_network=true created_admin_network=true
fi fi
iniset $MANILA_CONF $BE admin_network_id $admin_net_id iniset $MANILA_CONF $BE admin_network_id $admin_net_id
@ -326,23 +338,32 @@ function configure_data_service_generic_driver {
# create_manila_service_flavor - creates flavor, that will be used by backends # create_manila_service_flavor - creates flavor, that will be used by backends
# with configured generic driver to boot Nova VMs with. # with configured generic driver to boot Nova VMs with.
function create_manila_service_flavor { function create_manila_service_flavor {
# Create flavor for Manila's service VM if is_service_enabled nova; then
nova flavor-create \ local flavor_exists=$( nova flavor-list | grep " $MANILA_SERVICE_VM_FLAVOR_NAME " )
$MANILA_SERVICE_VM_FLAVOR_NAME \ if [[ -z $flavor_exists ]]; then
$MANILA_SERVICE_VM_FLAVOR_REF \ # Create flavor for Manila's service VM
$MANILA_SERVICE_VM_FLAVOR_RAM \ nova flavor-create \
$MANILA_SERVICE_VM_FLAVOR_DISK \ $MANILA_SERVICE_VM_FLAVOR_NAME \
$MANILA_SERVICE_VM_FLAVOR_VCPUS $MANILA_SERVICE_VM_FLAVOR_REF \
$MANILA_SERVICE_VM_FLAVOR_RAM \
$MANILA_SERVICE_VM_FLAVOR_DISK \
$MANILA_SERVICE_VM_FLAVOR_VCPUS
fi
fi
} }
# create_manila_service_image - creates image, that will be used by backends # create_manila_service_image - creates image, that will be used by backends
# with configured generic driver to boot Nova VMs from. # with configured generic driver to boot Nova VMs from.
function create_manila_service_image { function create_manila_service_image {
TOKEN=$(openstack token issue -c id -f value) if is_service_enabled nova; then
TOKEN=$(openstack token issue -c id -f value)
# Download Manila's image local image_exists=$( nova image-list | grep " $MANILA_SERVICE_IMAGE_NAME " )
if is_service_enabled g-reg; then if [[ -z $image_exists ]]; then
upload_image $MANILA_SERVICE_IMAGE_URL $TOKEN # Download Manila's image
if is_service_enabled g-reg; then
upload_image $MANILA_SERVICE_IMAGE_URL $TOKEN
fi
fi
fi fi
} }
@ -420,7 +441,10 @@ function create_default_share_type {
enabled_backends=(${MANILA_ENABLED_BACKENDS//,/ }) enabled_backends=(${MANILA_ENABLED_BACKENDS//,/ })
driver_handles_share_servers=$(iniget $MANILA_CONF ${enabled_backends[0]} driver_handles_share_servers) driver_handles_share_servers=$(iniget $MANILA_CONF ${enabled_backends[0]} driver_handles_share_servers)
manila type-create $MANILA_DEFAULT_SHARE_TYPE $driver_handles_share_servers local type_exists=$( manila type-list | grep " $MANILA_DEFAULT_SHARE_TYPE " )
if [[ -z $type_exists ]]; then
manila type-create $MANILA_DEFAULT_SHARE_TYPE $driver_handles_share_servers
fi
if [[ $MANILA_DEFAULT_SHARE_TYPE_EXTRA_SPECS ]]; then if [[ $MANILA_DEFAULT_SHARE_TYPE_EXTRA_SPECS ]]; then
manila type-key $MANILA_DEFAULT_SHARE_TYPE set $MANILA_DEFAULT_SHARE_TYPE_EXTRA_SPECS manila type-key $MANILA_DEFAULT_SHARE_TYPE set $MANILA_DEFAULT_SHARE_TYPE_EXTRA_SPECS
fi fi
@ -533,6 +557,8 @@ function init_manila {
# install_manila - Collect source and prepare # install_manila - Collect source and prepare
function install_manila { function install_manila {
git_clone $MANILACLIENT_REPO $MANILACLIENT_DIR $MANILACLIENT_BRANCH git_clone $MANILACLIENT_REPO $MANILACLIENT_DIR $MANILACLIENT_BRANCH
setup_develop $MANILACLIENT_DIR
setup_develop $MANILA_DIR
if [ "$SHARE_DRIVER" == "manila.share.drivers.lvm.LVMShareDriver" ]; then if [ "$SHARE_DRIVER" == "manila.share.drivers.lvm.LVMShareDriver" ]; then
if is_service_enabled m-shr; then if is_service_enabled m-shr; then
@ -610,10 +636,15 @@ function start_manila {
sleep 3 # Wait for 3 sec to ensure that apache is running sleep 3 # Wait for 3 sec to ensure that apache is running
fi fi
screen_it m-api "cd $MANILA_DIR && $MANILA_BIN_DIR/manila-api --config-file $MANILA_CONF" run_process m-api "$MANILA_BIN_DIR/manila-api --config-file $MANILA_CONF"
screen_it m-shr "cd $MANILA_DIR && $MANILA_BIN_DIR/manila-share --config-file $MANILA_CONF" run_process m-shr "$MANILA_BIN_DIR/manila-share --config-file $MANILA_CONF"
screen_it m-sch "cd $MANILA_DIR && $MANILA_BIN_DIR/manila-scheduler --config-file $MANILA_CONF" run_process m-sch "$MANILA_BIN_DIR/manila-scheduler --config-file $MANILA_CONF"
screen_it m-dat "cd $MANILA_DIR && $MANILA_BIN_DIR/manila-data --config-file $MANILA_CONF" run_process m-dat "$MANILA_BIN_DIR/manila-data --config-file $MANILA_CONF"
echo "Waiting for Manila to start..."
if ! wait_for_service $SERVICE_TIMEOUT $MANILA_SERVICE_PROTOCOL://$MANILA_SERVICE_HOST:$MANILA_SERVICE_PORT; then
die $LINENO "Manila did not start"
fi
# Start proxies if enabled # Start proxies if enabled
if is_service_enabled tls-proxy; then if is_service_enabled tls-proxy; then
@ -623,9 +654,9 @@ function start_manila {
# stop_manila - Stop running processes # stop_manila - Stop running processes
function stop_manila { function stop_manila {
# Kill the manila screen windows # Kill the manila processes
for serv in m-api m-sch m-shr m-dat; do for serv in m-api m-sch m-shr m-dat; do
screen -S $SCREEN_NAME -p $serv -X kill stop_process $serv
done done
} }