diff options
author | MatthewLi <matthew.lijun@huawei.com> | 2016-04-25 05:48:18 -0400 |
---|---|---|
committer | MatthewLi <matthew.lijun@huawei.com> | 2016-04-25 06:03:36 -0400 |
commit | 514ad1b0b8fea733bdf9dacfe8d9006aa882fd10 (patch) | |
tree | 3f5719a38a6e703b02e3d41f9e1be55c4d569c8f /ci/prepare_env.sh | |
parent | d5e21b553c692948ec3710a5f1c1bc7dbabb6a62 (diff) |
obtain openstack creds in container
JIRA: BOTTLENECK-69
Change-Id: I428e6bfaa0088cc01bd074fccc637dcd2a75be5c
Signed-off-by: MatthewLi <matthew.lijun@huawei.com>
Diffstat (limited to 'ci/prepare_env.sh')
-rwxr-xr-x | ci/prepare_env.sh | 58 |
1 files changed, 58 insertions, 0 deletions
diff --git a/ci/prepare_env.sh b/ci/prepare_env.sh new file mode 100755 index 00000000..a5aef66d --- /dev/null +++ b/ci/prepare_env.sh @@ -0,0 +1,58 @@ +#!/bin/bash +############################################################################### +# Copyright (c) 2016 Huawei Technologies Co.,Ltd and others. +# +# All rights reserved. This program and the accompanying materials +# are made available under the terms of the Apache License, Version 2.0 +# which accompanies this distribution, and is available at +# http://www.apache.org/licenses/LICENSE-2.0 +############################################################################## +BASEDIR=`dirname $0` +source ${BASEDIR}/../common.sh + +info "============ Preparing bottlenecks environment ===========" + +# definition of available installer names +INSTALLERS=(fuel compass apex joid) + +if [ ! -f ${BOTTLENECKS_REPO_DIR}/config/openstack.creds ]; then + # If credentials file is not given, check if environment variables are set + # to get the creds using fetch_os_creds.sh later on + info "Checking environment variables INSTALLER_TYPE and INSTALLER_IP" + if [ -z ${INSTALLER_TYPE} ]; then + error "Environment variable 'INSTALLER_TYPE' is not defined." + elif [[ ${INSTALLERS[@]} =~ ${INSTALLER_TYPE} ]]; then + info "INSTALLER_TYPE env variable found: ${INSTALLER_TYPE}" + else + error "Invalid environment variable INSTALLER_TYPE=${INSTALLER_TYPE}" + fi + + if [ -z ${INSTALLER_IP} ]; then + error "Environment variable 'INSTALLER_IP' is not defined." + fi + info "INSTALLER_IP env variable found: ${INSTALLER_IP}" +fi + +# Create Openstack credentials file +# $creds is an env varialbe in the docker container pointing to +# /home/opnfv/bottlenecks/config/openstack.creds +if [ ! -f ${creds} ]; then + ${REPOS_DIR}/releng/utils/fetch_os_creds.sh -d ${creds} \ + -i ${INSTALLER_TYPE} -a ${INSTALLER_IP} + retval=$? + if [ $retval != 0 ]; then + error "Cannot retrieve credentials file from installation. Check logs." + exit $retval + fi +else + info "OpenStack credentials file given to the docker" +fi + +# If we use SSL, by default use option OS_INSECURE=true which means that +# the cacert will be self-signed +if grep -Fq "OS_CACERT" ${creds}; then + echo "OS_INSECURE=true">>${creds}; +fi + +# Source credentials +source ${creds} |