refactor: Hoist helpers.expect into package namespace
It's silly to have to import a package's submodule directly, since in this case that only introduces another module name that the developer has to keep track of, just to gain access to a solitary function. This patch hoists marconi.tests.util.helpers.expect into marocni.tests.util so that it can be referenced more naturally by the test author. Accordingly, the Hacking.rst guide has been updated to allow this sort of thing (with some discretion). Implements: blueprint grizzly-debt Change-Id: Iad2e4f728aa4826d99bec2c599e2947a87eb5945
This commit is contained in:
parent
a556f392c5
commit
8b31b2e9b0
@ -56,12 +56,13 @@ Example::
|
|||||||
|
|
||||||
Imports
|
Imports
|
||||||
-------
|
-------
|
||||||
|
- Only modules may be imported
|
||||||
- Do not make relative imports
|
- Do not make relative imports
|
||||||
- Order your imports by the full module path
|
- Order your imports by the full module path
|
||||||
- Import of classes is just allowed inside __init__ files.
|
- Classes and functions may be hoisted into a package namespace, via __init__ files, with some discretion.
|
||||||
- Organize your imports according to the following template
|
- Organize your imports according to the template given below
|
||||||
|
|
||||||
Example::
|
Template::
|
||||||
|
|
||||||
{{stdlib imports in human alphabetical order}}
|
{{stdlib imports in human alphabetical order}}
|
||||||
\n
|
\n
|
||||||
|
@ -17,7 +17,6 @@
|
|||||||
from marconi import storage
|
from marconi import storage
|
||||||
from marconi.storage import exceptions
|
from marconi.storage import exceptions
|
||||||
from marconi.tests import util as testing
|
from marconi.tests import util as testing
|
||||||
from marconi.tests.util import helpers
|
|
||||||
|
|
||||||
|
|
||||||
class ControllerBaseTest(testing.TestBase):
|
class ControllerBaseTest(testing.TestBase):
|
||||||
@ -201,7 +200,7 @@ class MessageControllerTest(ControllerBaseTest):
|
|||||||
[msg1, msg2] = msgs
|
[msg1, msg2] = msgs
|
||||||
|
|
||||||
# A wrong claim does not ensure the message deletion
|
# A wrong claim does not ensure the message deletion
|
||||||
with helpers.expected(storage.exceptions.NotPermitted):
|
with testing.expect(storage.exceptions.NotPermitted):
|
||||||
self.controller.delete(self.queue_name, msg1["id"],
|
self.controller.delete(self.queue_name, msg1["id"],
|
||||||
project=self.project,
|
project=self.project,
|
||||||
claim=another_cid)
|
claim=another_cid)
|
||||||
@ -211,7 +210,7 @@ class MessageControllerTest(ControllerBaseTest):
|
|||||||
project=self.project,
|
project=self.project,
|
||||||
claim=cid)
|
claim=cid)
|
||||||
|
|
||||||
with helpers.expected(storage.exceptions.DoesNotExist):
|
with testing.expect(storage.exceptions.DoesNotExist):
|
||||||
self.controller.get(self.queue_name, msg1["id"],
|
self.controller.get(self.queue_name, msg1["id"],
|
||||||
project=self.project)
|
project=self.project)
|
||||||
|
|
||||||
@ -224,7 +223,7 @@ class MessageControllerTest(ControllerBaseTest):
|
|||||||
self.claim_controller.delete(self.queue_name, cid,
|
self.claim_controller.delete(self.queue_name, cid,
|
||||||
project=self.project)
|
project=self.project)
|
||||||
|
|
||||||
with helpers.expected(storage.exceptions.NotPermitted):
|
with testing.expect(storage.exceptions.NotPermitted):
|
||||||
self.controller.delete(self.queue_name, msg2["id"],
|
self.controller.delete(self.queue_name, msg2["id"],
|
||||||
project=self.project,
|
project=self.project,
|
||||||
claim=cid)
|
claim=cid)
|
||||||
@ -236,7 +235,7 @@ class MessageControllerTest(ControllerBaseTest):
|
|||||||
project=self.project,
|
project=self.project,
|
||||||
client_uuid='my_uuid')
|
client_uuid='my_uuid')
|
||||||
|
|
||||||
with helpers.expected(storage.exceptions.DoesNotExist):
|
with testing.expect(storage.exceptions.DoesNotExist):
|
||||||
self.controller.get(self.queue_name, msgid,
|
self.controller.get(self.queue_name, msgid,
|
||||||
project=self.project)
|
project=self.project)
|
||||||
|
|
||||||
@ -255,7 +254,7 @@ class MessageControllerTest(ControllerBaseTest):
|
|||||||
|
|
||||||
self.assertEquals(len(msgs), 0)
|
self.assertEquals(len(msgs), 0)
|
||||||
|
|
||||||
with helpers.expected(exceptions.DoesNotExist):
|
with testing.expect(exceptions.DoesNotExist):
|
||||||
self.controller.get('unused', 'illformed', '480924')
|
self.controller.get('unused', 'illformed', '480924')
|
||||||
|
|
||||||
def test_illformed_claim(self):
|
def test_illformed_claim(self):
|
||||||
@ -265,7 +264,7 @@ class MessageControllerTest(ControllerBaseTest):
|
|||||||
project='480924',
|
project='480924',
|
||||||
client_uuid='unused')
|
client_uuid='unused')
|
||||||
|
|
||||||
with helpers.expected(exceptions.NotPermitted):
|
with testing.expect(exceptions.NotPermitted):
|
||||||
self.controller.delete('unused', msgid,
|
self.controller.delete('unused', msgid,
|
||||||
project='480924',
|
project='480924',
|
||||||
claim='illformed')
|
claim='illformed')
|
||||||
@ -354,11 +353,11 @@ class ClaimControllerTest(ControllerBaseTest):
|
|||||||
claim_id, messages = self.controller.create(self.queue_name, meta,
|
claim_id, messages = self.controller.create(self.queue_name, meta,
|
||||||
project=self.project)
|
project=self.project)
|
||||||
|
|
||||||
with helpers.expected(storage.exceptions.DoesNotExist):
|
with testing.expect(storage.exceptions.DoesNotExist):
|
||||||
self.controller.get(self.queue_name, claim_id,
|
self.controller.get(self.queue_name, claim_id,
|
||||||
project=self.project)
|
project=self.project)
|
||||||
|
|
||||||
with helpers.expected(storage.exceptions.DoesNotExist):
|
with testing.expect(storage.exceptions.DoesNotExist):
|
||||||
self.controller.update(self.queue_name, claim_id,
|
self.controller.update(self.queue_name, claim_id,
|
||||||
meta, project=self.project)
|
meta, project=self.project)
|
||||||
|
|
||||||
@ -368,7 +367,7 @@ class ClaimControllerTest(ControllerBaseTest):
|
|||||||
self.queue_controller.upsert('unused', {}, '480924')
|
self.queue_controller.upsert('unused', {}, '480924')
|
||||||
self.controller.delete('unused', 'illformed', '480924')
|
self.controller.delete('unused', 'illformed', '480924')
|
||||||
|
|
||||||
with helpers.expected(exceptions.DoesNotExist):
|
with testing.expect(exceptions.DoesNotExist):
|
||||||
self.controller.update('unused', 'illformed',
|
self.controller.update('unused', 'illformed',
|
||||||
{'ttl': 40}, '480924')
|
{'ttl': 40}, '480924')
|
||||||
|
|
||||||
|
@ -15,7 +15,6 @@
|
|||||||
|
|
||||||
from marconi.common import config
|
from marconi.common import config
|
||||||
from marconi.tests import util as testing
|
from marconi.tests import util as testing
|
||||||
from marconi.tests.util import helpers
|
|
||||||
|
|
||||||
|
|
||||||
cfg_handle = config.project()
|
cfg_handle = config.project()
|
||||||
@ -36,5 +35,5 @@ class TestConfig(testing.TestBase):
|
|||||||
|
|
||||||
def test_wrong_type(self):
|
def test_wrong_type(self):
|
||||||
ns = config.namespace('local')
|
ns = config.namespace('local')
|
||||||
with helpers.expected(config.cfg.Error):
|
with testing.expect(config.cfg.Error):
|
||||||
ns.from_options(opt={})
|
ns.from_options(opt={})
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
"""Test utilities"""
|
"""Test utilities"""
|
||||||
|
|
||||||
from marconi.tests.util import base
|
from marconi.tests.util import base
|
||||||
|
from marconi.tests.util import helpers
|
||||||
|
|
||||||
TestBase = base.TestBase
|
TestBase = base.TestBase
|
||||||
|
expect = helpers.expect
|
||||||
|
@ -17,7 +17,24 @@ import contextlib
|
|||||||
|
|
||||||
|
|
||||||
@contextlib.contextmanager
|
@contextlib.contextmanager
|
||||||
def expected(*exc_type):
|
def expect(*exc_type):
|
||||||
|
"""A context manager to validate raised expections.
|
||||||
|
|
||||||
|
Can be used as an alternative to testtools.ExpectedException.
|
||||||
|
|
||||||
|
Notable differences:
|
||||||
|
1. This context manager accepts child classes of the
|
||||||
|
given type, testing that an "except" statement
|
||||||
|
referencing the given type would indeed catch it when
|
||||||
|
raised by the statement(s) defined inside the context.
|
||||||
|
2. When the expected exception (or a child thereof) is
|
||||||
|
not raised, this context manager *always* raises
|
||||||
|
an AssertionError, both when a different exception
|
||||||
|
is raised, and when no exception is raised at all.
|
||||||
|
|
||||||
|
:param *exc_type: Exception type(s) expected to be raised during
|
||||||
|
execution of the "with" context.
|
||||||
|
"""
|
||||||
assert len(exc_type) > 0
|
assert len(exc_type) > 0
|
||||||
|
|
||||||
try:
|
try:
|
||||||
|
Loading…
Reference in New Issue
Block a user