
The recent commit I45d73891f3c0829a2378a032dfc02e5ac0ee34b7 deduplicated the base test class methods from the tempest.lib reintegration. However the surviving base class was put in the wrong namespace. The base class is just that a base to build the individual test subclass off of. It's very confusing for that to not live in the base tests namespace. While the code in lib is supposed to be self contained there isn't a reason to do that here for the unit tests, especially because in this case the import heiarchy becomes more confusing with the base living in a submodule. This commit moves the base class to the base tempest.tests namespace where it really belongs. Change-Id: I079eeb1135eed3254e5e9dbebac8a52b979303c7
46 lines
1.8 KiB
Python
46 lines
1.8 KiB
Python
# Copyright 2013 IBM Corp.
|
|
#
|
|
# 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
|
|
import re
|
|
import six
|
|
import subprocess
|
|
|
|
from tempest.tests import base
|
|
|
|
|
|
class TestTestList(base.TestCase):
|
|
|
|
def test_testr_list_tests_no_errors(self):
|
|
# Remove unit test discover path from env to test tempest tests
|
|
test_env = os.environ.copy()
|
|
test_env.pop('OS_TEST_PATH')
|
|
import_failures = []
|
|
p = subprocess.Popen(['testr', 'list-tests'], stdout=subprocess.PIPE,
|
|
env=test_env)
|
|
ids, err = p.communicate()
|
|
self.assertEqual(0, p.returncode,
|
|
"test discovery failed, one or more files cause an "
|
|
"error on import %s" % ids)
|
|
ids = six.text_type(ids).split('\n')
|
|
for test_id in ids:
|
|
if re.match('(\w+\.){3}\w+', test_id):
|
|
if not test_id.startswith('tempest.'):
|
|
parts = test_id.partition('tempest')
|
|
fail_id = parts[1] + parts[2]
|
|
import_failures.append(fail_id)
|
|
error_message = ("The following tests have import failures and aren't"
|
|
" being run with test filters %s" % import_failures)
|
|
self.assertFalse(import_failures, error_message)
|