Use centralised test scripts
This patch consumes the test scripts implemented by https://review.openstack.org/375061 to ensure that the tests and test preparation is consistent and more maintainable. Change-Id: Iece5efb32143979f4d4a0322e3b26aaa5f10d66a
This commit is contained in:
parent
e16ddfd17a
commit
3e5bde5254
@ -30,4 +30,4 @@ export ANSIBLE_SSH_ARGS="-o ControlMaster=no \
|
|||||||
-o ForwardAgent=yes"
|
-o ForwardAgent=yes"
|
||||||
|
|
||||||
echo "Run manual functional tests by executing the following:"
|
echo "Run manual functional tests by executing the following:"
|
||||||
echo "# ./.tox/functional/bin/ansible-playbook -i tests/inventory tests/test.yml -e \"rolename=$(pwd)\""
|
echo "# ./.tox/functional/bin/ansible-playbook -i tests/inventory tests/test.yml"
|
||||||
|
@ -17,7 +17,7 @@
|
|||||||
hosts: localhost
|
hosts: localhost
|
||||||
connection: local
|
connection: local
|
||||||
roles:
|
roles:
|
||||||
- role: "{{ rolename | basename }}"
|
- role: "memcached_server"
|
||||||
post_tasks:
|
post_tasks:
|
||||||
- name: Open memcached log file
|
- name: Open memcached log file
|
||||||
stat:
|
stat:
|
||||||
|
87
tox.ini
87
tox.ini
@ -22,11 +22,11 @@ passenv =
|
|||||||
NO_PROXY
|
NO_PROXY
|
||||||
whitelist_externals =
|
whitelist_externals =
|
||||||
bash
|
bash
|
||||||
git
|
|
||||||
rm
|
|
||||||
setenv =
|
setenv =
|
||||||
VIRTUAL_ENV={envdir}
|
|
||||||
PYTHONUNBUFFERED=1
|
PYTHONUNBUFFERED=1
|
||||||
|
ROLE_NAME=memcached_server
|
||||||
|
VIRTUAL_ENV={envdir}
|
||||||
|
WORKING_DIR={toxinidir}
|
||||||
|
|
||||||
|
|
||||||
[testenv:docs]
|
[testenv:docs]
|
||||||
@ -52,17 +52,17 @@ commands =
|
|||||||
{posargs}
|
{posargs}
|
||||||
|
|
||||||
|
|
||||||
|
[testenv:tests_clone]
|
||||||
|
commands =
|
||||||
|
bash -c "if [ ! -d "{toxinidir}/tests/common" ]; then \
|
||||||
|
git clone https://git.openstack.org/openstack/openstack-ansible-tests {toxinidir}/tests/common; \
|
||||||
|
fi"
|
||||||
|
|
||||||
|
|
||||||
[testenv:pep8]
|
[testenv:pep8]
|
||||||
commands =
|
commands =
|
||||||
# Run hacking/flake8 check for all python files
|
{[testenv:tests_clone]commands}
|
||||||
bash -c "grep --recursive --binary-files=without-match \
|
bash -c "{toxinidir}/tests/common/test-pep8.sh"
|
||||||
--files-with-match '^.!.*python$' \
|
|
||||||
--exclude-dir .eggs \
|
|
||||||
--exclude-dir .git \
|
|
||||||
--exclude-dir .tox \
|
|
||||||
--exclude-dir *.egg-info \
|
|
||||||
--exclude-dir doc \
|
|
||||||
{toxinidir} | xargs flake8 --verbose"
|
|
||||||
|
|
||||||
|
|
||||||
[flake8]
|
[flake8]
|
||||||
@ -75,70 +75,27 @@ ignore=F403,H303
|
|||||||
|
|
||||||
[testenv:bashate]
|
[testenv:bashate]
|
||||||
commands =
|
commands =
|
||||||
# Run bashate check for all bash scripts
|
{[testenv:tests_clone]commands}
|
||||||
# Ignores the following rules:
|
bash -c "{toxinidir}/tests/common/test-bashate.sh"
|
||||||
# E003: Indent not multiple of 4 (we prefer to use multiples of 2)
|
|
||||||
# E006: Line longer than 79 columns (as many scripts use jinja
|
|
||||||
# templating, this is very difficult)
|
|
||||||
# E040: Syntax error determined using `bash -n` (as many scripts
|
|
||||||
# use jinja templating, this will often fail and the syntax
|
|
||||||
# error will be discovered in execution anyway)
|
|
||||||
bash -c "grep --recursive --binary-files=without-match \
|
|
||||||
--files-with-match '^.!.*\(ba\)\?sh$' \
|
|
||||||
--exclude-dir .tox \
|
|
||||||
--exclude-dir .git \
|
|
||||||
{toxinidir} | xargs bashate --error . --verbose --ignore=E003,E006,E040"
|
|
||||||
|
|
||||||
|
|
||||||
[testenv:ansible]
|
[testenv:ansible]
|
||||||
deps =
|
deps =
|
||||||
{[testenv]deps}
|
{[testenv]deps}
|
||||||
ansible==2.1.1
|
-rhttp://git.openstack.org/cgit/openstack/openstack-ansible-tests/plain/test-ansible-deps.txt
|
||||||
ansible-lint>=2.7.0,<3.0.0
|
|
||||||
setenv =
|
|
||||||
{[testenv]setenv}
|
|
||||||
ANSIBLE_HOST_KEY_CHECKING = False
|
|
||||||
ANSIBLE_SSH_CONTROL_PATH = /tmp/%%h-%%r
|
|
||||||
# TODO (odyssey4me) These are only here as they are non-standard folder
|
|
||||||
# names for Ansible 1.9.x. We are using the standard folder names for
|
|
||||||
# Ansible v2.x. We can remove this when we move to Ansible 2.x.
|
|
||||||
ANSIBLE_ACTION_PLUGINS = {homedir}/.ansible/plugins/action
|
|
||||||
ANSIBLE_CALLBACK_PLUGINS = {homedir}/.ansible/plugins/callback
|
|
||||||
ANSIBLE_FILTER_PLUGINS = {homedir}/.ansible/plugins/filter
|
|
||||||
ANSIBLE_LOOKUP_PLUGINS = {homedir}/.ansible/plugins/lookup
|
|
||||||
# This is required as the default is the current path or a path specified
|
|
||||||
# in ansible.cfg
|
|
||||||
ANSIBLE_LIBRARY = {homedir}/.ansible/plugins/library
|
|
||||||
# This is required as the default is '/etc/ansible/roles' or a path
|
|
||||||
# specified in ansible.cfg
|
|
||||||
ANSIBLE_ROLES_PATH = {homedir}/.ansible/roles:{toxinidir}/..
|
|
||||||
ANSIBLE_TRANSPORT = "ssh"
|
|
||||||
commands =
|
commands =
|
||||||
rm -rf {homedir}/.ansible/plugins
|
{[testenv:tests_clone]commands}
|
||||||
git clone https://git.openstack.org/openstack/openstack-ansible-plugins \
|
bash -c "{toxinidir}/tests/common/test-ansible-env-prep.sh"
|
||||||
{homedir}/.ansible/plugins
|
|
||||||
rm -rf {homedir}/.ansible/roles
|
|
||||||
ansible-galaxy install \
|
|
||||||
--role-file={toxinidir}/tests/ansible-role-requirements.yml \
|
|
||||||
--force
|
|
||||||
rm -rf {homedir}/.ansible/roles/memcached_server
|
|
||||||
bash -c "ln -s {toxinidir} {homedir}/.ansible/roles/memcached_server"
|
|
||||||
rm -rf {toxinidir}/tests/playbooks
|
|
||||||
git clone https://git.openstack.org/openstack/openstack-ansible-tests \
|
|
||||||
{toxinidir}/tests/playbooks
|
|
||||||
|
|
||||||
|
|
||||||
[testenv:ansible-syntax]
|
[testenv:ansible-syntax]
|
||||||
deps =
|
deps =
|
||||||
{[testenv:ansible]deps}
|
{[testenv:ansible]deps}
|
||||||
setenv =
|
|
||||||
{[testenv:ansible]setenv}
|
|
||||||
commands =
|
commands =
|
||||||
{[testenv:ansible]commands}
|
{[testenv:ansible]commands}
|
||||||
ansible-playbook -i {toxinidir}/tests/inventory \
|
ansible-playbook -i {toxinidir}/tests/inventory \
|
||||||
--syntax-check \
|
--syntax-check \
|
||||||
--list-tasks \
|
--list-tasks \
|
||||||
-e "rolename={toxinidir}" \
|
|
||||||
{toxinidir}/tests/test.yml
|
{toxinidir}/tests/test.yml
|
||||||
|
|
||||||
|
|
||||||
@ -160,10 +117,7 @@ install_command =
|
|||||||
|
|
||||||
[testenv:func_logs]
|
[testenv:func_logs]
|
||||||
commands =
|
commands =
|
||||||
bash -c 'mkdir -p {toxinidir}/logs'
|
bash -c "{toxinidir}/tests/common/test-log-collect.sh"
|
||||||
bash -c 'rsync --archive --verbose --ignore-errors /var/log/ /openstack/log/ {toxinidir}/logs/ || true'
|
|
||||||
bash -c 'find "{toxinidir}/logs/" -type f | sed "p;s|$|.txt|" | xargs -n2 mv'
|
|
||||||
bash -c 'command gzip --best --recursive "{toxinidir}/logs/"'
|
|
||||||
|
|
||||||
|
|
||||||
[testenv:functional]
|
[testenv:functional]
|
||||||
@ -179,12 +133,9 @@ install_command =
|
|||||||
{[testenv:func_base]install_command}
|
{[testenv:func_base]install_command}
|
||||||
deps =
|
deps =
|
||||||
{[testenv:ansible]deps}
|
{[testenv:ansible]deps}
|
||||||
setenv =
|
|
||||||
{[testenv:ansible]setenv}
|
|
||||||
commands =
|
commands =
|
||||||
{[testenv:ansible]commands}
|
{[testenv:ansible]commands}
|
||||||
ansible-playbook -i {toxinidir}/tests/inventory \
|
ansible-playbook -i {toxinidir}/tests/inventory \
|
||||||
-e "rolename={toxinidir}" \
|
|
||||||
-e "install_test_packages=True" \
|
-e "install_test_packages=True" \
|
||||||
{toxinidir}/tests/test.yml -vvvv
|
{toxinidir}/tests/test.yml -vvvv
|
||||||
{[testenv:func_logs]commands}
|
{[testenv:func_logs]commands}
|
||||||
@ -193,8 +144,6 @@ commands =
|
|||||||
[testenv:linters]
|
[testenv:linters]
|
||||||
deps =
|
deps =
|
||||||
{[testenv:ansible]deps}
|
{[testenv:ansible]deps}
|
||||||
setenv =
|
|
||||||
{[testenv:ansible]setenv}
|
|
||||||
commands =
|
commands =
|
||||||
{[testenv:pep8]commands}
|
{[testenv:pep8]commands}
|
||||||
{[testenv:bashate]commands}
|
{[testenv:bashate]commands}
|
||||||
|
Loading…
Reference in New Issue
Block a user