c6481469e6
Co-authored-by: Radosław Piliszek <radoslaw.piliszek@gmail.com> Depends-on: https://review.opendev.org/694476 Change-Id: I6e7f2f4229c8b579dcc17dacffeb74160875ae29
120 lines
3.7 KiB
Bash
Executable File
120 lines
3.7 KiB
Bash
Executable File
#!/bin/bash
|
|
|
|
set -o xtrace
|
|
set -o errexit
|
|
|
|
export PYTHONUNBUFFERED=1
|
|
|
|
function test_zun_logged {
|
|
. /etc/kolla/admin-openrc.sh
|
|
. ~/openstackclient-venv/bin/activate
|
|
|
|
echo "TESTING: Zun"
|
|
openstack appcontainer service list
|
|
openstack appcontainer host list
|
|
openstack subnet set --no-dhcp demo-subnet
|
|
sudo docker pull alpine
|
|
sudo docker save alpine | openstack image create alpine --public --container-format docker --disk-format raw
|
|
openstack appcontainer run --name test alpine sleep 1000
|
|
attempt=1
|
|
while [[ $(openstack appcontainer show test -f value -c status) != "Running" ]]; do
|
|
echo "Container not running yet"
|
|
attempt=$((attempt+1))
|
|
if [[ $attempt -eq 10 ]]; then
|
|
echo "Container failed to start"
|
|
openstack appcontainer show test
|
|
return 1
|
|
fi
|
|
sleep 10
|
|
done
|
|
openstack appcontainer list
|
|
openstack appcontainer show test
|
|
openstack appcontainer delete --force --stop test
|
|
|
|
# NOTE(yoctozepto): We have to wait for the container to be deleted due to
|
|
# check-failure.sh checking stopped containers and failing.
|
|
# It is also nice to test that deleting actually works.
|
|
attempt=1
|
|
while openstack appcontainer show test; do
|
|
echo "Container not deleted yet"
|
|
attempt=$((attempt+1))
|
|
if [[ $attempt -eq 10 ]]; then
|
|
echo "Zun failed to delete the container"
|
|
openstack appcontainer show test
|
|
return 1
|
|
fi
|
|
sleep 10
|
|
done
|
|
|
|
echo "SUCCESS: Zun"
|
|
|
|
echo "TESTING: Zun Cinder volume attachment"
|
|
openstack volume create --size 2 zun_test_volume
|
|
attempt=1
|
|
while [[ $(openstack volume show zun_test_volume -f value -c status) != "available" ]]; do
|
|
echo "Volume not available yet"
|
|
attempt=$((attempt+1))
|
|
if [[ $attempt -eq 10 ]]; then
|
|
echo "Volume failed to become available"
|
|
openstack volume show zun_test_volume
|
|
return 1
|
|
fi
|
|
sleep 10
|
|
done
|
|
openstack appcontainer run --name test2 --mount source=zun_test_volume,destination=/data alpine sleep 1000
|
|
attempt=1
|
|
while [[ $(openstack volume show zun_test_volume -f value -c status) != "in-use" ]]; do
|
|
echo "Volume not attached yet"
|
|
attempt=$((attempt+1))
|
|
if [[ $attempt -eq 10 ]]; then
|
|
echo "Volume failed to attach"
|
|
openstack volume show zun_test_volume
|
|
return 1
|
|
fi
|
|
sleep 10
|
|
done
|
|
attempt=1
|
|
while [[ $(openstack appcontainer show test2 -f value -c status) != "Running" ]]; do
|
|
echo "Container not running yet"
|
|
attempt=$((attempt+1))
|
|
if [[ $attempt -eq 10 ]]; then
|
|
echo "Container failed to start"
|
|
openstack appcontainer show test2
|
|
return 1
|
|
fi
|
|
sleep 10
|
|
done
|
|
openstack appcontainer delete --stop test2
|
|
attempt=1
|
|
while [[ $(openstack volume show zun_test_volume -f value -c status) != "available" ]]; do
|
|
echo "Volume not detached yet"
|
|
attempt=$((attempt+1))
|
|
if [[ $attempt -eq 10 ]]; then
|
|
echo "Volume failed to detach"
|
|
openstack volume show zun_test_volume
|
|
return 1
|
|
fi
|
|
sleep 10
|
|
done
|
|
openstack volume delete zun_test_volume
|
|
echo "SUCCESS: Zun Cinder volume attachment"
|
|
}
|
|
|
|
function test_zun {
|
|
echo "Testing Zun"
|
|
log_file=/tmp/logs/ansible/test-zun
|
|
if [[ -f $log_file ]]; then
|
|
log_file=${log_file}-upgrade
|
|
fi
|
|
test_zun_logged > $log_file 2>&1
|
|
result=$?
|
|
if [[ $result != 0 ]]; then
|
|
echo "Testing Zun failed. See ansible/test-zun for details"
|
|
else
|
|
echo "Successfully tested Zun. See ansible/test-zun for details"
|
|
fi
|
|
return $result
|
|
}
|
|
|
|
test_zun
|