mirror of
https://github.com/optim-enterprises-bv/openstack-helm.git
synced 2025-12-25 17:27:33 +00:00
This PS enables cinder volume attachment for nova when used with ceph. Change-Id: I9772f38fb3a1a9af26bd92ee18a651d3372de64c
115 lines
4.4 KiB
Bash
Executable File
115 lines
4.4 KiB
Bash
Executable File
#!/bin/bash
|
|
#
|
|
# 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 -xe
|
|
: ${WORK_DIR:="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )/.."}
|
|
source ${WORK_DIR}/tools/gate/vars.sh
|
|
source ${WORK_DIR}/tools/gate/funcs/network.sh
|
|
source ${WORK_DIR}/tools/gate/funcs/openstack.sh
|
|
|
|
# Create default private network
|
|
$NEUTRON net-create ${OSH_PRIVATE_NET_NAME}
|
|
$NEUTRON subnet-create \
|
|
--name ${OSH_PRIVATE_SUBNET_NAME} \
|
|
--ip-version 4 \
|
|
--dns-nameserver ${OSH_EXT_DNS} \
|
|
$($NEUTRON net-show private -f value -c id) \
|
|
${OSH_PRIVATE_SUBNET}
|
|
|
|
# Create default router and link networks
|
|
$NEUTRON router-create ${OSH_ROUTER}
|
|
$NEUTRON router-interface-add \
|
|
$($NEUTRON router-show ${OSH_ROUTER} -f value -c id) \
|
|
$($NEUTRON subnet-show private-subnet -f value -c id)
|
|
$NEUTRON router-gateway-set \
|
|
$($NEUTRON router-show ${OSH_ROUTER} -f value -c id) \
|
|
$($NEUTRON net-show ${OSH_EXT_NET_NAME} -f value -c id)
|
|
|
|
ROUTER_PUBLIC_IP=$($NEUTRON router-show ${OSH_ROUTER} -f value -c external_gateway_info | jq -r '.external_fixed_ips[].ip_address')
|
|
wait_for_ping ${ROUTER_PUBLIC_IP}
|
|
|
|
# Loosen up security group to allow access to the VM
|
|
PROJECT=$($OPENSTACK project show admin -f value -c id)
|
|
SECURITY_GROUP=$($OPENSTACK security group list -f csv | grep ${PROJECT} | grep "default" | awk -F "," '{ print $1 }' | tr -d '"')
|
|
$OPENSTACK security group rule create ${SECURITY_GROUP} \
|
|
--protocol icmp \
|
|
--src-ip 0.0.0.0/0
|
|
$OPENSTACK security group rule create ${SECURITY_GROUP} \
|
|
--protocol tcp \
|
|
--dst-port 22:22 \
|
|
--src-ip 0.0.0.0/0
|
|
|
|
# Setup SSH Keypair in Nova
|
|
KEYPAIR_LOC="$(mktemp).pem"
|
|
$OPENSTACK keypair create ${OSH_VM_KEY_CLI} > ${KEYPAIR_LOC}
|
|
chmod 600 ${KEYPAIR_LOC}
|
|
|
|
# Boot a vm and wait for it to become active
|
|
FLAVOR=$($OPENSTACK flavor show "${OSH_VM_FLAVOR}" -f value -c id)
|
|
IMAGE=$($OPENSTACK image list -f csv | awk -F ',' '{ print $2 "," $1 }' | grep "^\"Cirros" | head -1 | awk -F ',' '{ print $2 }' | tr -d '"')
|
|
NETWORK=$($NEUTRON net-show ${OSH_PRIVATE_NET_NAME} -f value -c id)
|
|
$NOVA boot \
|
|
--nic net-id=${NETWORK} \
|
|
--flavor=${FLAVOR} \
|
|
--image=${IMAGE} \
|
|
--key-name=${OSH_VM_KEY_CLI} \
|
|
--security-groups="default" \
|
|
${OSH_VM_NAME_CLI}
|
|
openstack_wait_for_vm ${OSH_VM_NAME_CLI}
|
|
|
|
# Assign a floating IP to the VM
|
|
FLOATING_IP=$($OPENSTACK floating ip create ${OSH_EXT_NET_NAME} -f value -c floating_ip_address)
|
|
$OPENSTACK server add floating ip ${OSH_VM_NAME_CLI} ${FLOATING_IP}
|
|
|
|
# Ping our VM
|
|
wait_for_ping ${FLOATING_IP} ${SERVICE_TEST_TIMEOUT}
|
|
|
|
# Wait for SSH to come up
|
|
wait_for_ssh_port ${FLOATING_IP} ${SERVICE_TEST_TIMEOUT}
|
|
|
|
# SSH into the VM and check it can reach the outside world
|
|
ssh-keyscan "$FLOATING_IP" >> ~/.ssh/known_hosts
|
|
ssh -i ${KEYPAIR_LOC} cirros@${FLOATING_IP} ping -q -c 1 -W 2 ${OSH_BR_EX_ADDR%/*}
|
|
|
|
# SSH into the VM and check it can reach the metadata server
|
|
ssh -i ${KEYPAIR_LOC} cirros@${FLOATING_IP} curl -sSL 169.254.169.254
|
|
|
|
# Bonus round - display a Unicorn
|
|
ssh -i ${KEYPAIR_LOC} cirros@${FLOATING_IP} curl http://artscene.textfiles.com/asciiart/unicorn || true
|
|
|
|
|
|
if $OPENSTACK service list -f value -c Type | grep -q volume; then
|
|
$OPENSTACK volume create \
|
|
--size ${OSH_VOL_SIZE_CLI} \
|
|
--type ${OSH_VOL_TYPE_CLI} \
|
|
${OSH_VOL_NAME_CLI}
|
|
openstack_wait_for_volume ${OSH_VOL_NAME_CLI} available ${SERVICE_TEST_TIMEOUT}
|
|
|
|
$OPENSTACK server add volume ${OSH_VM_NAME_CLI} ${OSH_VOL_NAME_CLI}
|
|
openstack_wait_for_volume ${OSH_VOL_NAME_CLI} in-use ${SERVICE_TEST_TIMEOUT}
|
|
|
|
VOL_DEV=$($OPENSTACK volume show ${OSH_VOL_NAME_CLI} \
|
|
-f value -c attachments | \
|
|
${WORK_DIR}/tools/gate/funcs/python-data-to-json.py | \
|
|
jq -r '.[] | .device')
|
|
ssh -i ${KEYPAIR_LOC} cirros@${FLOATING_IP} sudo /usr/sbin/mkfs.ext4 ${VOL_DEV}
|
|
|
|
$OPENSTACK server remove volume ${OSH_VM_NAME_CLI} ${OSH_VOL_NAME_CLI}
|
|
openstack_wait_for_volume ${OSH_VOL_NAME_CLI} available ${SERVICE_TEST_TIMEOUT}
|
|
|
|
$OPENSTACK volume delete ${OSH_VOL_NAME_CLI}
|
|
fi
|
|
|
|
# Remove the test vm
|
|
$NOVA delete ${OSH_VM_NAME_CLI}
|