Skip often failing SameHostNetworkTest and DifferentHostNetworkTest scenario test cases

Change-Id: I9a8ce2168ad397c827bc833001fb438858254f77
This commit is contained in:
Federico Ressi 2020-12-03 15:31:04 +01:00
parent ab9715a7aa
commit 08d8360ebf
14 changed files with 96 additions and 92 deletions

View File

@ -105,8 +105,9 @@ MultipleObjectsFound = _select.MultipleObjectsFound
SkipException = _skip.SkipException SkipException = _skip.SkipException
skip_if = _skip.skip_if skip_if = _skip.skip_if
skip_test = skip = _skip.skip_test skip_test = _skip.skip_test
skip_unless = _skip.skip_unless skip_unless = _skip.skip_unless
skip = _skip.skip
BaseTestCase = _testcase.TestCase BaseTestCase = _testcase.TestCase
assert_test_case_was_skipped = _testcase.assert_test_case_was_skipped assert_test_case_was_skipped = _testcase.assert_test_case_was_skipped

View File

@ -124,9 +124,8 @@ class RunsOperationProperty(object):
def is_before(): def is_before():
return self.get_operation().is_before return self.get_operation().is_before
decorator = _skip.skip_unless( decorator = _skip.skip_unless(f"Before operation {self.name}",
predicate=is_before, is_before)
reason="Before operation {name!r}".format(name=self.name))
return self.with_operation(decorator(obj)) return self.with_operation(decorator(obj))
@ -135,9 +134,8 @@ class RunsOperationProperty(object):
def is_after(): def is_after():
return self.get_operation().is_after return self.get_operation().is_after
decorator = _skip.skip_unless( decorator = _skip.skip_unless(f"After operation {self.name}",
predicate=is_after, is_after)
reason="After operation {name!r}".format(name=self.name))
return self.with_operation(decorator(obj)) return self.with_operation(decorator(obj))

View File

@ -15,70 +15,76 @@ from __future__ import absolute_import
import functools import functools
import inspect import inspect
import unittest
import typing # noqa import typing # noqa
import fixtures
import testtools import testtools
from tobiko.common import _fixture
SkipException = testtools.TestCase.skipException # type: typing.Type SkipException = testtools.TestCase.skipException # type: typing.Type
SkipTarget = typing.Union[typing.Callable,
typing.Type[testtools.TestCase],
typing.Type[fixtures.Fixture]]
SkipDecorator = typing.Callable[[SkipTarget], SkipTarget]
def skip_test(reason, *args, **kwargs):
if args or kwargs: def skip_test(reason: str):
reason = reason.format(*args, **kwargs) """Interrupt test case execution marking it as skipped for given reason"""
raise SkipException(reason) raise SkipException(reason)
def skip_if(reason, predicate, *args, **kwargs): def skip(reason: str) -> SkipDecorator:
return skip_if_match(reason, bool, predicate, *args, **kwargs) """Mark test case for being skipped for a given reason"""
return _skip_unless(reason, None, True)
def skip_unless(reason, predicate, *args, **kwargs): def skip_if(reason: str, function: typing.Callable, *args, **kwargs) -> \
return skip_if_match(reason, lambda x: bool(not x), predicate, *args, SkipDecorator:
**kwargs) """Mark test case for being skipped for a given reason if it matches"""
return _skip_unless(reason, function, False, *args, **kwargs)
def skip_if_match(reason, match, predicate, *args, **kwargs): def skip_unless(reason: str, function: typing.Callable, *args, **kwargs) -> \
SkipDecorator:
"""Mark test case for being skipped for a given reason unless it matches"""
return _skip_unless(reason, function, True, *args, **kwargs)
if not callable(predicate):
args = (predicate,) + args
predicate = bool
def decorator(obj): def _skip_unless(reason: str, function: typing.Optional[typing.Callable],
unless: bool, *args, **kwargs) -> SkipDecorator:
"""Mark test case for being skipped for a given reason unless it matches"""
def decorator(obj: SkipTarget) -> SkipTarget:
method = _get_decorated_method(obj) method = _get_decorated_method(obj)
@functools.wraps(method) @functools.wraps(method)
def wrapped_method(*_args, **_kwargs): def skipping_unless(*_args, **_kwargs):
return_value = predicate(*args, **kwargs) if function is not None:
if match(return_value): return_value = function(*args, **kwargs)
if unless is bool(return_value):
return method(*_args, **_kwargs)
if '{return_value' in reason: if '{return_value' in reason:
skip_test(reason, return_value=return_value) skip_test(reason.format(return_value=return_value))
else: skip_test(reason)
skip_test(reason)
return method(*_args, **_kwargs)
if obj is method: if obj is method:
return wrapped_method return skipping_unless
else: else:
setattr(obj, method.__name__, wrapped_method) setattr(obj, method.__name__, skipping_unless)
return obj return obj
return decorator return decorator
def _get_decorated_method(obj): def _get_decorated_method(obj: typing.Any) -> typing.Callable:
if inspect.isclass(obj): if inspect.isclass(obj):
if issubclass(obj, (unittest.TestCase, testtools.TestCase)): setup_method = getattr(obj, 'setUp', None)
return obj.setUp if callable(setup_method):
elif _fixture.is_fixture(obj): return setup_method
return obj.setUp
else: else:
raise TypeError("Cannot decorate class {!r}".format(obj)) raise TypeError(f"Class {obj} does not implement setUp method")
elif callable(obj):
return obj
else: else:
if callable(obj): raise TypeError(f"Object {obj} is not a class or a function")
return obj
else:
raise TypeError("Cannot decorate object {!r}".format(obj))

View File

@ -39,11 +39,9 @@ def open_file(filename, mode):
try: try:
lzma = import_lzma() lzma = import_lzma()
except ImportError: except ImportError:
tobiko.skip("Package lzma or backports.lzma is required to decompress " tobiko.skip_test(
"{filename!r} (mode={mode!r}) XZ image file " "Package lzma or backports.lzma is required to decompress "
"({python_version!r}).", f"{filename!r} (mode={mode!r}) XZ image file "
filename=filename, f"({sys.version!r}).")
mode=mode,
python_version=sys.version)
return lzma.LZMAFile(filename=filename, mode=mode) return lzma.LZMAFile(filename=filename, mode=mode)

View File

@ -214,20 +214,20 @@ class ServerStackFixture(heat.HeatStackFixture):
different_host_hypervisors = nova.get_different_host_hypervisors( different_host_hypervisors = nova.get_different_host_hypervisors(
self.same_host, hypervisor) self.same_host, hypervisor)
if different_host_hypervisors: if different_host_hypervisors:
tobiko.skip("server {!r} of stack {!r} created on " tobiko.skip_test(f"Server {self.server_id} of stack "
"different hypervisor host from servers:\n{!r}", f"{self.stack_name} created on different "
self.server_id, self.stack_name, "hypervisor host from servers:\n"
different_host_hypervisors) f"{different_host_hypervisors}")
def validate_different_host_scheduler_hints(self, hypervisor): def validate_different_host_scheduler_hints(self, hypervisor):
if self.different_host: if self.different_host:
same_host_hypervisors = nova.get_same_host_hypervisors( same_host_hypervisors = nova.get_same_host_hypervisors(
self.different_host, hypervisor) self.different_host, hypervisor)
if same_host_hypervisors: if same_host_hypervisors:
tobiko.skip("server {!r} of stack {!r} created on the same " tobiko.skip_test(f"Server {self.server_id} of stack "
"hypervisor host as servers:\n{!r}", f"{self.stack_name} created on the same "
self.server_id, self.stack_name, "hypervisor host as servers:\n"
same_host_hypervisors) f"{same_host_hypervisors}")
@property @property
def server_details(self): def server_details(self):
@ -301,8 +301,8 @@ class ServerStackFixture(heat.HeatStackFixture):
tobiko.reset_fixture(self) tobiko.reset_fixture(self)
return nova.wait_for_server_status(self.server_id, 'ACTIVE') return nova.wait_for_server_status(self.server_id, 'ACTIVE')
else: else:
tobiko.skip(f"{type(self).__name__}.ensure_server_status " tobiko.skip_test(f"{type(self).__name__}.ensure_server_status "
"method not implemented") "method not implemented")
class ExternalServerStackFixture(ServerStackFixture): class ExternalServerStackFixture(ServerStackFixture):

View File

@ -374,7 +374,7 @@ def rotate_logs(node):
""" """
containers = get_filtered_node_containers(node, ['logrotate.*', ]) containers = get_filtered_node_containers(node, ['logrotate.*', ])
if not containers: if not containers:
tobiko.skip('No logrotate container has been found') tobiko.skip_test('No logrotate container has been found')
else: else:
container = containers[0] container = containers[0]
sh.execute(f'docker exec -u root {container} logrotate ' sh.execute(f'docker exec -u root {container} logrotate '

View File

@ -38,8 +38,9 @@ class DockerNodeFixture(tobiko.SharedFixture):
break break
if self.node is None: if self.node is None:
tobiko.skip('Docker server is not running in any of nodes {}', nodes_text = ' '.join(node.name for node in nodes)
' '.join(node.name for node in nodes)) tobiko.skip_test("Docker server is not running in any of nodes "
f"{nodes_text}")
@keystone.skip_unless_has_keystone_credentials() @keystone.skip_unless_has_keystone_credentials()

View File

@ -44,37 +44,38 @@ class NetworkTest(testtools.TestCase):
def test_ipv4_subnet_cidr(self): def test_ipv4_subnet_cidr(self):
if not self.stack.has_ipv4: if not self.stack.has_ipv4:
tobiko.skip('Stack {!s} has no ipv4 subnet', self.stack.stack_name) tobiko.skip_test(f"Stack {self.stack.stack_name} has no ipv4 "
"subnet")
subnet = neutron.find_subnet(cidr=str(self.stack.ipv4_subnet_cidr)) subnet = neutron.find_subnet(cidr=str(self.stack.ipv4_subnet_cidr))
self.assertEqual(neutron.get_subnet(self.stack.ipv4_subnet_id), subnet) self.assertEqual(neutron.get_subnet(self.stack.ipv4_subnet_id), subnet)
def test_ipv6_subnet_cidr(self): def test_ipv6_subnet_cidr(self):
if not self.stack.has_ipv6: if not self.stack.has_ipv6:
tobiko.skip('Stack {!s} has no ipv6 subnet', self.stack.stack_name) tobiko.skip_test(f"Stack {self.stack.stack_name} has no ipv6 "
"subnet")
subnet = neutron.find_subnet(cidr=str(self.stack.ipv6_subnet_cidr)) subnet = neutron.find_subnet(cidr=str(self.stack.ipv6_subnet_cidr))
self.assertEqual(neutron.get_subnet(self.stack.ipv6_subnet_id), subnet) self.assertEqual(neutron.get_subnet(self.stack.ipv6_subnet_id), subnet)
def test_gateway_network(self): def test_gateway_network(self):
if not self.stack.has_gateway: if not self.stack.has_gateway:
tobiko.skip('Stack {!s} has no gateway', tobiko.skip_test(f"Stack {self.stack.stack_name} has no gateway")
self.stack.stack_name)
self.assertEqual( self.assertEqual(
self.stack.gateway_network_id, self.stack.gateway_network_id,
self.stack.gateway_details['external_gateway_info']['network_id']) self.stack.gateway_details['external_gateway_info']['network_id'])
def test_ipv4_subnet_gateway_ip(self): def test_ipv4_subnet_gateway_ip(self):
if not self.stack.has_ipv4 or not self.stack.has_gateway: if not self.stack.has_ipv4 or not self.stack.has_gateway:
tobiko.skip('Stack {!s} has no IPv4 gateway', tobiko.skip_test(f"Stack {self.stack.stack_name} has no IPv4 "
self.stack.stack_name) "gateway")
self.assertIn( self.assertIn(
self.stack.ipv4_subnet_gateway_ip, self.stack.ipv4_subnet_gateway_ip,
self.stack.ipv4_gateway_addresses) self.stack.ipv4_gateway_addresses)
def test_ipv6_subnet_gateway_ip(self): def test_ipv6_subnet_gateway_ip(self):
if not self.stack.has_ipv6 or not self.stack.has_gateway: if not self.stack.has_ipv6 or not self.stack.has_gateway:
tobiko.skip('Stack {!s} has no IPv6 gateway', tobiko.skip_test(f"Stack {self.stack.stack_name} has no IPv6 "
self.stack.stack_name) "gateway")
self.assertIn( self.assertIn(
self.stack.ipv6_subnet_gateway_ip, self.stack.ipv6_subnet_gateway_ip,
self.stack.ipv6_gateway_addresses) self.stack.ipv6_gateway_addresses)

View File

@ -44,7 +44,7 @@ class NeutronApiTest(testtools.TestCase):
def test_find_floating_network(self): def test_find_floating_network(self):
floating_network = CONF.tobiko.neutron.floating_network floating_network = CONF.tobiko.neutron.floating_network
if not floating_network: if not floating_network:
tobiko.skip('floating_network not configured') tobiko.skip_test('floating_network not configured')
network = neutron.find_network(name=floating_network) network = neutron.find_network(name=floating_network)
self.assertIn(floating_network, [network['name'], network['id']]) self.assertIn(floating_network, [network['name'], network['id']])
self.assertEqual(self.stack.gateway_network_id, network['id']) self.assertEqual(self.stack.gateway_network_id, network['id'])
@ -102,23 +102,23 @@ class NeutronApiTest(testtools.TestCase):
def test_get_router(self): def test_get_router(self):
if not self.stack.has_gateway: if not self.stack.has_gateway:
tobiko.skip("Stack {stack} has no gateway router", tobiko.skip_test(f"Stack {self.stack.stack_name} has no gateway "
stack=self.stack.stack_name) "router")
router = neutron.get_router(self.stack.gateway_id) router = neutron.get_router(self.stack.gateway_id)
self.assertEqual(self.stack.gateway_id, router['id']) self.assertEqual(self.stack.gateway_id, router['id'])
def test_get_ipv4_subnet(self): def test_get_ipv4_subnet(self):
if not self.stack.has_ipv4: if not self.stack.has_ipv4:
tobiko.skip("Stack {stack} has no IPv4 subnet", tobiko.skip_test(
stack=self.stack.stack_name) "Stack {self.stack.stack_name} has no IPv4 subnet")
subnet = neutron.get_subnet(self.stack.ipv4_subnet_id) subnet = neutron.get_subnet(self.stack.ipv4_subnet_id)
self.assertEqual(self.stack.ipv4_subnet_id, subnet['id']) self.assertEqual(self.stack.ipv4_subnet_id, subnet['id'])
self.assertEqual(self.stack.ipv4_subnet_details, subnet) self.assertEqual(self.stack.ipv4_subnet_details, subnet)
def test_get_ipv6_subnet(self): def test_get_ipv6_subnet(self):
if not self.stack.has_ipv6: if not self.stack.has_ipv6:
tobiko.skip("Stack {stack} has no IPv6 subnet", tobiko.skip_test(
stack=self.stack.stack_name) "Stack {self.stack.stack_name} has no IPv6 subnet")
subnet = neutron.get_subnet(self.stack.ipv6_subnet_id) subnet = neutron.get_subnet(self.stack.ipv6_subnet_id)
self.assertEqual(self.stack.ipv6_subnet_id, subnet['id']) self.assertEqual(self.stack.ipv6_subnet_id, subnet['id'])
self.assertEqual(self.stack.ipv6_subnet_details, subnet) self.assertEqual(self.stack.ipv6_subnet_details, subnet)

View File

@ -38,8 +38,9 @@ class PodmanNodeFixture(tobiko.SharedFixture):
break break
if self.node is None: if self.node is None:
tobiko.skip('Podman server is not running in any of nodes {}', nodes_text = ' '.join(node.name for node in nodes)
' '.join(node.name for node in nodes)) tobiko.skip_test("Podman server is not running in any of nodes "
f"{nodes_text}")
@keystone.skip_unless_has_keystone_credentials() @keystone.skip_unless_has_keystone_credentials()

View File

@ -57,6 +57,7 @@ class NetworkTest(testtools.TestCase):
gateway['ha']) gateway['ha'])
@tobiko.skip("The test is not able to allocate required resources")
class SameHostNetworkTest(NetworkTest): class SameHostNetworkTest(NetworkTest):
#: Resources stack with Nova server to send messages to #: Resources stack with Nova server to send messages to
@ -72,6 +73,7 @@ class SameHostNetworkTest(NetworkTest):
getattr(receiver, 'OS-EXT-SRV-ATTR:host')) getattr(receiver, 'OS-EXT-SRV-ATTR:host'))
@tobiko.skip("The test is not able to allocate required resources")
@nova.skip_if_missing_hypervisors(count=2, state='up', status='enabled') @nova.skip_if_missing_hypervisors(count=2, state='up', status='enabled')
class DifferentHostNetworkTest(NetworkTest): class DifferentHostNetworkTest(NetworkTest):

View File

@ -37,8 +37,8 @@ class RouterTest(testtools.TestCase):
def setUp(self): def setUp(self):
super(RouterTest, self).setUp() super(RouterTest, self).setUp()
if not self.stack.network_stack.has_gateway: if not self.stack.network_stack.has_gateway:
tobiko.skip('Stack {!s} has no gateway', tobiko.skip_test(
self.stack.network_stack.stack_name) f"Stack {self.stack.network_stack.stack_name} has no gateway")
@property @property
def router(self): def router(self):
@ -47,15 +47,15 @@ class RouterTest(testtools.TestCase):
@property @property
def ipv4_subnet_gateway_ip(self): def ipv4_subnet_gateway_ip(self):
if not self.stack.network_stack.has_ipv4: if not self.stack.network_stack.has_ipv4:
tobiko.skip('Stack {!s} has no ipv4 subnet', tobiko.skip_test(f"Stack {self.stack.network_stack.stack_name} "
self.stack.network_stack.stack_name) "has no ipv4 subnet")
return self.stack.network_stack.ipv4_subnet_gateway_ip return self.stack.network_stack.ipv4_subnet_gateway_ip
@property @property
def ipv6_subnet_gateway_ip(self): def ipv6_subnet_gateway_ip(self):
if not self.stack.network_stack.has_ipv6: if not self.stack.network_stack.has_ipv6:
tobiko.skip('Stack {!s} has no ipv6 subnet', tobiko.skip_test(f"Stack {self.stack.network_stack.stack_name} "
self.stack.network_stack.stack_name) "has no ipv6 subnet")
return self.stack.network_stack.ipv6_subnet_gateway_ip return self.stack.network_stack.ipv6_subnet_gateway_ip
@property @property

View File

@ -42,10 +42,10 @@ class MyBaseFixture(tobiko.SharedFixture):
class MySkyppingFixture(tobiko.SharedFixture): class MySkyppingFixture(tobiko.SharedFixture):
def setup_fixture(self): def setup_fixture(self):
tobiko.skip('some-reason') tobiko.skip_test('some-reason')
def cleanup_fixture(self): def cleanup_fixture(self):
tobiko.skip('some-reason') tobiko.skip_test('some-reason')
class MyFixture(MyBaseFixture): class MyFixture(MyBaseFixture):

View File

@ -24,8 +24,8 @@ def condition(value):
class PositiveSkipMethodTest(unit.TobikoUnitTest): class PositiveSkipMethodTest(unit.TobikoUnitTest):
@tobiko.skip_if('condition value was true', True) @tobiko.skip('must always skip')
def test_skip_if_condition(self): def test_skip(self):
self.fail('Not skipped') self.fail('Not skipped')
@tobiko.skip_if('condition value was true', condition, True) @tobiko.skip_if('condition value was true', condition, True)
@ -58,10 +58,6 @@ class NegativeSkipBase(unit.TobikoUnitTest):
class NegativeSkipMethodTest(NegativeSkipBase): class NegativeSkipMethodTest(NegativeSkipBase):
@tobiko.skip_if('condition value was false', False)
def test_skip_if_conditions(self):
self.test_method_called = True
@tobiko.skip_if('condition value was false', condition, False) @tobiko.skip_if('condition value was false', condition, False)
def test_skip_if_condition_called_with_args(self): def test_skip_if_condition_called_with_args(self):
self.test_method_called = True self.test_method_called = True