You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
57 lines
2.1 KiB
57 lines
2.1 KiB
# Copyright (c) 2014 OpenStack Foundation. |
|
# All Rights Reserved. |
|
# |
|
# 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. |
|
|
|
import os |
|
|
|
from neutron.tests import base |
|
|
|
|
|
SUDO_CMD = 'sudo -n' |
|
|
|
|
|
class BaseSudoTestCase(base.BaseTestCase): |
|
""" |
|
Base class for tests requiring invocation of commands via a root helper. |
|
|
|
Inheritors of this class should call check_sudo_enabled() in |
|
setUp() to ensure that tests requiring sudo are skipped unless |
|
OS_SUDO_TESTING is set to '1' or 'True' in the test execution |
|
environment. This is intended to allow developers to run the |
|
functional suite (e.g. tox -e functional) without test failures if |
|
sudo invocations are not allowed. |
|
|
|
Running sudo tests in the upstream gate jobs |
|
(*-neutron-dsvm-functional) requires the additional step of |
|
setting OS_ROOTWRAP_CMD to the rootwrap command configured by |
|
devstack, e.g. |
|
|
|
sudo /usr/local/bin/neutron-rootwrap /etc/neutron/rootwrap.conf |
|
|
|
Gate jobs do not allow invocations of sudo without rootwrap to |
|
ensure that rootwrap configuration gets as much testing as |
|
possible. |
|
""" |
|
|
|
def setUp(self): |
|
super(BaseSudoTestCase, self).setUp() |
|
env = os.environ |
|
self.sudo_enabled = env.get('OS_SUDO_TESTING') in base.TRUE_STRING |
|
self.root_helper = env.get('OS_ROOTWRAP_CMD', SUDO_CMD) |
|
self.fail_on_missing_deps = ( |
|
env.get('OS_FAIL_ON_MISSING_DEPS') in base.TRUE_STRING) |
|
|
|
def check_sudo_enabled(self): |
|
if not self.sudo_enabled: |
|
self.skipTest('testing with sudo is not enabled')
|
|
|