diff options
| author | Chris McDonough <chrism@agendaless.com> | 2009-04-16 20:31:40 +0000 |
|---|---|---|
| committer | Chris McDonough <chrism@agendaless.com> | 2009-04-16 20:31:40 +0000 |
| commit | d1209e077a1607440677a363651bda4393d72d82 (patch) | |
| tree | 90a202a00438645d1624445cf7c34f8a73a4a46a /repoze/bfg/tests/test_router.py | |
| parent | 168c10641aecba898616c01a25091b745362e366 (diff) | |
| download | pyramid-d1209e077a1607440677a363651bda4393d72d82.tar.gz pyramid-d1209e077a1607440677a363651bda4393d72d82.tar.bz2 pyramid-d1209e077a1607440677a363651bda4393d72d82.zip | |
- The interface for ``repoze.bfg.interfaces.ITraverser`` and the
built-in implementations that implement the interface
(``repoze.bfg.traversal.ModelGraphTraverser``, and
``repoze.bfg.urldispatch.RoutesModelTraverser``) now expect the
``__call__`` method of an ITraverser to return 3 additional
arguments: ``traversed``, ``virtual_root``, and
``virtual_root_path`` (the old contract was that the ``__call__``
method of an ITraverser returned; three arguments, the contract new
is that it returns six). ``traversed`` will be a sequence of
Unicode names that were traversed (including the virtual root path,
if any) or ``None`` if no traversal was performed, ``virtual_root``
will be a model object representing the virtual root (or the
physical root if traversal was not performed), and
``virtual_root_path`` will be a sequence representing the virtual
root path (a sequence of Unicode names) or ``None`` if traversal was
not performed.
Six arguments are now returned from BFG ITraversers. They are
returned in this order: ``context``, ``view_name``, ``subpath``,
``traversed``, ``virtual_root``, and ``virtual_root_path``.
Places in the BFG code which called an ITraverser continue to accept
a 3-argument return value, although BFG will generate and log a
warning when one is encountered.
- The request object now has the following attributes: ``traversed``
(the sequence of names traversed or ``None`` if traversal was not
performed), ``virtual_root`` (the model object representing the
virtual root, including the virtual root path if any), and
``virtual_root_path`` (the seuquence of names representing the
virtual root path or ``None`` if traversal was not performed).
- A new decorator named ``wsgiapp2`` was added to the
``repoze.bfg.wsgi`` module. This decorator performs the same
function as ``repoze.bfg.wsgi.wsgiapp`` except it fixes up the
``SCRIPT_NAME``, and ``PATH_INFO`` environment values before
invoking the WSGI subapplication.
- The ``repoze.bfg.testing.DummyRequest`` object now has default
attributes for ``traversed``, ``virtual_root``, and
``virtual_root_path``.
- The RoutesModelTraverser now behaves more like the Routes
"RoutesMiddleware" object when an element in the match dict is named
``path_info`` (usually when there's a pattern like
``http://foo/*path_info``). When this is the case, the
``PATH_INFO`` environment variable is set to the value in the match
dict, and the ``SCRIPT_NAME`` is appended to with the prefix of the
original ``PATH_INFO`` not including the value of the new variable.
- The notfound debug now shows the traversed path, the virtual root,
and the virtual root path too.
Diffstat (limited to 'repoze/bfg/tests/test_router.py')
| -rw-r--r-- | repoze/bfg/tests/test_router.py | 36 |
1 files changed, 35 insertions, 1 deletions
diff --git a/repoze/bfg/tests/test_router.py b/repoze/bfg/tests/test_router.py index 29849e396..dd249a8fe 100644 --- a/repoze/bfg/tests/test_router.py +++ b/repoze/bfg/tests/test_router.py @@ -21,6 +21,7 @@ class RouterTests(unittest.TestCase): self.messages = [] def info(self, msg): self.messages.append(msg) + warn = info debug = info logger = Logger() self.registry.registerUtility(logger, ILogger, name='repoze.bfg.debug') @@ -93,6 +94,28 @@ class RouterTests(unittest.TestCase): router = self._makeOne() self.assertEqual(router.root_policy, rootfactory) + def test_3arg_policy(self): + rootfactory = make_rootfactory(None) + environ = self._makeEnviron() + context = DummyContext() + traversalfactory = make_3arg_traversal_factory(context, '', []) + self._registerTraverserFactory(traversalfactory, '', None) + logger = self._registerLogger() + self._registerRootFactory(rootfactory) + router = self._makeOne() + start_response = DummyStartResponse() + result = router(environ, start_response) + self.failUnless(traversalfactory in router.traverser_warned) + headers = start_response.headers + self.assertEqual(len(headers), 2) + status = start_response.status + self.assertEqual(status, '404 Not Found') + self.failUnless('http://localhost:8080' in result[0], result) + self.failIf('debug_notfound' in result[0]) + self.assertEqual(len(logger.messages), 1) + message = logger.messages[0] + self.failUnless('is an pre-0.7.1-style ITraverser ' in message) + def test_call_no_view_registered_no_isettings(self): rootfactory = make_rootfactory(None) environ = self._makeEnviron() @@ -717,7 +740,17 @@ def make_view(response): return response return view -def make_traversal_factory(context, name, subpath): +def make_traversal_factory(context, name, subpath, vroot=None, + vroot_path=(), traversed=()): + class DummyTraversalFactory: + def __init__(self, root): + self.root = root + + def __call__(self, path): + return context, name, subpath, traversed, vroot, vroot_path + return DummyTraversalFactory + +def make_3arg_traversal_factory(context, name, subpath): class DummyTraversalFactory: def __init__(self, root): self.root = root @@ -726,6 +759,7 @@ def make_traversal_factory(context, name, subpath): return context, name, subpath return DummyTraversalFactory + def make_permission_factory(result): class DummyPermissionFactory: def __init__(self, context, request): |
