Keystone Functional Tests
Functional tests using OpenStack Keystone Authentication. Tests require the following: 1. Keystone server is running locally 2. Keystone server has been setup according to the test.conf 3. /mnt/gluster-object has the directories setup Change-Id: I460471e549da91366cb817916ed5293c7e7adda4 Signed-off-by: Luis Pabon <lpabon@redhat.com> Reviewed-on: http://review.gluster.org/6218 Reviewed-by: Peter Portante <pportant@redhat.com> Tested-by: Peter Portante <pportant@redhat.com>
This commit is contained in:
parent
0c34fa6085
commit
2bd930bb44
@ -1,4 +1,3 @@
|
|||||||
# Copyright (c) 2010-2012 OpenStack Foundation
|
|
||||||
#
|
#
|
||||||
# Licensed under the Apache License, Version 2.0 (the "License");
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
# you may not use this file except in compliance with the License.
|
# you may not use this file except in compliance with the License.
|
||||||
@ -155,13 +154,13 @@ class Connection(object):
|
|||||||
self.storage_host = x[2].split(':')[0]
|
self.storage_host = x[2].split(':')[0]
|
||||||
if ':' in x[2]:
|
if ':' in x[2]:
|
||||||
self.storage_port = int(x[2].split(':')[1])
|
self.storage_port = int(x[2].split(':')[1])
|
||||||
# Make sure storage_url is a string and not unicode, since
|
# Make sure storage_url and the storage_token are
|
||||||
|
# strings and not unicode, since
|
||||||
# keystoneclient (called by swiftclient) returns them in
|
# keystoneclient (called by swiftclient) returns them in
|
||||||
# unicode and this would cause troubles when doing
|
# unicode and this would cause troubles when doing
|
||||||
# no_safe_quote query.
|
# no_safe_quote query.
|
||||||
self.storage_url = str('/%s/%s' % (x[3], x[4]))
|
self.storage_url = str('/%s/%s' % (x[3], x[4]))
|
||||||
|
self.storage_token = str(storage_token)
|
||||||
self.storage_token = storage_token
|
|
||||||
|
|
||||||
self.http_connect()
|
self.http_connect()
|
||||||
return self.storage_url, self.storage_token
|
return self.storage_url, self.storage_token
|
||||||
|
32
test/functional_auth/keystone/conf/account-server.conf
Normal file
32
test/functional_auth/keystone/conf/account-server.conf
Normal file
@ -0,0 +1,32 @@
|
|||||||
|
[DEFAULT]
|
||||||
|
devices = /mnt/gluster-object
|
||||||
|
#
|
||||||
|
# Once you are confident that your startup processes will always have your
|
||||||
|
# gluster volumes properly mounted *before* the account-server workers start,
|
||||||
|
# you can *consider* setting this value to "false" to reduce the per-request
|
||||||
|
# overhead it can incur.
|
||||||
|
#
|
||||||
|
# *** Keep false for Functional Tests ***
|
||||||
|
mount_check = false
|
||||||
|
bind_port = 6012
|
||||||
|
#
|
||||||
|
# Override swift's default behaviour for fallocate.
|
||||||
|
disable_fallocate = true
|
||||||
|
#
|
||||||
|
# One or two workers should be sufficient for almost any installation of
|
||||||
|
# Gluster.
|
||||||
|
workers = 1
|
||||||
|
|
||||||
|
[pipeline:main]
|
||||||
|
pipeline = account-server
|
||||||
|
|
||||||
|
[app:account-server]
|
||||||
|
use = egg:gluster_swift#account
|
||||||
|
user = root
|
||||||
|
log_facility = LOG_LOCAL2
|
||||||
|
log_level = WARN
|
||||||
|
#
|
||||||
|
# After ensuring things are running in a stable manner, you can turn off
|
||||||
|
# normal request logging for the account server to unclutter the log
|
||||||
|
# files. Warnings and errors will still be logged.
|
||||||
|
log_requests = off
|
35
test/functional_auth/keystone/conf/container-server.conf
Normal file
35
test/functional_auth/keystone/conf/container-server.conf
Normal file
@ -0,0 +1,35 @@
|
|||||||
|
[DEFAULT]
|
||||||
|
devices = /mnt/gluster-object
|
||||||
|
#
|
||||||
|
# Once you are confident that your startup processes will always have your
|
||||||
|
# gluster volumes properly mounted *before* the container-server workers
|
||||||
|
# start, you can *consider* setting this value to "false" to reduce the
|
||||||
|
# per-request overhead it can incur.
|
||||||
|
#
|
||||||
|
# *** Keep false for Functional Tests ***
|
||||||
|
mount_check = false
|
||||||
|
bind_port = 6011
|
||||||
|
#
|
||||||
|
# Override swift's default behaviour for fallocate.
|
||||||
|
disable_fallocate = true
|
||||||
|
#
|
||||||
|
# One or two workers should be sufficient for almost any installation of
|
||||||
|
# Gluster.
|
||||||
|
workers = 1
|
||||||
|
|
||||||
|
[pipeline:main]
|
||||||
|
pipeline = container-server
|
||||||
|
|
||||||
|
[app:container-server]
|
||||||
|
use = egg:gluster_swift#container
|
||||||
|
user = root
|
||||||
|
log_facility = LOG_LOCAL2
|
||||||
|
log_level = WARN
|
||||||
|
#
|
||||||
|
# After ensuring things are running in a stable manner, you can turn off
|
||||||
|
# normal request logging for the container server to unclutter the log
|
||||||
|
# files. Warnings and errors will still be logged.
|
||||||
|
log_requests = off
|
||||||
|
|
||||||
|
#enable object versioning for functional test
|
||||||
|
allow_versions = on
|
19
test/functional_auth/keystone/conf/fs.conf
Normal file
19
test/functional_auth/keystone/conf/fs.conf
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
[DEFAULT]
|
||||||
|
#
|
||||||
|
# IP address of a node in the GlusterFS server cluster hosting the
|
||||||
|
# volumes to be served via Swift API.
|
||||||
|
mount_ip = localhost
|
||||||
|
|
||||||
|
# Performance optimization parameter. When turned off, the filesystem will
|
||||||
|
# see a reduced number of stat calls, resulting in substantially faster
|
||||||
|
# response time for GET and HEAD container requests on containers with large
|
||||||
|
# numbers of objects, at the expense of an accurate count of combined bytes
|
||||||
|
# used by all objects in the container. For most installations "off" works
|
||||||
|
# fine.
|
||||||
|
#
|
||||||
|
# *** Keep on for Functional Tests ***
|
||||||
|
accurate_size_in_listing = on
|
||||||
|
|
||||||
|
# *** Keep on for Functional Tests ***
|
||||||
|
container_update_object_count = on
|
||||||
|
account_update_container_count = on
|
48
test/functional_auth/keystone/conf/object-server.conf
Normal file
48
test/functional_auth/keystone/conf/object-server.conf
Normal file
@ -0,0 +1,48 @@
|
|||||||
|
[DEFAULT]
|
||||||
|
devices = /mnt/gluster-object
|
||||||
|
#
|
||||||
|
# Once you are confident that your startup processes will always have your
|
||||||
|
# gluster volumes properly mounted *before* the object-server workers start,
|
||||||
|
# you can *consider* setting this value to "false" to reduce the per-request
|
||||||
|
# overhead it can incur.
|
||||||
|
#
|
||||||
|
# *** Keep false for Functional Tests ***
|
||||||
|
mount_check = false
|
||||||
|
bind_port = 6010
|
||||||
|
#
|
||||||
|
# Maximum number of clients one worker can process simultaneously (it will
|
||||||
|
# actually accept N + 1). Setting this to one (1) will only handle one request
|
||||||
|
# at a time, without accepting another request concurrently. By increasing the
|
||||||
|
# number of workers to a much higher value, one can prevent slow file system
|
||||||
|
# operations for one request from starving other requests.
|
||||||
|
max_clients = 1024
|
||||||
|
#
|
||||||
|
# If not doing the above, setting this value initially to match the number of
|
||||||
|
# CPUs is a good starting point for determining the right value.
|
||||||
|
workers = 1
|
||||||
|
# Override swift's default behaviour for fallocate.
|
||||||
|
disable_fallocate = true
|
||||||
|
|
||||||
|
[pipeline:main]
|
||||||
|
pipeline = object-server
|
||||||
|
|
||||||
|
[app:object-server]
|
||||||
|
use = egg:gluster_swift#object
|
||||||
|
user = root
|
||||||
|
log_facility = LOG_LOCAL2
|
||||||
|
log_level = WARN
|
||||||
|
#
|
||||||
|
# For performance, after ensuring things are running in a stable manner, you
|
||||||
|
# can turn off normal request logging for the object server to reduce the
|
||||||
|
# per-request overhead and unclutter the log files. Warnings and errors will
|
||||||
|
# still be logged.
|
||||||
|
log_requests = off
|
||||||
|
#
|
||||||
|
# Adjust this value to match the stripe width of the underlying storage array
|
||||||
|
# (not the stripe element size). This will provide a reasonable starting point
|
||||||
|
# for tuning this value.
|
||||||
|
disk_chunk_size = 65536
|
||||||
|
#
|
||||||
|
# Adjust this value match whatever is set for the disk_chunk_size initially.
|
||||||
|
# This will provide a reasonable starting point for tuning this value.
|
||||||
|
network_chunk_size = 65556
|
89
test/functional_auth/keystone/conf/proxy-server.conf
Normal file
89
test/functional_auth/keystone/conf/proxy-server.conf
Normal file
@ -0,0 +1,89 @@
|
|||||||
|
[DEFAULT]
|
||||||
|
bind_port = 8080
|
||||||
|
user = root
|
||||||
|
# Consider using 1 worker per CPU
|
||||||
|
workers = 1
|
||||||
|
|
||||||
|
[pipeline:main]
|
||||||
|
#pipeline = catch_errors healthcheck proxy-logging cache tempauth proxy-logging proxy-server
|
||||||
|
pipeline = catch_errors healthcheck proxy-logging cache authtoken keystoneauth proxy-logging proxy-server
|
||||||
|
|
||||||
|
[app:proxy-server]
|
||||||
|
use = egg:gluster_swift#proxy
|
||||||
|
log_facility = LOG_LOCAL1
|
||||||
|
log_level = WARN
|
||||||
|
# The API allows for account creation and deletion, but since Gluster/Swift
|
||||||
|
# automounts a Gluster volume for a given account, there is no way to create
|
||||||
|
# or delete an account. So leave this off.
|
||||||
|
allow_account_management = false
|
||||||
|
account_autocreate = true
|
||||||
|
# Only need to recheck the account exists once a day
|
||||||
|
recheck_account_existence = 86400
|
||||||
|
# May want to consider bumping this up if containers are created and destroyed
|
||||||
|
# infrequently.
|
||||||
|
recheck_container_existence = 60
|
||||||
|
# Timeout clients that don't read or write to the proxy server after 5
|
||||||
|
# seconds.
|
||||||
|
client_timeout = 5
|
||||||
|
# Give more time to connect to the object, container or account servers in
|
||||||
|
# cases of high load.
|
||||||
|
conn_timeout = 5
|
||||||
|
# For high load situations, once connected to an object, container or account
|
||||||
|
# server, allow for delays communicating with them.
|
||||||
|
node_timeout = 60
|
||||||
|
# May want to consider bumping up this value to 1 - 4 MB depending on how much
|
||||||
|
# traffic is for multi-megabyte or gigabyte requests; perhaps matching the
|
||||||
|
# stripe width (not stripe element size) of your storage volume is a good
|
||||||
|
# starting point. See below for sizing information.
|
||||||
|
object_chunk_size = 65536
|
||||||
|
# If you do decide to increase the object_chunk_size, then consider lowering
|
||||||
|
# this value to one. Up to "put_queue_length" object_chunk_size'd buffers can
|
||||||
|
# be queued to the object server for processing. Given one proxy server worker
|
||||||
|
# can handle up to 1,024 connections, by default, it will consume 10 * 65,536
|
||||||
|
# * 1,024 bytes of memory in the worse case (default values). Be sure the
|
||||||
|
# amount of memory available on the system can accommodate increased values
|
||||||
|
# for object_chunk_size.
|
||||||
|
put_queue_depth = 10
|
||||||
|
|
||||||
|
[filter:catch_errors]
|
||||||
|
use = egg:swift#catch_errors
|
||||||
|
|
||||||
|
[filter:proxy-logging]
|
||||||
|
use = egg:swift#proxy_logging
|
||||||
|
|
||||||
|
[filter:healthcheck]
|
||||||
|
use = egg:swift#healthcheck
|
||||||
|
|
||||||
|
[filter:tempauth]
|
||||||
|
use = egg:swift#tempauth
|
||||||
|
user_admin_admin = admin .admin .reseller_admin
|
||||||
|
user_d4dde08c621a4f0fb4cde0ac6a62aa0c_tester = testing .admin
|
||||||
|
user_test_tester = testing .admin
|
||||||
|
user_test2_tester2 = testing2 .admin
|
||||||
|
user_test_tester3 = testing3
|
||||||
|
|
||||||
|
[filter:authtoken]
|
||||||
|
paste.filter_factory = keystoneclient.middleware.auth_token:filter_factory
|
||||||
|
signing_dir = /etc/swift
|
||||||
|
# Keystone server info
|
||||||
|
auth_host = 127.0.0.1
|
||||||
|
auth_port = 35357
|
||||||
|
auth_protocol = http
|
||||||
|
# Swift server info
|
||||||
|
service_host = 127.0.0.1
|
||||||
|
service_port = 8080
|
||||||
|
admin_token = ADMIN
|
||||||
|
# Needed to support Swift container ACL
|
||||||
|
delay_auth_decision = true
|
||||||
|
|
||||||
|
[filter:keystoneauth]
|
||||||
|
use = egg:swift#keystoneauth
|
||||||
|
operator_roles = admin
|
||||||
|
is_admin = true
|
||||||
|
cache = swift.cache
|
||||||
|
|
||||||
|
[filter:cache]
|
||||||
|
use = egg:swift#memcache
|
||||||
|
# Update this line to contain a comma separated list of memcache servers
|
||||||
|
# shared by all nodes running the proxy-server service.
|
||||||
|
memcache_servers = localhost:11211
|
85
test/functional_auth/keystone/conf/swift.conf
Normal file
85
test/functional_auth/keystone/conf/swift.conf
Normal file
@ -0,0 +1,85 @@
|
|||||||
|
[DEFAULT]
|
||||||
|
|
||||||
|
|
||||||
|
[swift-hash]
|
||||||
|
# random unique string that can never change (DO NOT LOSE)
|
||||||
|
swift_hash_path_suffix = gluster
|
||||||
|
|
||||||
|
|
||||||
|
# The swift-constraints section sets the basic constraints on data
|
||||||
|
# saved in the swift cluster.
|
||||||
|
|
||||||
|
[swift-constraints]
|
||||||
|
|
||||||
|
# max_file_size is the largest "normal" object that can be saved in
|
||||||
|
# the cluster. This is also the limit on the size of each segment of
|
||||||
|
# a "large" object when using the large object manifest support.
|
||||||
|
# This value is set in bytes. Setting it to lower than 1MiB will cause
|
||||||
|
# some tests to fail.
|
||||||
|
# Default is 1 TiB = 2**30*1024
|
||||||
|
max_file_size = 1099511627776
|
||||||
|
|
||||||
|
|
||||||
|
# max_meta_name_length is the max number of bytes in the utf8 encoding
|
||||||
|
# of the name portion of a metadata header.
|
||||||
|
|
||||||
|
#max_meta_name_length = 128
|
||||||
|
|
||||||
|
|
||||||
|
# max_meta_value_length is the max number of bytes in the utf8 encoding
|
||||||
|
# of a metadata value
|
||||||
|
|
||||||
|
#max_meta_value_length = 256
|
||||||
|
|
||||||
|
|
||||||
|
# max_meta_count is the max number of metadata keys that can be stored
|
||||||
|
# on a single account, container, or object
|
||||||
|
|
||||||
|
#max_meta_count = 90
|
||||||
|
|
||||||
|
|
||||||
|
# max_meta_overall_size is the max number of bytes in the utf8 encoding
|
||||||
|
# of the metadata (keys + values)
|
||||||
|
|
||||||
|
#max_meta_overall_size = 4096
|
||||||
|
|
||||||
|
|
||||||
|
# max_object_name_length is the max number of bytes in the utf8 encoding of an
|
||||||
|
# object name: Gluster FS can handle much longer file names, but the length
|
||||||
|
# between the slashes of the URL is handled below. Remember that most web
|
||||||
|
# clients can't handle anything greater than 2048, and those that do are
|
||||||
|
# rather clumsy.
|
||||||
|
|
||||||
|
max_object_name_length = 2048
|
||||||
|
|
||||||
|
# max_object_name_component_length (GlusterFS) is the max number of bytes in
|
||||||
|
# the utf8 encoding of an object name component (the part between the
|
||||||
|
# slashes); this is a limit imposed by the underlying file system (for XFS it
|
||||||
|
# is 255 bytes).
|
||||||
|
|
||||||
|
max_object_name_component_length = 255
|
||||||
|
|
||||||
|
# container_listing_limit is the default (and max) number of items
|
||||||
|
# returned for a container listing request
|
||||||
|
|
||||||
|
#container_listing_limit = 10000
|
||||||
|
|
||||||
|
|
||||||
|
# account_listing_limit is the default (and max) number of items returned
|
||||||
|
# for an account listing request
|
||||||
|
|
||||||
|
#account_listing_limit = 10000
|
||||||
|
|
||||||
|
|
||||||
|
# max_account_name_length is the max number of bytes in the utf8 encoding of
|
||||||
|
# an account name: Gluster FS Filename limit (XFS limit?), must be the same
|
||||||
|
# size as max_object_name_component_length above.
|
||||||
|
|
||||||
|
max_account_name_length = 255
|
||||||
|
|
||||||
|
|
||||||
|
# max_container_name_length is the max number of bytes in the utf8 encoding
|
||||||
|
# of a container name: Gluster FS Filename limit (XFS limit?), must be the same
|
||||||
|
# size as max_object_name_component_length above.
|
||||||
|
|
||||||
|
max_container_name_length = 255
|
50
test/functional_auth/keystone/conf/test.conf
Normal file
50
test/functional_auth/keystone/conf/test.conf
Normal file
@ -0,0 +1,50 @@
|
|||||||
|
[func_test]
|
||||||
|
# sample config
|
||||||
|
#auth_host = 127.0.0.1
|
||||||
|
#auth_port = 8080
|
||||||
|
#auth_ssl = no
|
||||||
|
#auth_prefix = /auth/
|
||||||
|
## sample config for Swift with Keystone
|
||||||
|
auth_version = 2
|
||||||
|
auth_host = localhost
|
||||||
|
auth_port = 5000
|
||||||
|
auth_ssl = no
|
||||||
|
auth_prefix = /v2.0/
|
||||||
|
|
||||||
|
# Primary functional test account (needs admin access to the account)
|
||||||
|
account = test
|
||||||
|
username = tester
|
||||||
|
password = testing
|
||||||
|
|
||||||
|
# User on a second account (needs admin access to the account)
|
||||||
|
account2 = test2
|
||||||
|
username2 = tester2
|
||||||
|
password2 = testing2
|
||||||
|
|
||||||
|
# User on same account as first, but without admin access
|
||||||
|
username3 = tester3
|
||||||
|
password3 = testing3
|
||||||
|
|
||||||
|
# Default constraints if not defined here, the test runner will try
|
||||||
|
# to set them from /etc/swift/swift.conf. If that file isn't found,
|
||||||
|
# the test runner will skip tests that depend on these values.
|
||||||
|
# Note that the cluster must have "sane" values for the test suite to pass.
|
||||||
|
#max_file_size = 5368709122
|
||||||
|
#max_meta_name_length = 128
|
||||||
|
#max_meta_value_length = 256
|
||||||
|
#max_meta_count = 90
|
||||||
|
#max_meta_overall_size = 4096
|
||||||
|
#max_object_name_length = 1024
|
||||||
|
#container_listing_limit = 10000
|
||||||
|
#account_listing_limit = 10000
|
||||||
|
#max_account_name_length = 256
|
||||||
|
#max_container_name_length = 256
|
||||||
|
normalized_urls = True
|
||||||
|
|
||||||
|
collate = C
|
||||||
|
|
||||||
|
[unit_test]
|
||||||
|
fake_syslog = False
|
||||||
|
|
||||||
|
[probe_test]
|
||||||
|
# check_server_timeout = 30
|
108
tools/keystone_functional_tests.sh
Executable file
108
tools/keystone_functional_tests.sh
Executable file
@ -0,0 +1,108 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Copyright (c) 2013 Red Hat, Inc.
|
||||||
|
#
|
||||||
|
# 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.
|
||||||
|
|
||||||
|
# This program expects to be run by tox in a virtual python environment
|
||||||
|
# so that it does not pollute the host development system
|
||||||
|
|
||||||
|
sudo_env()
|
||||||
|
{
|
||||||
|
sudo bash -c "PATH=$PATH $*"
|
||||||
|
}
|
||||||
|
|
||||||
|
cleanup()
|
||||||
|
{
|
||||||
|
sudo service memcached stop
|
||||||
|
sudo_env swift-init main stop
|
||||||
|
sudo rm -rf /etc/swift > /dev/null 2>&1
|
||||||
|
for acct in /mnt/gluster-object/* ; do
|
||||||
|
sudo rm -rf /mnt/gluster-object/${acct}/* > /dev/null 2>&1
|
||||||
|
sudo setfattr -x user.swift.metadata /mnt/gluster-object/${acct} > /dev/null 2>&1
|
||||||
|
done
|
||||||
|
}
|
||||||
|
|
||||||
|
quit()
|
||||||
|
{
|
||||||
|
echo "$1"
|
||||||
|
exit 1
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
fail()
|
||||||
|
{
|
||||||
|
cleanup
|
||||||
|
quit "$1"
|
||||||
|
}
|
||||||
|
|
||||||
|
### MAIN ###
|
||||||
|
|
||||||
|
# Only run if there is no configuration in the system
|
||||||
|
if [ -x /etc/swift ] ; then
|
||||||
|
quit "/etc/swift exists, cannot run functional tests."
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Check the directories exist
|
||||||
|
DIRS="/mnt/gluster-object /mnt/gluster-object/test /mnt/gluster-object/test2 /mnt/gluster-object/gsmetadata"
|
||||||
|
for d in $DIRS ; do
|
||||||
|
if [ ! -x $d ] ; then
|
||||||
|
quit "$d must exist on an XFS or GlusterFS volume"
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
|
# Check if keystone is running on this host
|
||||||
|
if ! ps -ef | grep keystone | grep python > /dev/null 2>&1 ; then
|
||||||
|
fail "Keystone is not running on localhost"
|
||||||
|
fi
|
||||||
|
|
||||||
|
export SWIFT_TEST_CONFIG_FILE=/etc/swift/test.conf
|
||||||
|
|
||||||
|
# Install the configuration files
|
||||||
|
sudo mkdir /etc/swift > /dev/null 2>&1
|
||||||
|
sudo cp -r test/functional_auth/keystone/conf/* /etc/swift || fail "Unable to copy configuration files to /etc/swift"
|
||||||
|
|
||||||
|
# Create the ring files according to any directories
|
||||||
|
# in /mnt/gluster-object since the script can't
|
||||||
|
# interrogate keystone to get the tenant-id's
|
||||||
|
accounts=""
|
||||||
|
for acct in /mnt/gluster-object/* ; do
|
||||||
|
acct=`basename $acct`
|
||||||
|
accounts="$acct $accounts"
|
||||||
|
done
|
||||||
|
sudo_env gluster-swift-gen-builders $accounts || fail "Unable to create ring files"
|
||||||
|
|
||||||
|
# Start the services
|
||||||
|
sudo service memcached start || fail "Unable to start memcached"
|
||||||
|
sudo_env swift-init main start || fail "Unable to start swift"
|
||||||
|
|
||||||
|
mkdir functional_tests > /dev/null 2>&1
|
||||||
|
|
||||||
|
echo "== Keystone: Generic Functional Tests =="
|
||||||
|
|
||||||
|
nosetests -v --exe \
|
||||||
|
--with-xunit \
|
||||||
|
--xunit-file functional_tests/gluster-swift-keystone-generic-functional-TC-report.xml \
|
||||||
|
--with-html-output \
|
||||||
|
--html-out-file functional_tests/gluster-swift-keystone-generic-functional-result.html \
|
||||||
|
test/functional || fail "Functional tests failed"
|
||||||
|
nosetests -v --exe \
|
||||||
|
--with-xunit \
|
||||||
|
--xunit-file functional_tests/gluster-swift-keystone-functionalnosetests-TC-report.xml \
|
||||||
|
--with-html-output \
|
||||||
|
--html-out-file functional_tests/gluster-swift-keystone-functionalnosetests-result.html \
|
||||||
|
test/functionalnosetests || fail "Functional-nose tests failed"
|
||||||
|
|
||||||
|
cleanup
|
||||||
|
exit 0
|
@ -10,3 +10,4 @@ openstack.nose_plugin
|
|||||||
nosehtmloutput
|
nosehtmloutput
|
||||||
sphinx>=1.1.2
|
sphinx>=1.1.2
|
||||||
mock>=0.8.0
|
mock>=0.8.0
|
||||||
|
python-keystoneclient
|
||||||
|
7
tox.ini
7
tox.ini
@ -1,5 +1,5 @@
|
|||||||
[tox]
|
[tox]
|
||||||
envlist = py26,py27,pep8,functest
|
envlist = py26,py27,pep8,functest,ksfunctest
|
||||||
|
|
||||||
[testenv]
|
[testenv]
|
||||||
setenv = VIRTUAL_ENV={envdir}
|
setenv = VIRTUAL_ENV={envdir}
|
||||||
@ -25,6 +25,11 @@ whitelist_externals=bash
|
|||||||
commands = bash tools/functional_tests.sh
|
commands = bash tools/functional_tests.sh
|
||||||
bash tools/gswauth_functional_tests.sh
|
bash tools/gswauth_functional_tests.sh
|
||||||
|
|
||||||
|
[testenv:ksfunctest]
|
||||||
|
changedir = {toxinidir}
|
||||||
|
whitelist_externals=bash
|
||||||
|
commands = bash tools/keystone_functional_tests.sh
|
||||||
|
|
||||||
[testenv:pep8]
|
[testenv:pep8]
|
||||||
deps =
|
deps =
|
||||||
--download-cache={homedir}/.pipcache
|
--download-cache={homedir}/.pipcache
|
||||||
|
Loading…
Reference in New Issue
Block a user