122 lines
3.3 KiB
Bash
Executable File
122 lines
3.3 KiB
Bash
Executable File
#!/bin/bash
|
|
# Copyright (c) 2014 OpenStack Foundation
|
|
#
|
|
# 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.
|
|
|
|
cd $(readlink -f $(dirname $0))
|
|
|
|
. ./swift3.config
|
|
|
|
CONF_DIR=$(readlink -f ./conf)
|
|
|
|
rm -rf $TEST_DIR
|
|
mkdir -p ${TEST_DIR}/etc ${TEST_DIR}/log
|
|
mkdir -p ${TEST_DIR}/sda ${TEST_DIR}/sdb ${TEST_DIR}/sdc
|
|
mkdir -p ${TEST_DIR}/certs ${TEST_DIR}/private
|
|
|
|
# create config files
|
|
if [ "$AUTH" == 'keystone' ]; then
|
|
MIDDLEWARE="s3token authtoken keystoneauth"
|
|
elif [ "$AUTH" == 'tempauth' ]; then
|
|
MIDDLEWARE="tempauth"
|
|
else
|
|
echo "unknown auth: $AUTH"
|
|
exit 1
|
|
fi
|
|
|
|
for server in keystone swift proxy-server object-server container-server account-server; do
|
|
sed -e "s#%MIDDLEWARE%#${MIDDLEWARE}#g" \
|
|
-e "s#%S3ACL%#${S3ACL}#g" \
|
|
-e "s#%USER%#`whoami`#g" \
|
|
-e "s#%TEST_DIR%#${TEST_DIR}#g" \
|
|
-e "s#%CONF_DIR%#${CONF_DIR}#g" \
|
|
conf/${server}.conf.in \
|
|
> conf/${server}.conf
|
|
done
|
|
|
|
# setup keystone
|
|
if [ "$AUTH" == 'keystone' ]; then
|
|
. ./setup_keystone
|
|
fi
|
|
|
|
|
|
# build ring
|
|
cd ${TEST_DIR}/etc/
|
|
|
|
swift-ring-builder object.builder create 0 3 0
|
|
swift-ring-builder container.builder create 0 3 0
|
|
swift-ring-builder account.builder create 0 3 0
|
|
|
|
swift-ring-builder object.builder add r1z0-127.0.0.1:6000/sda 1
|
|
swift-ring-builder object.builder add r1z1-127.0.0.1:6000/sdb 1
|
|
swift-ring-builder object.builder add r1z2-127.0.0.1:6000/sdc 1
|
|
swift-ring-builder container.builder add r1z0-127.0.0.1:6001/sda 1
|
|
swift-ring-builder container.builder add r1z1-127.0.0.1:6001/sdb 1
|
|
swift-ring-builder container.builder add r1z2-127.0.0.1:6001/sdc 1
|
|
swift-ring-builder account.builder add r1z0-127.0.0.1:6002/sda 1
|
|
swift-ring-builder account.builder add r1z1-127.0.0.1:6002/sdb 1
|
|
swift-ring-builder account.builder add r1z2-127.0.0.1:6002/sdc 1
|
|
|
|
swift-ring-builder object.builder rebalance
|
|
swift-ring-builder container.builder rebalance
|
|
swift-ring-builder account.builder rebalance
|
|
|
|
cd -
|
|
|
|
# start swift servers
|
|
|
|
_start()
|
|
{
|
|
local name=$1; shift
|
|
|
|
echo Start ${name}-server.
|
|
"$@" > ${TEST_DIR}/log/${name}.log 2>&1 &
|
|
export ${name}_pid=$!
|
|
|
|
local cnt
|
|
for cnt in `seq 60`; do # wait at most 60 seconds
|
|
grep 'Started child' ${TEST_DIR}/log/${name}.log > /dev/null
|
|
if [ $? == 0 ]; then
|
|
return
|
|
fi
|
|
sleep 1
|
|
done
|
|
|
|
cat ${TEST_DIR}/log/${name}.log
|
|
echo "Cannot start ${name}-server."
|
|
exit 1
|
|
}
|
|
|
|
_start account ./run_daemon.py account 6002 conf/account-server.conf -v
|
|
_start container ./run_daemon.py container 6001 conf/container-server.conf -v
|
|
_start object ./run_daemon.py object 6000 conf/object-server.conf -v
|
|
|
|
coverage erase
|
|
_start proxy coverage run --branch --include=../../* --omit=./* \
|
|
./run_daemon.py proxy 8080 conf/proxy-server.conf -v
|
|
|
|
# run tests
|
|
nosetests -v ./
|
|
rvalue=$?
|
|
|
|
# cleanup
|
|
kill -HUP $proxy_pid $account_pid $container_pid $object_pid $keystone_pid
|
|
|
|
# show report
|
|
sleep 3
|
|
coverage report
|
|
coverage html
|
|
|
|
exit $rvalue
|