Replace Swift Docker test with Ceph image

This commit is contained in:
Robin McCorkell 2015-09-09 22:06:41 +01:00 committed by Thomas Müller
parent 2577a624c0
commit 0de9819da3
2 changed files with 38 additions and 22 deletions

View File

@ -9,8 +9,8 @@
# Set environment variable DEBUG to print config file # Set environment variable DEBUG to print config file
# #
# @author Morris Jobke # @author Morris Jobke
# @copyright 2015 Morris Jobke <hey@morrisjobke.de> # @author Robin McCorkell
# # @copyright 2015 ownCloud
if ! command -v docker >/dev/null 2>&1; then if ! command -v docker >/dev/null 2>&1; then
echo "No docker executable found - skipped docker setup" echo "No docker executable found - skipped docker setup"
@ -19,48 +19,64 @@ fi
echo "Docker executable found - setup docker" echo "Docker executable found - setup docker"
echo "Fetch recent morrisjobke/docker-swift-onlyone docker image" docker_image=xenopathic/ceph-keystone
docker pull morrisjobke/docker-swift-onlyone
echo "Fetch recent ${docker_image} docker image"
docker pull ${docker_image}
# retrieve current folder to place the config in the parent folder # retrieve current folder to place the config in the parent folder
thisFolder=`echo $0 | replace "env/start-swift-morrisjobke.sh" ""` thisFolder=`echo $0 | replace "env/start-swift-ceph.sh" ""`
if [ -z "$thisFolder" ]; then if [ -z "$thisFolder" ]; then
thisFolder="." thisFolder="."
fi; fi;
container=`docker run -d -e SWIFT_SET_PASSWORDS=true morrisjobke/docker-swift-onlyone` port=5001
user=test
pass=testing
tenant=testenant
region=testregion
service=testceph
container=`docker run -d \
-e KEYSTONE_PUBLIC_PORT=${port} \
-e KEYSTONE_ADMIN_USER=${user} \
-e KEYSTONE_ADMIN_PASS=${pass} \
-e KEYSTONE_ADMIN_TENANT=${tenant} \
-e KEYSTONE_ENDPOINT_REGION=${region} \
-e KEYSTONE_SERVICE=${service} \
${docker_image}`
host=`docker inspect $container | grep IPAddress | cut -d '"' -f 4` host=`docker inspect $container | grep IPAddress | cut -d '"' -f 4`
echo "swift container: $container" echo "${docker_image} container: $container"
# put container IDs into a file to drop them after the test run (keep in mind that multiple tests run in parallel on the same host) # put container IDs into a file to drop them after the test run (keep in mind that multiple tests run in parallel on the same host)
echo $container >> $thisFolder/dockerContainerMorrisJobke.$EXECUTOR_NUMBER.swift echo $container >> $thisFolder/dockerContainerCeph.$EXECUTOR_NUMBER.swift
# TODO find a way to determine the successful initialization inside the docker container # TODO find a way to determine the successful initialization inside the docker container
echo "Waiting 15 seconds for swift initialization ... " echo "Waiting 20 seconds for ceph initialization ... "
sleep 15 sleep 20
user=test:tester
password=`docker logs $container | grep "user_test_tester " | cut -d " " -f3`
cat > $thisFolder/config.swift.php <<DELIM cat > $thisFolder/config.swift.php <<DELIM
<?php <?php
return array( return array(
'run'=>true, 'run'=>true,
'url'=>'http://$host:8080/auth/v1.0', 'url'=>'http://$host:$port/v2.0',
'user'=>'$user', 'user'=>'$user',
'key'=>'$password', 'tenant'=>'$tenant',
'password'=>'$pass',
'service_name'=>'$service',
'bucket'=>'swift', 'bucket'=>'swift',
'region' => 'DFW', 'region' => '$region',
); );
DELIM DELIM
if [ -n "$DEBUG" ]; then if [ -n "$DEBUG" ]; then
cat $thisFolder/config.swift.php cat $thisFolder/config.swift.php
cat $thisFolder/dockerContainerMorrisJobke.$EXECUTOR_NUMBER.swift cat $thisFolder/dockerContainerCeph.$EXECUTOR_NUMBER.swift
fi fi

View File

@ -6,8 +6,8 @@
# against. It will also revert the config changes done in start step. # against. It will also revert the config changes done in start step.
# #
# @author Morris Jobke # @author Morris Jobke
# @copyright 2015 Morris Jobke <hey@morrisjobke.de> # @author Robin McCorkell
# # @copyright 2015 ownCloud
if ! command -v docker >/dev/null 2>&1; then if ! command -v docker >/dev/null 2>&1; then
echo "No docker executable found - skipped docker stop" echo "No docker executable found - skipped docker stop"
@ -17,14 +17,14 @@ fi
echo "Docker executable found - stop and remove docker containers" echo "Docker executable found - stop and remove docker containers"
# retrieve current folder to remove the config from the parent folder # retrieve current folder to remove the config from the parent folder
thisFolder=`echo $0 | replace "env/stop-swift-morrisjobke.sh" ""` thisFolder=`echo $0 | replace "env/stop-swift-ceph.sh" ""`
if [ -z "$thisFolder" ]; then if [ -z "$thisFolder" ]; then
thisFolder="." thisFolder="."
fi; fi;
# stopping and removing docker containers # stopping and removing docker containers
for container in `cat $thisFolder/dockerContainerMorrisJobke.$EXECUTOR_NUMBER.swift`; do for container in `cat $thisFolder/dockerContainerCeph.$EXECUTOR_NUMBER.swift`; do
echo "Stopping and removing docker container $container" echo "Stopping and removing docker container $container"
# kills running container and removes it # kills running container and removes it
docker rm -f $container docker rm -f $container
@ -32,5 +32,5 @@ done;
# cleanup # cleanup
rm $thisFolder/config.swift.php rm $thisFolder/config.swift.php
rm $thisFolder/dockerContainerMorrisJobke.$EXECUTOR_NUMBER.swift rm $thisFolder/dockerContainerCeph.$EXECUTOR_NUMBER.swift