#!/bin/bash # Copyright 2018 AT&T Intellectual Property. All other rights reserved. # # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. # You may obtain a copy of the License at # # http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # See the License for the specific language governing permissions and # limitations under the License. set -e # External subnet is local to the environment and generally can be anything # other then clash with default all-in-one OSH setup that uses 127.24.4.0/24 export OSH_BR_EX_ADDR="172.24.8.1/24" export OSH_EXT_SUBNET="172.24.8.0/24" # Install curl if it's not already installed apt -y install --no-install-recommends curl # Copy run_openstack_cli and openstack_cli_docker_base_command script to dev_single_node directory cp /root/deploy/airship-in-a-bottle/tools/run_openstack_cli.sh /root/deploy/airship-in-a-bottle/manifests/dev_single_node/ cp /root/deploy/airship-in-a-bottle/tools/openstack_cli_docker_base_command.sh /root/deploy/airship-in-a-bottle/manifests/dev_single_node/ # Change to the dev_single_node directory cd /root/deploy/airship-in-a-bottle/manifests/dev_single_node printf "\nCreating KeyPair\n" env -i ./run_openstack_cli.sh keypair create heat-vm-key > id_rsa chmod 600 id_rsa printf "Downloading heat-public-net-deployment.yaml\n" curl -LO https://raw.githubusercontent.com/openstack/openstack-helm/master/tools/gate/files/heat-public-net-deployment.yaml printf "Creating public-net Heat Stack\n" env -i ./run_openstack_cli.sh stack create --wait \ --parameter subnet_cidr=${OSH_EXT_SUBNET} \ --parameter subnet_gateway=${OSH_BR_EX_ADDR%/*} \ -t heat-public-net-deployment.yaml \ public-net printf "Downloading heat-basic-vm-deployment.yaml\n" curl -LO https://raw.githubusercontent.com/openstack/openstack-helm/master/tools/gate/files/heat-basic-vm-deployment.yaml printf "Creating test-stack-01\n" env -i ./run_openstack_cli.sh stack create -t heat-basic-vm-deployment.yaml test-stack-01 --wait printf "Heat Stack List\n" env -i ./run_openstack_cli.sh stack list printf "Nova Server List\n" env -i ./run_openstack_cli.sh server list FLOATING_IP=$(env -i ./run_openstack_cli.sh stack output show \ test-stack-01 \ floating_ip \ -f value -c output_value) printf "Configuring required network settings\n" sudo ip addr add ${OSH_BR_EX_ADDR} dev br-ex sudo ip link set br-ex up sudo iptables -P FORWARD ACCEPT DEFAULT_ROUTE_DEV="$(sudo ip -4 route list 0/0 | awk '{ print $5; exit }')" sudo iptables -t nat -A POSTROUTING -o ${DEFAULT_ROUTE_DEV} -s ${OSH_EXT_SUBNET} -j MASQUERADE function wait_for_ssh_port { # Default wait timeout is 300 seconds set +x end=$(date +%s) if ! [ -z $2 ]; then end=$((end + $2)) else end=$((end + 300)) fi while true; do # Use Nmap as its the same on Ubuntu and RHEL family distros nmap -Pn -p22 $1 | awk '$1 ~ /22/ {print $2}' | grep -q 'open' && \ break || true sleep 1 now=$(date +%s) [ $now -gt $end ] && echo "Could not connect to $1 port 22 in time" && exit -1 done set -x } wait_for_ssh_port $FLOATING_IP install -m 0700 -d ~/.ssh ssh-keyscan "${FLOATING_IP}" >> ~/.ssh/known_hosts printf "The test VM is accessible via SSH: ssh -i id_rsa cirros@${FLOATING_IP}\n"