From 9c4a7271c71fa17827df8adefb07fe4bb2c3e2a7 Mon Sep 17 00:00:00 2001 From: Chris McDonough Date: Thu, 12 Nov 2009 01:47:33 +0000 Subject: Test alsoProvides. --- repoze/bfg/tests/test_urldispatch.py | 23 +++++++++++++++++++++++ 1 file changed, 23 insertions(+) diff --git a/repoze/bfg/tests/test_urldispatch.py b/repoze/bfg/tests/test_urldispatch.py index 803f4503f..ecc76fe04 100644 --- a/repoze/bfg/tests/test_urldispatch.py +++ b/repoze/bfg/tests/test_urldispatch.py @@ -106,6 +106,29 @@ class RoutesRootFactoryTests(unittest.TestCase): self.assertEqual(request.matchdict, routing_args) self.failUnless(req_iface.providedBy(request)) + def test_route_matches_already_has_iface(self): + from zope.interface import Interface + from zope.interface import directlyProvides + root_factory = DummyRootFactory(123) + req_iface = self._registerRouteRequest('foo') + mapper = self._makeOne(root_factory) + mapper.connect('archives/:action/:article', 'foo') + request = self._getRequest(PATH_INFO='/archives/action1/article1') + class IFoo(Interface): + pass + directlyProvides(request, IFoo) + result = mapper(request) + self.assertEqual(result, 123) + environ = request.environ + routing_args = environ['wsgiorg.routing_args'][1] + self.assertEqual(routing_args['action'], 'action1') + self.assertEqual(routing_args['article'], 'article1') + self.assertEqual(environ['bfg.routes.matchdict'], routing_args) + self.assertEqual(environ['bfg.routes.route'].name, 'foo') + self.assertEqual(request.matchdict, routing_args) + self.failUnless(req_iface.providedBy(request)) + self.failUnless(IFoo.providedBy(request)) + def test_route_matches_and_has_factory(self): root_factory = DummyRootFactory(123) req_iface = self._registerRouteRequest('foo') -- cgit v1.2.3