Add tox support

This commit is contained in:
James Page 2016-02-23 17:55:02 +00:00
parent 8564f38c37
commit f01229827f
9 changed files with 64 additions and 5 deletions

View File

@ -1,3 +1,5 @@
bin bin
.coverage .coverage
tags tags
.tox
.testrepository

8
.testr.conf Normal file
View File

@ -0,0 +1,8 @@
[DEFAULT]
test_command=OS_STDOUT_CAPTURE=${OS_STDOUT_CAPTURE:-1} \
OS_STDERR_CAPTURE=${OS_STDERR_CAPTURE:-1} \
OS_TEST_TIMEOUT=${OS_TEST_TIMEOUT:-60} \
${PYTHON:-python} -m subunit.run discover -t ./ ./unit_tests $LISTOPT $IDOPTION
test_id_option=--load-list $IDFILE
test_list_option=--list

View File

@ -89,9 +89,8 @@ def remap_plugin(plugin):
def core_plugin(): def core_plugin():
plugin = remap_plugin(config('plugin')) plugin = remap_plugin(config('plugin'))
if (get_os_codename_install_source(config('openstack-origin')) if (get_os_codename_install_source(config('openstack-origin')) >=
>= 'icehouse' 'icehouse' and plugin == OVS):
and plugin == OVS):
return NEUTRON_ML2_PLUGIN return NEUTRON_ML2_PLUGIN
else: else:
return CORE_PLUGIN[networking_name()][plugin] return CORE_PLUGIN[networking_name()][plugin]

View File

@ -315,7 +315,7 @@ def update_nrpe_config():
shortname="netns", shortname="netns",
description='Network Namespace check {%s}' % current_unit, description='Network Namespace check {%s}' % current_unit,
check_cmd='check_status_file.py -f /var/lib/nagios/netns-check.txt' check_cmd='check_status_file.py -f /var/lib/nagios/netns-check.txt'
) )
nrpe_setup.write() nrpe_setup.write()

12
requirements.txt Normal file
View File

@ -0,0 +1,12 @@
# The order of packages is significant, because pip processes them in the order
# of appearance. Changing the order has an impact on the overall integration
# process, which may cause wedges in the gate later.
PyYAML>=3.1.0
simplejson>=2.2.0
netifaces>=0.10.4
netaddr>=0.7.12,!=0.7.16
Jinja2>=2.6 # BSD License (3 clause)
six>=1.9.0
dnspython>=1.12.0
psutil>=1.1.1,<2.0.0
python-neutronclient>=2.6.0

8
test-requirements.txt Normal file
View File

@ -0,0 +1,8 @@
# The order of packages is significant, because pip processes them in the order
# of appearance. Changing the order has an impact on the overall integration
# process, which may cause wedges in the gate later.
coverage>=3.6
mock>=1.2
flake8>=2.2.4,<=2.4.1
os-testr>=0.4.1
charm-tools

29
tox.ini Normal file
View File

@ -0,0 +1,29 @@
[tox]
envlist = pep8,py27
skipsdist = True
[testenv]
setenv = VIRTUAL_ENV={envdir}
PYTHONHASHSEED=0
install_command =
pip install --allow-unverified python-apt {opts} {packages}
commands = ostestr {posargs}
[testenv:py27]
basepython = python2.7
deps = -r{toxinidir}/requirements.txt
-r{toxinidir}/test-requirements.txt
[testenv:pep8]
basepython = python2.7
deps = -r{toxinidir}/requirements.txt
-r{toxinidir}/test-requirements.txt
commands = flake8 {posargs} hooks unit_tests tests actions
charm proof
[testenv:venv]
commands = {posargs}
[flake8]
ignore = E402,E226
exclude = hooks/charmhelpers

View File

@ -14,6 +14,7 @@ with patch('charmhelpers.core.hookenv.status_set'):
TO_PATCH = [ TO_PATCH = [
'do_openstack_upgrade', 'do_openstack_upgrade',
'config_changed', 'config_changed',
'get_common_package',
] ]

View File

@ -55,7 +55,7 @@ class TestL3AgentContext(CharmTestCase):
self.config.side_effect = self.test_config.get self.config.side_effect = self.test_config.get
@patch('neutron_contexts.NeutronAPIContext') @patch('neutron_contexts.NeutronAPIContext')
def test_no_ext_netid(self, _NeutronAPIContext): def test_no_ext_netid(self, _NeutronAPIContext):
_NeutronAPIContext.return_value = \ _NeutronAPIContext.return_value = \
DummyNeutronAPIContext(return_value={'enable_dvr': False}) DummyNeutronAPIContext(return_value={'enable_dvr': False})
self.test_config.set('run-internal-router', 'none') self.test_config.set('run-internal-router', 'none')