129 lines
3.1 KiB
Bash
Executable file
129 lines
3.1 KiB
Bash
Executable file
#!/usr/bin/env bash
|
|
#
|
|
# build_ci_config.sh - Build a config.ini for openstack-integration-tests
|
|
# (https://github.com/openstack/openstack-integration-tests)
|
|
|
|
function usage {
|
|
echo "$0 - Build config.ini for openstack-integration-tests"
|
|
echo ""
|
|
echo "Usage: $0 configfile"
|
|
exit 1
|
|
}
|
|
|
|
if [ ! "$#" -eq "1" ]; then
|
|
usage
|
|
fi
|
|
|
|
CONFIG_FILE=$1
|
|
|
|
# Clean up any resources that may be in use
|
|
cleanup() {
|
|
set +o errexit
|
|
|
|
# Mop up temporary files
|
|
if [ -n "$CONFIG_FILE_TMP" -a -e "$CONFIG_FILE_TMP" ]; then
|
|
rm -f $CONFIG_FILE_TMP
|
|
fi
|
|
|
|
# Kill ourselves to signal any calling process
|
|
trap 2; kill -2 $$
|
|
}
|
|
|
|
trap cleanup SIGHUP SIGINT SIGTERM
|
|
|
|
# Keep track of the current directory
|
|
TOOLS_DIR=$(cd $(dirname "$0") && pwd)
|
|
TOP_DIR=`cd $TOOLS_DIR/..; pwd`
|
|
|
|
# Abort if localrc is not set
|
|
if [ ! -e $TOP_DIR/localrc ]; then
|
|
echo "You must have a localrc with ALL necessary passwords and configuration defined before proceeding."
|
|
echo "See stack.sh for required passwords."
|
|
exit 1
|
|
fi
|
|
|
|
# Source params
|
|
source ./stackrc
|
|
|
|
# Where Openstack code lives
|
|
DEST=${DEST:-/opt/stack}
|
|
|
|
DIST_NAME=${DIST_NAME:-natty}
|
|
|
|
# Process network configuration vars
|
|
GUEST_NETWORK=${GUEST_NETWORK:-1}
|
|
GUEST_RECREATE_NET=${GUEST_RECREATE_NET:-yes}
|
|
|
|
GUEST_IP=${GUEST_IP:-192.168.$GUEST_NETWORK.50}
|
|
GUEST_CIDR=${GUEST_CIDR:-$GUEST_IP/24}
|
|
GUEST_NETMASK=${GUEST_NETMASK:-255.255.255.0}
|
|
GUEST_GATEWAY=${GUEST_GATEWAY:-192.168.$GUEST_NETWORK.1}
|
|
GUEST_MAC=${GUEST_MAC:-"02:16:3e:07:69:`printf '%02X' $GUEST_NETWORK`"}
|
|
GUEST_RAM=${GUEST_RAM:-1524288}
|
|
GUEST_CORES=${GUEST_CORES:-1}
|
|
|
|
# Use the GUEST_IP unless an explicit IP is set by ``HOST_IP``
|
|
HOST_IP=${HOST_IP:-$GUEST_IP}
|
|
# Use the first IP if HOST_IP still is not set
|
|
if [ ! -n "$HOST_IP" ]; then
|
|
HOST_IP=`LC_ALL=C /sbin/ifconfig | grep -m 1 'inet addr:'| cut -d: -f2 | awk '{print $1}'`
|
|
fi
|
|
|
|
RABBIT_HOST=${RABBIT_HOST:-localhost}
|
|
|
|
# Glance connection info. Note the port must be specified.
|
|
GLANCE_HOSTPORT=${GLANCE_HOSTPORT:-$HOST_IP:9292}
|
|
set `echo $GLANCE_HOSTPORT | tr ':' ' '`
|
|
GLANCE_HOST=$1
|
|
GLANCE_PORT=$2
|
|
|
|
CONFIG_FILE_TMP=$(mktemp $CONFIG_FILE.XXXXXX)
|
|
cat >$CONFIG_FILE_TMP <<EOF
|
|
[environment]
|
|
aki_location = $DEST/openstack-integration-tests/include/sample_vm/$DIST_NAME-server-cloudimg-amd64-vmlinuz-virtual
|
|
#ari_location = $DEST/openstack-integration-tests/include/sample_vm/$DIST_NAME-server-cloudimg-amd64-loader
|
|
ami_location = $DEST/openstack-integration-tests/include/sample_vm/$DIST_NAME-server-cloudimg-amd64.img
|
|
|
|
[glance]
|
|
host = $GLANCE_HOST
|
|
apiver = v1
|
|
port = $GLANCE_PORT
|
|
image_id = 1
|
|
tenant_id = 1
|
|
|
|
[keystone]
|
|
service_host = $HOST_IP
|
|
service_port = 5000
|
|
apiver = v2.0
|
|
user = admin
|
|
password = $ADMIN_PASSWORD
|
|
tenant_id = 1
|
|
|
|
[nova]
|
|
host = $HOST_IP
|
|
port = 8774
|
|
apiver = v1.1
|
|
project = admin
|
|
user = admin
|
|
key = $ADMIN_PASSWORD
|
|
ssh_timeout = 300
|
|
build_timeout = 300
|
|
flavor_ref = 1
|
|
flavor_ref_alt = 2
|
|
|
|
[rabbitmq]
|
|
host = $RABBIT_HOST
|
|
user = guest
|
|
password = $RABBIT_PASSWORD
|
|
|
|
[swift]
|
|
auth_host = $HOST_IP
|
|
auth_port = 443
|
|
auth_prefix = /auth/
|
|
auth_ssl = yes
|
|
account = system
|
|
username = root
|
|
password = password
|
|
|
|
EOF
|
|
mv $CONFIG_FILE_TMP $CONFIG_FILE
|