Merge "Clean up trovestack utility (fix kick-start)"

This commit is contained in:
Jenkins 2016-12-12 14:38:19 +00:00 committed by Gerrit Code Review
commit 8adfb7e4f2
3 changed files with 129 additions and 144 deletions

View File

@ -10,9 +10,7 @@ TROVE_LOGDIR=$TROVE_LOGDIR
TROVE_AUTH_CACHE_DIR=$TROVE_AUTH_CACHE_DIR TROVE_AUTH_CACHE_DIR=$TROVE_AUTH_CACHE_DIR
# Enable the Trove plugin for devstack # Enable the Trove plugin for devstack
if [[ $USE_DEVSTACK_TROVE_PLUGIN = true ]]; then enable_plugin trove $TROVE_REPO $TROVE_BRANCH
enable_plugin trove $TROVE_REPO $TROVE_BRANCH
fi
# Enable Trove, Swift, and Heat # Enable Trove, Swift, and Heat
ENABLED_SERVICES+=,trove,tr-api,tr-tmgr,tr-cond ENABLED_SERVICES+=,trove,tr-api,tr-tmgr,tr-cond

View File

@ -9,8 +9,9 @@
# # # #
############################################################################### ###############################################################################
PATH_TROVE=${PATH_TROVE:=$(readlink -f $(dirname $0)/../..)} SCRIPT_DIRNAME=$(dirname "$0")
TROVESTACK_SCRIPTS=${TROVESTACK_SCRIPTS:=$(readlink -f $(dirname $0))} PATH_TROVE=${PATH_TROVE:=$(readlink -f "${SCRIPT_DIRNAME}"/../..)}
TROVESTACK_SCRIPTS=${TROVESTACK_SCRIPTS:=$(readlink -f "${SCRIPT_DIRNAME}")}
TROVESTACK_TESTS=$TROVESTACK_SCRIPTS/../tests/ TROVESTACK_TESTS=$TROVESTACK_SCRIPTS/../tests/
DEFAULT_LOCAL_CONF=local.conf.rc DEFAULT_LOCAL_CONF=local.conf.rc
DEFAULT_LOCALRC=localrc.rc DEFAULT_LOCALRC=localrc.rc
@ -18,6 +19,18 @@ LOCAL_CONF=local.conf
LOCALRC=localrc LOCALRC=localrc
LOCALRC_AUTO=.localrc.auto LOCALRC_AUTO=.localrc.auto
USER_LOCAL_CONF_NAME=.devstack.$LOCAL_CONF USER_LOCAL_CONF_NAME=.devstack.$LOCAL_CONF
CLOUD_ADMIN_ARG="--os-cloud=devstack-admin"
# Make sure we're not affected by the local environment
# by unsetting all the 'OS_' variables
while read -r ENV_VAR; do unset "${ENV_VAR}"; done < <(env|grep "OS_"|awk -F= '{print $1}')
# Now grab the admin credentials from devstack if it's set up.
# This is to facilitate setting the ADMIN_PASSWORD correctly
# for gate runs.
if [ -f $DEST/devstack/accrc/admin/admin ]; then
source $DEST/devstack/accrc/admin/admin
fi
USERHOME=$HOME USERHOME=$HOME
# Load options not checked into VCS. # Load options not checked into VCS.
@ -62,15 +75,6 @@ export RELEASE=${RELEASE:-$DISTRO_RELEASE}
[[ -f $PATH_DEVSTACK_SRC/functions-common ]] && source $PATH_DEVSTACK_SRC/functions-common [[ -f $PATH_DEVSTACK_SRC/functions-common ]] && source $PATH_DEVSTACK_SRC/functions-common
[[ -f $PATH_DEVSTACK_SRC/functions ]] && source $PATH_DEVSTACK_SRC/functions [[ -f $PATH_DEVSTACK_SRC/functions ]] && source $PATH_DEVSTACK_SRC/functions
# Source the old-style localrc, or new-style .local.auto - only one should exist.
# Note: The devstack localrc's have references to 'enable_plugin' which causes
# errors when sourcing them in the stable/juno and stable/kilo branches.
# These errors are safe to ignore when sourcing these files.
set +e
[[ -f $PATH_DEVSTACK_SRC/$LOCALRC ]] && source $PATH_DEVSTACK_SRC/$LOCALRC
[[ -f $PATH_DEVSTACK_SRC/$LOCALRC_AUTO ]] && source $PATH_DEVSTACK_SRC/$LOCALRC_AUTO
set -e
# Set up variables for the CONF files - this has to happen after loading trovestack.rc, since # Set up variables for the CONF files - this has to happen after loading trovestack.rc, since
# TROVE_CONF_DIR is defined there - these will be used by devstack too # TROVE_CONF_DIR is defined there - these will be used by devstack too
export TROVE_CONF=$TROVE_CONF_DIR/trove.conf export TROVE_CONF=$TROVE_CONF_DIR/trove.conf
@ -91,7 +95,6 @@ KEYSTONE_AUTH_PROTOCOL=${KEYSTONE_AUTH_PROTOCOL:-$SERVICE_PROTOCOL}
KEYSTONE_AUTH_PORT=${KEYSTONE_AUTH_PORT:-35357} KEYSTONE_AUTH_PORT=${KEYSTONE_AUTH_PORT:-35357}
GLANCE_HOSTPORT=${GLANCE_HOSTPORT:-$SERVICE_HOST:9292} GLANCE_HOSTPORT=${GLANCE_HOSTPORT:-$SERVICE_HOST:9292}
GLANCE_SERVICE_PROTOCOL=${GLANCE_SERVICE_PROTOCOL:-http} GLANCE_SERVICE_PROTOCOL=${GLANCE_SERVICE_PROTOCOL:-http}
TROVE_AUTH_ENDPOINT=$KEYSTONE_AUTH_PROTOCOL://$KEYSTONE_AUTH_HOST:$KEYSTONE_AUTH_PORT/v2.0
# The following depends on whether neutron is used or nova-network # The following depends on whether neutron is used or nova-network
# neutron uses a bridge, nova-network does not # neutron uses a bridge, nova-network does not
@ -103,6 +106,8 @@ ESCAPED_PATH_TROVE=$(echo $PATH_TROVE | sed 's/\//\\\//g')
ESCAPED_TROVESTACK_SCRIPTS=$(echo $TROVESTACK_SCRIPTS | sed 's/\//\\\//g') ESCAPED_TROVESTACK_SCRIPTS=$(echo $TROVESTACK_SCRIPTS | sed 's/\//\\\//g')
TROVE_AUTH_CACHE_DIR=${TROVE_AUTH_CACHE_DIR:-/var/cache/trove} TROVE_AUTH_CACHE_DIR=${TROVE_AUTH_CACHE_DIR:-/var/cache/trove}
TROVE_LOGDIR=${TROVE_LOGDIR:-$DEST/logs} TROVE_LOGDIR=${TROVE_LOGDIR:-$DEST/logs}
TROVE_DEVSTACK_SETTINGS="$DEST/trove/devstack/settings"
TROVE_DEVSTACK_PLUGIN="$DEST/trove/devstack/plugin.sh"
# DATASTORE_PKG_LOCATION defines the location from where the datastore packages # DATASTORE_PKG_LOCATION defines the location from where the datastore packages
# can be accessed by the DIB elements. This is applicable only for datastores # can be accessed by the DIB elements. This is applicable only for datastores
# that do not have a public repository from where their packages can be accessed. # that do not have a public repository from where their packages can be accessed.
@ -117,11 +122,6 @@ else
TROVE_BIN_DIR=$(get_python_exec_prefix) TROVE_BIN_DIR=$(get_python_exec_prefix)
fi fi
# Allow sourcing config values from env.rc for overrides
if [ -f /tmp/integration/env.rc ]; then
source /tmp/integration/env.rc
fi
# set up respective package managers # set up respective package managers
if is_fedora; then if is_fedora; then
PKG_INSTALL_OPTS="" PKG_INSTALL_OPTS=""
@ -151,27 +151,6 @@ function exclaim () {
echo "*******************************************************************************" echo "*******************************************************************************"
} }
# Set the location of the Trove setup commands file for devstack - either in
# the devstack repo, or the Trove one. Also sets the flag which activates the
# devstack trove plugin, if required. We'll use the devstack version if it
# exists, otherwise we assume the plugin method.
function set_trove_plugin_vars () {
FAIL_IF_MISSING=${1:-true}
TROVE_SETUP_CMD_FILE="$PATH_DEVSTACK_SRC/lib/trove"
if [ -f "$TROVE_SETUP_CMD_FILE" ]; then
USE_DEVSTACK_TROVE_PLUGIN=false
else
TROVE_SETUP_CMD_FILE="$DEST/trove/devstack/plugin.sh"
USE_DEVSTACK_TROVE_PLUGIN=true
fi
# Only complain if we have a devstack directory and are told to
if [ "$FAIL_IF_MISSING" = "true" ] && [ -d "$PATH_DEVSTACK_SRC" ] && [ ! -f "$TROVE_SETUP_CMD_FILE" ]; then
exclaim "${COLOR_RED}Trove setup file '${TROVE_SETUP_CMD_FILE}' not found!${COLOR_NONE}"
exit 1
fi
}
function pkg_install () { function pkg_install () {
echo Installing $@... echo Installing $@...
sudo -E $PKG_INSTALL_OPTS $HTTP_PROXY $PKG_MGR $PKG_GET_ARGS $PKG_INSTALL_ARG $@ sudo -E $PKG_INSTALL_OPTS $HTTP_PROXY $PKG_MGR $PKG_GET_ARGS $PKG_INSTALL_ARG $@
@ -182,11 +161,6 @@ function pkg_update () {
sudo -E $PKG_INSTALL_OPTS $HTTP_PROXY $PKG_MGR $PKG_GET_ARGS $PKG_UPDATE_ARG $@ sudo -E $PKG_INSTALL_OPTS $HTTP_PROXY $PKG_MGR $PKG_GET_ARGS $PKG_UPDATE_ARG $@
} }
function set_home_dir() {
exclaim "set_home_dir has been nooped."
exit 1
}
function set_http_proxy() { function set_http_proxy() {
if [ ! "${http_proxy}" = '' ]; then if [ ! "${http_proxy}" = '' ]; then
HTTP_PROXY="http_proxy=$http_proxy https_proxy=$https_proxy" HTTP_PROXY="http_proxy=$http_proxy https_proxy=$https_proxy"
@ -211,10 +185,10 @@ function add_flavor() {
local FLAVOR_MEMORY_MB=$3 local FLAVOR_MEMORY_MB=$3
local FLAVOR_ROOT_GB=$4 local FLAVOR_ROOT_GB=$4
local FLAVOR_VCPUS=$5 local FLAVOR_VCPUS=$5
local FLAVOR_SKIP_RESIZE=${6:-""}
credentials="--os-username=admin --os-password=$ADMIN_PASSWORD --os-tenant-name=admin --os-auth-url=$TROVE_AUTH_ENDPOINT"
if [[ -z "$FLAVOR_LIST_FOR_ADD" ]]; then if [[ -z "$FLAVOR_LIST_FOR_ADD" ]]; then
FLAVOR_LIST_FOR_ADD=$(nova $credentials flavor-list | cut -d'|' -f3 | sed -e's/ /,/g') FLAVOR_LIST_FOR_ADD=$(openstack $CLOUD_ADMIN_ARG flavor list | cut -d'|' -f3 | sed -e's/ /,/g')
fi fi
base_id=${FLAVOR_ID} base_id=${FLAVOR_ID}
@ -232,30 +206,24 @@ function add_flavor() {
memory=${FLAVOR_MEMORY_MB} memory=${FLAVOR_MEMORY_MB}
vcpus=${FLAVOR_VCPUS} vcpus=${FLAVOR_VCPUS}
if [[ $ephemeral != 0 ]]; then if [[ $ephemeral != 0 ]]; then
if [[ $BRANCH_OVERRIDE == "stable/juno" || $BRANCH_OVERRIDE == "stable/kilo" ]]; then
id=1${id}
else
id=${id}e id=${id}e
fi fi
fi
if [[ $name == ${resize_name} ]]; then if [[ $name == ${resize_name} ]]; then
if [[ $BRANCH_OVERRIDE == "stable/juno" || $BRANCH_OVERRIDE == "stable/kilo" ]]; then
id=2${id}
else
id=${id}r id=${id}r
fi
memory=$((${FLAVOR_MEMORY_MB} + 16)) memory=$((${FLAVOR_MEMORY_MB} + 16))
vcpus=$((${FLAVOR_VCPUS} + 1)) vcpus=$((${FLAVOR_VCPUS} + 1))
fi fi
if [[ $FLAVOR_LIST_FOR_ADD != *",$name,"* ]]; then if [[ $FLAVOR_LIST_FOR_ADD != *",$name,"* ]]; then
nova $credentials flavor-create $name $id $memory $FLAVOR_ROOT_GB $vcpus --ephemeral $ephemeral if [[ -z ${FLAVOR_SKIP_RESIZE} || ${name} == ${reg_name} ]]; then
openstack $CLOUD_ADMIN_ARG flavor create $name --id $id --ram $memory --disk $FLAVOR_ROOT_GB --vcpus $vcpus --ephemeral $ephemeral
fi
fi fi
done done
done done
} }
function get_attribute_id() { function get_attribute_id() {
openstack --os-auth-url=$TROVE_AUTH_ENDPOINT --os-username=admin --os-password=$ADMIN_PASSWORD --os-project-name=admin $1 list | grep " $2" | get_field $3 openstack --os-cloud=devstack-admin $1 list | grep " $2" | get_field $3
} }
@ -422,7 +390,6 @@ function run_devstack() {
USER_OPTS_TAG_END="$MARKER_TOKEN End Of User Specified Options $MARKER_TOKEN" USER_OPTS_TAG_END="$MARKER_TOKEN End Of User Specified Options $MARKER_TOKEN"
ADD_OPTS_TAG="$MARKER_TOKEN Additional Options $MARKER_TOKEN" ADD_OPTS_TAG="$MARKER_TOKEN Additional Options $MARKER_TOKEN"
ADD_OPTS_TAG_END="$MARKER_TOKEN End Of Additional Options $MARKER_TOKEN" ADD_OPTS_TAG_END="$MARKER_TOKEN End Of Additional Options $MARKER_TOKEN"
set_trove_plugin_vars false
pushd "$PATH_DEVSTACK_SRC" pushd "$PATH_DEVSTACK_SRC"
DEVSTACK_LOCAL_CONF=$LOCAL_CONF DEVSTACK_LOCAL_CONF=$LOCAL_CONF
@ -551,8 +518,10 @@ function set_mysql_pkg() {
function cmd_set_datastore() { function cmd_set_datastore() {
IMAGEID=$1 local IMAGEID=$1
DATASTORE_TYPE=$2 local DATASTORE_TYPE=$2
local RESTART_TROVE=${3:-$(get_bool RESTART_TROVE "true")}
# rd_manage datastore_update <datastore_name> <default_version> # rd_manage datastore_update <datastore_name> <default_version>
rd_manage datastore_update "$DATASTORE_TYPE" "" rd_manage datastore_update "$DATASTORE_TYPE" ""
PACKAGES=${PACKAGES:-""} PACKAGES=${PACKAGES:-""}
@ -612,10 +581,14 @@ function cmd_set_datastore() {
rd_manage db_load_datastore_config_parameters "$DATASTORE_TYPE" "$VERSION" "$PATH_TROVE"/trove/templates/$DATASTORE_TYPE/validation-rules.json rd_manage db_load_datastore_config_parameters "$DATASTORE_TYPE" "$VERSION" "$PATH_TROVE"/trove/templates/$DATASTORE_TYPE/validation-rules.json
fi fi
if [[ "${RESTART_TROVE}" == true ]]; then
cmd_stop cmd_stop
fi
iniset $TROVE_CONF DEFAULT default_datastore "$DATASTORE_TYPE" iniset $TROVE_CONF DEFAULT default_datastore "$DATASTORE_TYPE"
sleep 1.5 sleep 1.5
if [[ "${RESTART_TROVE}" == true ]]; then
cmd_start cmd_start
fi
} }
############################################################################### ###############################################################################
@ -727,9 +700,8 @@ function mod_confs() {
# network - write this info to the confs so that the integration tests can # network - write this info to the confs so that the integration tests can
# use it. # use it.
if [[ $ENABLE_NEUTRON = true ]]; then if [[ $ENABLE_NEUTRON = true ]]; then
local credentials="--os-username=admin --os-password=$ADMIN_PASSWORD --os-tenant-name=admin --os-auth-url=$TROVE_AUTH_ENDPOINT --os-region $REGION_NAME" TROVE_NET_ID=$(openstack $CLOUD_ADMIN_ARG network list | grep " $TROVE_PRIVATE_NETWORK_NAME " | awk '{print $2}')
TROVE_NET_ID=$(openstack $credentials network list | grep " $TROVE_PRIVATE_NETWORK_NAME " | awk '{print $2}') TROVE_SUBNET_ID=$(openstack $CLOUD_ADMIN_ARG subnet list | grep " $TROVE_PRIVATE_SUBNET_NAME " | awk '{print $2}')
TROVE_SUBNET_ID=$(openstack $credentials subnet list | grep " $TROVE_PRIVATE_SUBNET_NAME " | awk '{print $2}')
echo "Using network ${TROVE_PRIVATE_NETWORK_NAME} (${TROVE_NET_ID}): ${TROVE_PRIVATE_SUBNET_NAME} (${TROVE_SUBNET_ID})" echo "Using network ${TROVE_PRIVATE_NETWORK_NAME} (${TROVE_NET_ID}): ${TROVE_PRIVATE_SUBNET_NAME} (${TROVE_SUBNET_ID})"
sed -i "s,%shared_network%,$TROVE_NET_ID,g" $TEST_CONF sed -i "s,%shared_network%,$TROVE_NET_ID,g" $TEST_CONF
sed -i "s,%shared_network_subnet%,$TROVE_SUBNET_ID,g" $TEST_CONF sed -i "s,%shared_network_subnet%,$TROVE_SUBNET_ID,g" $TEST_CONF
@ -780,19 +752,26 @@ function add_test_flavors() {
add_flavor 'large' 27 2048 15 1 add_flavor 'large' 27 2048 15 1
# This will allow Nova to create an instance, but not enough disk to boot the image # This will allow Nova to create an instance, but not enough disk to boot the image
add_flavor 'fault_1' 30 512 1 1 add_flavor 'fault_1' 30 512 1 1 'skip_resize'
# This should be enough memory to cause Nova to fail entirely due to too much allocation # This should be enough memory to cause Nova to fail entirely due to too much allocation
add_flavor 'fault_2' 31 131072 5 1 add_flavor 'fault_2' 31 131072 5 1 'skip_resize'
} }
function cmd_test_init() { function cmd_test_init() {
local DATASTORE_TYPE=$1
if [ -z "${DATASTORE_TYPE}" ]; then
exclaim "${COLOR_RED}Datastore argument was not specified.${COLOR_NONE}"
exit 1
fi
exclaim 'Initializing Configuration for Running Tests...' exclaim 'Initializing Configuration for Running Tests...'
exclaim "Installing python test packages." exclaim "Installing python test packages."
install_test_packages $1 install_test_packages "${DATASTORE_TYPE}"
exclaim "Modifying test.conf and guest.conf with appropriate values." exclaim "Modifying test.conf and guest.conf with appropriate values."
mod_confs $1 mod_confs "${DATASTORE_TYPE}"
exclaim "Creating Test Flavors." exclaim "Creating Test Flavors."
add_test_flavors add_test_flavors
@ -807,10 +786,10 @@ function cmd_test_init() {
} }
function cmd_build_image() { function cmd_build_image() {
IMAGE_DATASTORE_TYPE=${1:-'mysql'} local IMAGE_DATASTORE_TYPE=${1:-'mysql'}
ESCAPED_PATH_TROVE=${2:-'\/opt\/stack\/trove'} local ESCAPED_PATH_TROVE=${2:-'\/opt\/stack\/trove'}
HOST_SCP_USERNAME=${3:-'ubuntu'} local HOST_SCP_USERNAME=${3:-'ubuntu'}
GUEST_USERNAME=${4:-'ubuntu'} local GUEST_USERNAME=${4:-'ubuntu'}
exclaim "Ensuring we have all packages needed to build image." exclaim "Ensuring we have all packages needed to build image."
sudo $HTTP_PROXY $PKG_MGR $PKG_GET_ARGS update sudo $HTTP_PROXY $PKG_MGR $PKG_GET_ARGS update
@ -827,6 +806,14 @@ function cmd_build_image() {
} }
function cmd_build_and_upload_image() { function cmd_build_and_upload_image() {
local DATASTORE_TYPE=$1
local RESTART_TROVE=${2:-$(get_bool RESTART_TROVE "true")}
if [ -z "${DATASTORE_TYPE}" ]; then
exclaim "${COLOR_RED}Datastore argument was not specified.${COLOR_NONE}"
exit 1
fi
local IMAGE_URL="" local IMAGE_URL=""
# Use /tmp as file_cache # Use /tmp as file_cache
FILES=/tmp FILES=/tmp
@ -835,23 +822,21 @@ function cmd_build_and_upload_image() {
IMAGE_URL=$IMAGE_DOWNLOAD_URL IMAGE_URL=$IMAGE_DOWNLOAD_URL
else else
exclaim "Trying to build image" exclaim "Trying to build image"
build_guest_image $1 build_guest_image "${DATASTORE_TYPE}"
QCOW_IMAGE=`find $VM_PATH -name '*.qcow2'` QCOW_IMAGE=`find $VM_PATH -name '*.qcow2'`
IMAGE_URL="file://$QCOW_IMAGE" IMAGE_URL="file://$QCOW_IMAGE"
fi fi
local credentials="--os-username=admin --os-password=$ADMIN_PASSWORD --os-tenant-name=admin --os-auth-url=$TROVE_AUTH_ENDPOINT --os-region $REGION_NAME" GLANCE_IMAGEIDS=$(openstack $CLOUD_ADMIN_ARG image list | grep $(basename $IMAGE_URL .qcow2) | get_field 1)
TOKEN=$(openstack $credentials token issue | grep ' id ' | get_field 2)
GLANCE_IMAGEIDS=$(glance $credentials image-list | grep $(basename $IMAGE_URL .qcow2) | get_field 1)
if [[ -n $GLANCE_IMAGEIDS ]]; then if [[ -n $GLANCE_IMAGEIDS ]]; then
glance $credentials image-delete $GLANCE_IMAGEIDS openstack $CLOUD_ADMIN_ARG image delete $GLANCE_IMAGEIDS
fi fi
GLANCE_IMAGEID=`get_glance_id upload_image $IMAGE_URL $TOKEN` GLANCE_IMAGEID=`get_glance_id upload_image $IMAGE_URL`
[[ -z "$GLANCE_IMAGEID" ]] && echo "Glance upload failed!" && exit 1 [[ -z "$GLANCE_IMAGEID" ]] && echo "Glance upload failed!" && exit 1
echo "IMAGE ID: $GLANCE_IMAGEID" echo "IMAGE ID: $GLANCE_IMAGEID"
exclaim "Updating Datastores" exclaim "Updating Datastores"
cmd_set_datastore $GLANCE_IMAGEID $1 cmd_set_datastore "${GLANCE_IMAGEID}" "${DATASTORE_TYPE}" "${RESTART_TROVE}"
} }
@ -929,7 +914,6 @@ function init_fake_mode() {
function cmd_start() { function cmd_start() {
if screen -ls | grep -q stack; then if screen -ls | grep -q stack; then
set_trove_plugin_vars
USE_SCREEN=True USE_SCREEN=True
TOP_DIR=$PATH_DEVSTACK_SRC TOP_DIR=$PATH_DEVSTACK_SRC
LOGDIR=$TROVE_LOGDIR LOGDIR=$TROVE_LOGDIR
@ -937,7 +921,8 @@ function cmd_start() {
if [[ "$RUNNING" =~ " tr-" ]]; then if [[ "$RUNNING" =~ " tr-" ]]; then
exclaim "${COLOR_RED}WARNING: Trove services appear to be running. Please run 'stop' or 'restart'${COLOR_NONE}" exclaim "${COLOR_RED}WARNING: Trove services appear to be running. Please run 'stop' or 'restart'${COLOR_NONE}"
else else
source /dev/stdin < <(sed -n '/^function start_trove\(\)/,/^}/p' "$TROVE_SETUP_CMD_FILE") source "$TROVE_DEVSTACK_SETTINGS"
source /dev/stdin < <(sed -n '/^function start_trove\(\)/,/^}/p' "$TROVE_DEVSTACK_PLUGIN")
start_trove start_trove
fi fi
else else
@ -968,10 +953,10 @@ function cmd_run_fake() {
function cmd_stop() { function cmd_stop() {
if screen -ls | grep -q stack; then if screen -ls | grep -q stack; then
set_trove_plugin_vars
rm -f $DEST/status/stack/tr-* rm -f $DEST/status/stack/tr-*
USE_SCREEN=True USE_SCREEN=True
source /dev/stdin < <(sed -n '/^function stop_trove\(\)/,/^}/p' "$TROVE_SETUP_CMD_FILE") source "$TROVE_DEVSTACK_SETTINGS"
source /dev/stdin < <(sed -n '/^function stop_trove\(\)/,/^}/p' "$TROVE_DEVSTACK_PLUGIN")
MAX_RETRY=5 MAX_RETRY=5
COUNT=1 COUNT=1
while true; do while true; do
@ -1112,21 +1097,23 @@ function cmd_vagrant_ssh() {
function cmd_run_ci() { function cmd_run_ci() {
exclaim "Running CI suite..." local DATASTORE_TYPE=$1
local RESTART_TROVE=${2:-$(get_bool RESTART_TROVE "true")}
if [ -z $1 ]; then if [ -z "${DATASTORE_TYPE}" ]; then
exclaim "Datastore argument was not specified." exclaim "${COLOR_RED}Datastore argument was not specified.${COLOR_NONE}"
exit 1 exit 1
fi fi
exclaim "Running CI suite..."
set +e set +e
cmd_stop_deps cmd_stop_deps
cmd_stop cmd_stop
set -e set -e
cmd_install cmd_install
cmd_test_init $1 cmd_test_init "${DATASTORE_TYPE}"
# The arg will be the image type # The arg will be the image type
cmd_build_and_upload_image $1 cmd_build_and_upload_image "${DATASTORE_TYPE}" "${RESTART_TROVE}"
# Test in fake mode. # Test in fake mode.
exclaim "Testing in fake mode." exclaim "Testing in fake mode."
@ -1196,7 +1183,10 @@ function exec_cmd_on_output() {
} }
function cmd_clean() { function cmd_clean() {
echo "Cleaning up project '${OS_PROJECT_NAME}'" local project_name=${1:-alt_demo}
exclaim "Cleaning up project '${COLOR_BLUE}${project_name}${COLOR_NONE}'"
# reset any stuck backups # reset any stuck backups
mysql_trove "update backups set state='COMPLETED'" mysql_trove "update backups set state='COMPLETED'"
# clear out any DS version metadata # clear out any DS version metadata
@ -1210,7 +1200,11 @@ function cmd_clean() {
# mark all instance modules as deleted # mark all instance modules as deleted
mysql_trove "update instance_modules set deleted=1" mysql_trove "update instance_modules set deleted=1"
source "${PATH_DEVSTACK_SRC}"/openrc admin "${OS_PROJECT_NAME}" if [[ ! -f "${PATH_DEVSTACK_SRC}"/accrc/${project_name}/admin ]]; then
echo "Could not find credentials file for project '${project_name}'"
exit 1
fi
source "${PATH_DEVSTACK_SRC}"/accrc/${project_name}/admin
# delete any trove clusters # delete any trove clusters
exec_cmd_on_output "trove cluster-list" "trove cluster-delete" 20 exec_cmd_on_output "trove cluster-list" "trove cluster-delete" 20
# delete any trove instances # delete any trove instances
@ -1218,48 +1212,46 @@ function cmd_clean() {
# delete any backups # delete any backups
exec_cmd_on_output "trove backup-list" "trove backup-delete" exec_cmd_on_output "trove backup-list" "trove backup-delete"
# clean up any remaining nova instances or cinder volumes # clean up any remaining nova instances or cinder volumes
exec_cmd_on_output "nova list" "nova delete" 5 exec_cmd_on_output "openstack $CLOUD_ADMIN_ARG server list" "openstack $CLOUD_ADMIN_ARG server delete" 5
exec_cmd_on_output "cinder list" "cinder delete" 1 exec_cmd_on_output "openstack $CLOUD_ADMIN_ARG volume list" "openstack $CLOUD_ADMIN_ARG volume delete" 1
# delete any config groups since all instances should be gone now # delete any config groups since all instances should be gone now
exec_cmd_on_output "trove configuration-list" "trove configuration-delete" exec_cmd_on_output "trove configuration-list" "trove configuration-delete"
# delete any modules too # delete any modules too
exec_cmd_on_output "trove module-list" "trove module-delete" exec_cmd_on_output "trove module-list" "trove module-delete"
# make sure that security groups are also gone, except the default # make sure that security groups are also gone, except the default
exec_cmd_on_output "openstack security group list" "openstack security group delete" 0 "default" exec_cmd_on_output "openstack $CLOUD_ADMIN_ARG security group list" "openstack $CLOUD_ADMIN_ARG security group delete" 0 "default"
# delete server groups # delete server groups
exec_cmd_on_output "nova server-group-list" "nova server-group-delete" exec_cmd_on_output "openstack $CLOUD_ADMIN_ARG server group list" "openstack $CLOUD_ADMIN_ARG server group delete"
} }
function cmd_kick_start() { function cmd_kick_start() {
if [ -z $1 ]; then local DATASTORE_TYPE=$1
exclaim "Datastore argument was not specified." local RESTART_TROVE=${2:-$(get_bool RESTART_TROVE "true")}
if [ -z "${DATASTORE_TYPE}" ]; then
exclaim "${COLOR_RED}Datastore argument was not specified.${COLOR_NONE}"
exit 1 exit 1
fi fi
cmd_test_init $1 exclaim "Running kick-start for $DATASTORE_TYPE (restart trove: $RESTART_TROVE)"
cmd_build_and_upload_image $1 cmd_test_init "${DATASTORE_TYPE}"
cmd_build_and_upload_image "${DATASTORE_TYPE}" "${RESTART_TROVE}"
} }
function cmd_dsvm_gate_tests() { function cmd_dsvm_gate_tests() {
exclaim "Running cmd_dsvm_gate_tests ..."
ACTUAL_HOSTNAME=$(hostname -I | sed 's/[0-9]*\.[0-9]*\.[0-9]*\.1\b//g' | sed 's/[0-9a-z][0-9a-z]*:.*:[0-9a-z][0-9a-z]*//g' | sed 's/ /\n/g' | sed '/^$/d' | sort -bu | head -1) ACTUAL_HOSTNAME=$(hostname -I | sed 's/[0-9]*\.[0-9]*\.[0-9]*\.1\b//g' | sed 's/[0-9a-z][0-9a-z]*:.*:[0-9a-z][0-9a-z]*//g' | sed 's/ /\n/g' | sed '/^$/d' | sort -bu | head -1)
DATASTORE_TYPE=${1:-'mysql'}
TEST_GROUP=${2:-${DATASTORE_TYPE}} local DATASTORE_TYPE=${1:-'mysql'}
HOST_SCP_USERNAME=${3:-'jenkins'} local TEST_GROUP=${2:-${DATASTORE_TYPE}}
GUEST_USERNAME=${4:-'ubuntu'} local HOST_SCP_USERNAME=${3:-'jenkins'}
CONTROLLER_IP=${5:-$ACTUAL_HOSTNAME} local GUEST_USERNAME=${4:-'ubuntu'}
ESCAPED_PATH_TROVE=${6:-'\/opt\/stack\/new\/trove'} local CONTROLLER_IP=${5:-$ACTUAL_HOSTNAME}
local ESCAPED_PATH_TROVE=${6:-'\/opt\/stack\/new\/trove'}
exclaim "Running cmd_dsvm_gate_tests ..."
export REPORT_DIRECTORY=${REPORT_DIRECTORY:=$HOME/dsvm-report/} export REPORT_DIRECTORY=${REPORT_DIRECTORY:=$HOME/dsvm-report/}
export TROVE_REPORT_DIR=$HOME/dsvm-report/ export TROVE_REPORT_DIR=$HOME/dsvm-report/
if [[ $BRANCH_OVERRIDE == "stable/liberty" ]]; then
# Devstack in liberty doesn't copy the clouds.yaml file to /etc so we need to
# ensure we have access to the clouds.yaml file set up by devstack-gate
sudo mkdir -p ~/.config/openstack
sudo ln -s $DEST/.config/openstack/clouds.yaml ~/.config/openstack/clouds.yaml
sudo chown -R $(whoami) ~/.config
fi
# Devstack vm-gate runs as the jenkins user, but needs to connect to the guest image as ubuntu # Devstack vm-gate runs as the jenkins user, but needs to connect to the guest image as ubuntu
echo "User=ubuntu" >> /home/jenkins/.ssh/config echo "User=ubuntu" >> /home/jenkins/.ssh/config
@ -1272,25 +1264,15 @@ function cmd_dsvm_gate_tests() {
cd $TROVESTACK_SCRIPTS cd $TROVESTACK_SCRIPTS
sudo -H $HTTP_PROXY pip install --upgrade pip dib-utils sudo -H $HTTP_PROXY pip install --upgrade pip dib-utils
cmd_kick_start $DATASTORE_TYPE local RESTART_TROVE=false
cmd_kick_start "${DATASTORE_TYPE}" "${RESTART_TROVE}"
# Update the local swift endpoint in the catalog to use the CONTROLLER_IP instead of 127.0.0.1 # Update the local swift endpoint in the catalog to use the CONTROLLER_IP instead of 127.0.0.1
source $DEST/devstack/accrc/admin/admin SWIFT_ENDPOINTS=$(openstack $CLOUD_ADMIN_ARG endpoint list --service swift -c ID -f value)
# NOTE(mriedem): We have to treat stable branches before liberty special openstack $CLOUD_ADMIN_ARG endpoint create swift public 'http://'$CONTROLLER_IP':8080/v1/AUTH_$(tenant_id)s' --region RegionOne
# due to constraints with older versions of python-openstackclient. openstack $CLOUD_ADMIN_ARG endpoint create swift internal 'http://'$CONTROLLER_IP':8080/v1/AUTH_$(tenant_id)s' --region RegionOne
if [[ $BRANCH_OVERRIDE == "stable/juno" || $BRANCH_OVERRIDE == "stable/kilo" ]]; then openstack $CLOUD_ADMIN_ARG endpoint create swift admin 'http://'$CONTROLLER_IP':8080' --region RegionOne
SWIFT_ENDPOINT=$(openstack endpoint list | grep 'swift' | get_field 1) echo $SWIFT_ENDPOINTS | xargs -n 1 openstack $CLOUD_ADMIN_ARG endpoint delete
openstack endpoint create swift --region RegionOne --publicurl 'http://'$CONTROLLER_IP':8080/v1/AUTH_$(tenant_id)s' \
--internalurl 'http://'$CONTROLLER_IP':8080/v1/AUTH_$(tenant_id)s' --adminurl 'http://'$CONTROLLER_IP':8080'
openstack endpoint delete $SWIFT_ENDPOINT
else
OS_CLIENT_ARGS="--os-auth-type v3password --os-auth-url $KEYSTONE_AUTH_PROTOCOL://$KEYSTONE_AUTH_HOST:5000/v3 --os-identity-api-version=3"
SWIFT_ENDPOINTS=$(openstack endpoint list $OS_CLIENT_ARGS --service swift -c ID -f value)
openstack endpoint create $OS_CLIENT_ARGS swift public 'http://'$CONTROLLER_IP':8080/v1/AUTH_$(tenant_id)s' --region RegionOne
openstack endpoint create $OS_CLIENT_ARGS swift internal 'http://'$CONTROLLER_IP':8080/v1/AUTH_$(tenant_id)s' --region RegionOne
openstack endpoint create $OS_CLIENT_ARGS swift admin 'http://'$CONTROLLER_IP':8080' --region RegionOne
echo $SWIFT_ENDPOINTS | xargs -n 1 openstack endpoint delete $OS_CLIENT_ARGS
fi
cmd_int_tests --group=$TEST_GROUP cmd_int_tests --group=$TEST_GROUP
} }
@ -1300,8 +1282,9 @@ function cmd_reset_task() {
} }
function cmd_clone_projects() { function cmd_clone_projects() {
UPDATE_PROJECTS=$1 local UPDATE_PROJECTS=$1
PROJECT_LIST_FILES=${@:2} local PROJECT_LIST_FILES=${@:2}
for project in $(cat $PROJECT_LIST_FILES); do for project in $(cat $PROJECT_LIST_FILES); do
if [ ! -d $PATH_DEVSTACK_OUTPUT/$project ]; then if [ ! -d $PATH_DEVSTACK_OUTPUT/$project ]; then
echo "Creating a new clone of $project..." echo "Creating a new clone of $project..."
@ -1361,9 +1344,7 @@ fi
# Set this to exit immediately on error # Set this to exit immediately on error
set -o errexit set -o errexit
# set_home_dir
set_http_proxy set_http_proxy
set_trove_plugin_vars false
function print_usage() { function print_usage() {
echo "Usage: $0 [command]" echo "Usage: $0 [command]"
@ -1383,7 +1364,6 @@ function print_usage() {
--helper for environment-- --helper for environment--
kick-start - kick start the setup of trove. kick-start - kick start the setup of trove.
(trovestack test-init/build-image in one step) (trovestack test-init/build-image in one step)
[mysql no-clean] no clean avoids rebuilding packages from scratch
- Set REBUILD_IMAGE=True to force rebuild (won't use cached image) - Set REBUILD_IMAGE=True to force rebuild (won't use cached image)
--trove dependency services-- --trove dependency services--
@ -1391,13 +1371,19 @@ function print_usage() {
stop-deps - Kill daemons Trove depends on. stop-deps - Kill daemons Trove depends on.
--trove services-- --trove services--
start - Start or resume daemons Trove depends on. start - Start or resume Trove daemons.
stop - Kill daemons Trove depends on. stop - Kill Trove daemons.
restart - Runs stop then start for Trove services. restart - Runs stop then start for Trove services.
--tests-- --tests--
unit-tests - Run the unit tests.dependencies unit-tests - Run the unit tests.dependencies
int-tests - Runs the integration tests (requires all daemons). int-tests - Runs the integration tests (requires all daemons).
See trove/tests/int_tests.py for list of registered groups.
Examples:
Run original MySQL tests: ./trovestack int-tests
Run all MySQL scenario tests: ./trovestack int-tests --group=mysql-supported
Run single Redis scenario tests: ./trovestack int-tests --group=redis-supported-single
Run specific functional tests: ./trovestack int-tests --group=module-create --group=configuration-create
simple-tests - Runs the simple integration tests (requires all daemons). simple-tests - Runs the simple integration tests (requires all daemons).
dsvm-gate-tests - Configures and runs the int-tests in a devstack vm-gate environment. dsvm-gate-tests - Configures and runs the int-tests in a devstack vm-gate environment.
@ -1407,7 +1393,8 @@ function print_usage() {
rd-sql - Opens the Trove MySQL database. rd-sql - Opens the Trove MySQL database.
vagrant-ssh - Runs a command from the host on the server. vagrant-ssh - Runs a command from the host on the server.
clear - Destroy instances and rabbit queues. clear - Destroy instances and rabbit queues.
clean - Clean up resources created by a failed test run. clean - Clean up resources created by a failed test run. Takes
project_name as an optional parameter (defaults to alt_demo).
run - Starts RD but not in a screen. run - Starts RD but not in a screen.
run-fake - Runs the server in fake mode. run-fake - Runs the server in fake mode.
update-projects - Git pull on all the daemons trove dependencies. update-projects - Git pull on all the daemons trove dependencies.
@ -1425,7 +1412,7 @@ function run_command() {
case "$1" in case "$1" in
"install" ) cmd_install;; "install" ) cmd_install;;
"test-init" ) cmd_test_init $@;; "test-init" ) shift; cmd_test_init $@;;
"build-image" ) shift; cmd_build_image $@;; "build-image" ) shift; cmd_build_image $@;;
"initialize" ) cmd_initialize;; "initialize" ) cmd_initialize;;
"unit-tests" ) cmd_unit_tests;; "unit-tests" ) cmd_unit_tests;;

View File

@ -87,7 +87,7 @@ VOLUME_BACKING_FILE_SIZE=${VOLUME_BACKING_FILE_SIZE:-51200M}
MYSQL_PASSWORD=e1a2c042c828d3566d0a MYSQL_PASSWORD=e1a2c042c828d3566d0a
RABBIT_PASSWORD=f7999d1955c5014aa32c RABBIT_PASSWORD=f7999d1955c5014aa32c
SERVICE_TOKEN=be19c524ddc92109a224 SERVICE_TOKEN=be19c524ddc92109a224
ADMIN_PASSWORD=3de4922d8b6ac5a1aad9 ADMIN_PASSWORD=${ADMIN_PASSWORD:-${OS_PASSWORD:-3de4922d8b6ac5a1aad9}}
SERVICE_PASSWORD=7de4162d826bc5a11ad9 SERVICE_PASSWORD=7de4162d826bc5a11ad9
# Swift hash used by devstack. # Swift hash used by devstack.