Add stack phases to extras.d handling

Add hooks to stack.sh, unstack.sh and clean.sh to call the extras.d
scripts at multiple points in stack.sh.  This allows these scripts to
perform installation and startup tasks at similar times as they would
if integrated into stack.sh.

extras.d/70-tempest.sh is present as an example of the structure
of these scripts.

See extras.d/README.md for more information.

Change-Id: Ic1fe522559b94d204d6c0319a2e3d23684c8d028
This commit is contained in:
Dean Troyer 2013-10-15 09:42:43 -05:00
parent 13209d8b6d
commit cdf3d76647
7 changed files with 119 additions and 28 deletions

View File

@ -215,6 +215,10 @@ If tempest has been successfully configured, a basic set of smoke tests can be r
$ cd /opt/stack/tempest $ cd /opt/stack/tempest
$ nosetests tempest/scenario/test_network_basic_ops.py $ nosetests tempest/scenario/test_network_basic_ops.py
# Additional Projects
DevStack has a hook mechanism to call out to a dispatch script at specific points in the execution if `stack.sh`, `unstack.sh` and `clean.sh`. This allows higher-level projects, especially those that the lower level projects have no dependency on, to be added to DevStack without modifying the scripts. Tempest is built this way as an example of how to structure the dispatch script, see `extras.d/80-tempest.sh`. See `extras.d/README.md` for more information.
# Multi-Node Setup # Multi-Node Setup
A more interesting setup involves running multiple compute nodes, with Neutron networks connecting VMs on different compute nodes. A more interesting setup involves running multiple compute nodes, with Neutron networks connecting VMs on different compute nodes.

View File

@ -47,6 +47,15 @@ source $TOP_DIR/lib/neutron
source $TOP_DIR/lib/baremetal source $TOP_DIR/lib/baremetal
source $TOP_DIR/lib/ldap source $TOP_DIR/lib/ldap
# Extras Source
# --------------
# Phase: source
if [[ -d $TOP_DIR/extras.d ]]; then
for i in $TOP_DIR/extras.d/*.sh; do
[[ -r $i ]] && source $i source
done
fi
# See if there is anything running... # See if there is anything running...
# need to adapt when run_service is merged # need to adapt when run_service is merged
@ -56,6 +65,16 @@ if [[ -n "$SESSION" ]]; then
$TOP_DIR/unstack.sh --all $TOP_DIR/unstack.sh --all
fi fi
# Run extras
# ==========
# Phase: clean
if [[ -d $TOP_DIR/extras.d ]]; then
for i in $TOP_DIR/extras.d/*.sh; do
[[ -r $i ]] && source $i clean
done
fi
# Clean projects # Clean projects
cleanup_oslo cleanup_oslo
cleanup_cinder cleanup_cinder

View File

@ -1,21 +1,29 @@
# tempest.sh - DevStack extras script # tempest.sh - DevStack extras script
source $TOP_DIR/lib/tempest if is_service_enabled tempest; then
if [[ "$1" == "source" ]]; then
if [[ "$1" == "stack" ]]; then # Initial source
# Configure Tempest last to ensure that the runtime configuration of source $TOP_DIR/lib/tempest
# the various OpenStack services can be queried. elif [[ "$1" == "stack" && "$2" == "install" ]]; then
if is_service_enabled tempest; then echo_summary "Installing Tempest"
echo_summary "Configuring Tempest"
install_tempest install_tempest
elif [[ "$1" == "stack" && "$2" == "post-config" ]]; then
# Tempest config must come after layer 2 services are running
:
elif [[ "$1" == "stack" && "$2" == "extra" ]]; then
echo_summary "Initializing Tempest"
configure_tempest configure_tempest
init_tempest init_tempest
fi fi
fi
if [[ "$1" == "unstack" ]]; then if [[ "$1" == "unstack" ]]; then
# no-op # no-op
: :
fi
if [[ "$1" == "clean" ]]; then
# no-op
:
fi
fi fi

View File

@ -1,14 +0,0 @@
The extras.d directory contains project initialization scripts to be
sourced by stack.sh at the end of its run. This is expected to be
used by external projects that want to be configured, started and
stopped with DevStack.
Order is controlled by prefixing the script names with the a two digit
sequence number. Script names must end with '.sh'. This provides a
convenient way to disable scripts by simoy renaming them.
DevStack reserves the sequence numbers 00 through 09 and 90 through 99
for its own use.
The scripts are called with an argument of 'stack' by stack.sh and
with an argument of 'unstack' by unstack.sh.

31
extras.d/README.md Normal file
View File

@ -0,0 +1,31 @@
# Extras Hooks
The `extras.d` directory contains project dispatch scripts that are called
at specific times by `stack.sh`, `unstack.sh` and `clean.sh`. These hooks are
used to install, configure and start additional projects during a DevStack run
without any modifications to the base DevStack scripts.
When `stack.sh` reaches one of the hook points it sources the scripts in `extras.d`
that end with `.sh`. To control the order that the scripts are sourced their
names start with a two digit sequence number. DevStack reserves the sequence
numbers 00 through 09 and 90 through 99 for its own use.
The scripts are sourced at each hook point so they should not declare anything
at the top level that would cause a problem, specifically, functions. This does
allow the entire `stack.sh` variable space to be available. The scripts are
sourced with one or more arguments, the first of which defines the hook phase:
arg 1: source | stack | unstack | clean
source: always called first in any of the scripts, used to set the
initial defaults in a lib/* script or similar
stack: called by stack.sh. There are three possible values for
the second arg to distinguish the phase stack.sh is in:
arg 2: install | post-config | extra
unstack: called by unstack.sh
clean: called by clean.sh. Remember, clean.sh also calls unstack.sh
so that work need not be repeated.

View File

@ -313,6 +313,16 @@ source $TOP_DIR/lib/ldap
source $TOP_DIR/lib/ironic source $TOP_DIR/lib/ironic
source $TOP_DIR/lib/trove source $TOP_DIR/lib/trove
# Extras Source
# --------------
# Phase: source
if [[ -d $TOP_DIR/extras.d ]]; then
for i in $TOP_DIR/extras.d/*.sh; do
[[ -r $i ]] && source $i source
done
fi
# Set the destination directories for other OpenStack projects # Set the destination directories for other OpenStack projects
OPENSTACKCLIENT_DIR=$DEST/python-openstackclient OPENSTACKCLIENT_DIR=$DEST/python-openstackclient
@ -725,6 +735,16 @@ if is_service_enabled ir-api ir-cond; then
configure_ironic configure_ironic
fi fi
# Extras Install
# --------------
# Phase: install
if [[ -d $TOP_DIR/extras.d ]]; then
for i in $TOP_DIR/extras.d/*.sh; do
[[ -r $i ]] && source $i stack install
done
fi
if [[ $TRACK_DEPENDS = True ]]; then if [[ $TRACK_DEPENDS = True ]]; then
$DEST/.venv/bin/pip freeze > $DEST/requires-post-pip $DEST/.venv/bin/pip freeze > $DEST/requires-post-pip
if ! diff -Nru $DEST/requires-pre-pip $DEST/requires-post-pip > $DEST/requires.diff; then if ! diff -Nru $DEST/requires-pre-pip $DEST/requires-post-pip > $DEST/requires.diff; then
@ -1000,6 +1020,17 @@ if is_service_enabled nova && is_baremetal; then
fi fi
# Extras Configuration
# ====================
# Phase: post-config
if [[ -d $TOP_DIR/extras.d ]]; then
for i in $TOP_DIR/extras.d/*.sh; do
[[ -r $i ]] && source $i stack post-config
done
fi
# Local Configuration # Local Configuration
# =================== # ===================
@ -1214,9 +1245,10 @@ merge_config_group $TOP_DIR/local.conf extra
# Run extras # Run extras
# ========== # ==========
# Phase: extra
if [[ -d $TOP_DIR/extras.d ]]; then if [[ -d $TOP_DIR/extras.d ]]; then
for i in $TOP_DIR/extras.d/*.sh; do for i in $TOP_DIR/extras.d/*.sh; do
[[ -r $i ]] && source $i stack [[ -r $i ]] && source $i stack extra
done done
fi fi

View File

@ -42,6 +42,16 @@ source $TOP_DIR/lib/neutron
source $TOP_DIR/lib/ironic source $TOP_DIR/lib/ironic
source $TOP_DIR/lib/trove source $TOP_DIR/lib/trove
# Extras Source
# --------------
# Phase: source
if [[ -d $TOP_DIR/extras.d ]]; then
for i in $TOP_DIR/extras.d/*.sh; do
[[ -r $i ]] && source $i source
done
fi
# Determine what system we are running on. This provides ``os_VENDOR``, # Determine what system we are running on. This provides ``os_VENDOR``,
# ``os_RELEASE``, ``os_UPDATE``, ``os_PACKAGE``, ``os_CODENAME`` # ``os_RELEASE``, ``os_UPDATE``, ``os_PACKAGE``, ``os_CODENAME``
GetOSVersion GetOSVersion
@ -53,6 +63,7 @@ fi
# Run extras # Run extras
# ========== # ==========
# Phase: unstack
if [[ -d $TOP_DIR/extras.d ]]; then if [[ -d $TOP_DIR/extras.d ]]; then
for i in $TOP_DIR/extras.d/*.sh; do for i in $TOP_DIR/extras.d/*.sh; do
[[ -r $i ]] && source $i unstack [[ -r $i ]] && source $i unstack