From 55b9dc53ea99454a9674d7be6b5d4f72b94245d4 Mon Sep 17 00:00:00 2001 From: Sergey Kolekonov Date: Tue, 29 Apr 2014 15:17:01 +0400 Subject: [PATCH] Added Devstack integration - added devstack integration files - added a simple api test (for the devstack-gate job) Partial implements blueprint mistral-devstack-gate-job Change-Id: Ibb859c5eda7719d0e046bf833a6eec69bcbeb8be --- contrib/devstack/README.rst | 20 +++ contrib/devstack/extras.d/70-mistral.sh | 23 ++++ contrib/devstack/lib/mistral | 167 ++++++++++++++++++++++++ tools/check_api.sh | 9 ++ 4 files changed, 219 insertions(+) create mode 100644 contrib/devstack/README.rst create mode 100644 contrib/devstack/extras.d/70-mistral.sh create mode 100644 contrib/devstack/lib/mistral create mode 100644 tools/check_api.sh diff --git a/contrib/devstack/README.rst b/contrib/devstack/README.rst new file mode 100644 index 000000000..276429d0b --- /dev/null +++ b/contrib/devstack/README.rst @@ -0,0 +1,20 @@ +1. Follow Devstack documentation to setup a host for Devstack. Then clone + Devstack source code. + +2. Copy Mistral integration scripts to Devstack:: + + $ cp lib/mistral ${DEVSTACK_DIR}/lib + $ cp extras.d/70-mistral.sh ${DEVSTACK_DIR}/extras.d + +3. Create a ``localrc`` file as input to devstack. + +4. The Mistral service is not enabled by default, so it must be + enabled in ``localrc`` before running ``stack.sh``. This example ``localrc`` + file shows all of the settings required for Mistral:: + + # Enable Mistral + enable_service mistral + +5. Deploy your OpenStack Cloud with Mistral:: + + $ ./stack.sh diff --git a/contrib/devstack/extras.d/70-mistral.sh b/contrib/devstack/extras.d/70-mistral.sh new file mode 100644 index 000000000..c3908ce79 --- /dev/null +++ b/contrib/devstack/extras.d/70-mistral.sh @@ -0,0 +1,23 @@ +# 70-mistral.sh - DevStack extras script to install Mistral + +if is_service_enabled mistral; then + if [[ "$1" == "source" ]]; then + # Initial source + source $TOP_DIR/lib/mistral + elif [[ "$1" == "stack" && "$2" == "install" ]]; then + echo_summary "Installing mistral" + install_mistral + elif [[ "$1" == "stack" && "$2" == "post-config" ]]; then + echo_summary "Configuring mistral" + configure_mistral + create_mistral_accounts + elif [[ "$1" == "stack" && "$2" == "extra" ]]; then + echo_summary "Initializing mistral" + init_mistral + start_mistral + fi + + if [[ "$1" == "unstack" ]]; then + stop_mistral + fi +fi diff --git a/contrib/devstack/lib/mistral b/contrib/devstack/lib/mistral new file mode 100644 index 000000000..cf20f1a68 --- /dev/null +++ b/contrib/devstack/lib/mistral @@ -0,0 +1,167 @@ +# lib/mistral + +# Dependencies: +# ``functions`` file +# ``DEST``, ``DATA_DIR``, ``STACK_USER`` must be defined + +# ``stack.sh`` calls the entry points in this order: +# +# install_mistral +# configure_mistral +# start_mistral +# stop_mistral + + +# Save trace setting +XTRACE=$(set +o | grep xtrace) +set -o xtrace + + +# Defaults +# -------- + +# Set up default repos +MISTRAL_REPO=${MISTRAL_REPO:-${GIT_BASE}/stackforge/mistral.git} +MISTRAL_BRANCH=${MISTRAL_BRANCH:-master} + +# Set up default directories +MISTRAL_DIR=$DEST/mistral +MISTRAL_CONF_DIR=${MISTRAL_CONF_DIR:-/etc/mistral} +MISTRAL_CONF_FILE=${MISTRAL_CONF_DIR}/mistral.conf +MISTRAL_DEBUG=${MISTRAL_DEBUG:-True} + +MISTRAL_SERVICE_HOST=${MISTRAL_SERVICE_HOST:-$SERVICE_HOST} +MISTRAL_SERVICE_PORT=${MISTRAL_SERVICE_PORT:-8989} +MISTRAL_SERVICE_PROTOCOL=${MISTRAL_SERVICE_PROTOCOL:-$SERVICE_PROTOCOL} + +MISTRAL_ADMIN_USER=${MISTRAL_ADMIN_USER:-mistral} + +# Support entry points installation of console scripts +if [[ -d $MISTRAL_DIR/bin ]]; then + MISTRAL_BIN_DIR=$MISTRAL_DIR/bin +else + MISTRAL_BIN_DIR=$(get_python_exec_prefix) +fi + +# create_mistral_accounts() - Set up common required mistral accounts +# +# Tenant User Roles +# ------------------------------ +# service mistral admin +function create_mistral_accounts() { + if ! is_service_enabled key; then + return + fi + + SERVICE_TENANT=$(openstack project list | awk "/ $SERVICE_TENANT_NAME / { print \$2 }") + ADMIN_ROLE=$(openstack role list | awk "/ admin / { print \$2 }") + + MISTRAL_USER=$(openstack user create \ + $MISTRAL_ADMIN_USER \ + --password "$SERVICE_PASSWORD" \ + --project $SERVICE_TENANT \ + --email mistral@example.com \ + | grep " id " | get_field 2) + + openstack role add \ + $ADMIN_ROLE \ + --project $SERVICE_TENANT \ + --user $MISTRAL_USER + + if [[ "$KEYSTONE_CATALOG_BACKEND" = 'sql' ]]; then + MISTRAL_SERVICE=$(openstack service create \ + mistral \ + --type=workflow_service \ + --description="Workflow Service" \ + | grep " id " | get_field 2) + openstack endpoint create \ + $MISTRAL_SERVICE \ + --region RegionOne \ + --publicurl "$MISTRAL_SERVICE_PROTOCOL://$MISTRAL_SERVICE_HOST:$MISTRAL_SERVICE_PORT/v1" \ + --adminurl "$MISTRAL_SERVICE_PROTOCOL://$MISTRAL_SERVICE_HOST:$MISTRAL_SERVICE_PORT/v1" \ + --internalurl "$MISTRAL_SERVICE_PROTOCOL://$MISTRAL_SERVICE_HOST:$MISTRAL_SERVICE_PORT/v1" + fi +} + + +function mkdir_chown_stack { + if [[ ! -d "$1" ]]; then + sudo mkdir -p "$1" + fi + sudo chown $STACK_USER "$1" +} + +# Entry points +# ------------ + +# configure_mistral() - Set config files, create data dirs, etc +function configure_mistral { + mkdir_chown_stack "$MISTRAL_CONF_DIR" + + # Copy over Mistral configuration file and configure common parameters. + cp $MISTRAL_DIR/etc/mistral.conf.example $MISTRAL_CONF_FILE + iniset $MISTRAL_CONF_FILE DEFAULT debug $MISTRAL_DEBUG + + # Run all Mistral processes as a single process + iniset $MISTRAL_CONF_FILE DEFAULT server all + + # Mistral Configuration + #------------------------- + + # Setup keystone_authtoken section + iniset $MISTRAL_CONF_FILE keystone auth_host $KEYSTONE_AUTH_HOST + iniset $MISTRAL_CONF_FILE keystone auth_port $KEYSTONE_AUTH_PORT + iniset $MISTRAL_CONF_FILE keystone auth_protocol $KEYSTONE_AUTH_PROTOCOL + iniset $MISTRAL_CONF_FILE keystone admin_tenant_name $SERVICE_TENANT_NAME + iniset $MISTRAL_CONF_FILE keystone admin_user $MISTRAL_ADMIN_USER + iniset $MISTRAL_CONF_FILE keystone admin_password $SERVICE_PASSWORD + + # Setup RabbitMQ credentials + iniset $MISTRAL_CONF_FILE DEFAULT rabbit_password $RABBIT_PASSWORD + + # Configure the database. + iniset $MISTRAL_CONF_FILE database connection `database_connection_url mistral` + + # Configure keystone auth url + iniset $MISTRAL_CONF_FILE keystone auth_uri "http://${KEYSTONE_AUTH_HOST}:5000/v3" +} + + +# init_mistral() - Initialize the database +function init_mistral() { + # (re)create Mistral database + recreate_database mistral utf8 +} + + +# install_mistral() - Collect source and prepare +function install_mistral() { + git_clone $MISTRAL_REPO $MISTRAL_DIR $MISTRAL_BRANCH + + # setup_package function is used because Mistral requirements + # don't match with global-requirement.txt + # both functions (setup_develop and setup_package) are defined at: + # http://git.openstack.org/cgit/openstack-dev/devstack/tree/functions-common + setup_package $MISTRAL_DIR -e +} + + +# start_mistral() - Start running processes, including screen +function start_mistral() { + screen_it mistral "cd $MISTRAL_DIR && $MISTRAL_BIN_DIR/mistral-server --config-file $MISTRAL_CONF_DIR/mistral.conf" +} + + +# stop_mistral() - Stop running processes +function stop_mistral() { + # Kill the Mistral screen windows + screen -S $SCREEN_NAME -p mistral -X kill +} + + +# Restore xtrace +$XTRACE + +# Local variables: +# mode: shell-script +# End: diff --git a/tools/check_api.sh b/tools/check_api.sh new file mode 100644 index 000000000..7b4c84188 --- /dev/null +++ b/tools/check_api.sh @@ -0,0 +1,9 @@ +#!/bin/bash + +# How many seconds to wait for the API to be responding before giving up +API_RESPONDING_TIMEOUT=20 + +if ! timeout ${API_RESPONDING_TIMEOUT} sh -c "while ! curl -s http://127.0.0.1:8989/v1/ 2>/dev/null | grep -q 'Authentication required' ; do sleep 1; done"; then + echo "Mistral API failed to respond within ${API_RESPONDING_TIMEOUT} seconds" + exit 1 +fi