From 69c3ad9896ae3ef82fa458629bc2213fd7b8de84 Mon Sep 17 00:00:00 2001 From: Michael Merickel Date: Tue, 19 Mar 2013 10:10:10 -0700 Subject: add test to ensure unrelated views are not invoked after PredicateMismatch --- pyramid/tests/test_router.py | 26 ++++++++++++++++++++++++++ 1 file changed, 26 insertions(+) diff --git a/pyramid/tests/test_router.py b/pyramid/tests/test_router.py index 32e74a3b3..432959147 100644 --- a/pyramid/tests/test_router.py +++ b/pyramid/tests/test_router.py @@ -1236,6 +1236,32 @@ class TestRouter(unittest.TestCase): app_iter = router(environ, start_response) self.assertEqual(app_iter, [b'abc']) + def test_call_view_predicate_mismatch_doesnt_find_unrelated_views(self): + from pyramid.exceptions import PredicateMismatch + from pyramid.interfaces import IViewClassifier + from pyramid.interfaces import IRequest + from zope.interface import Interface, implementer + class IContext(Interface): + pass + class IOtherContext(Interface): + pass + @implementer(IContext) + class DummyContext: + pass + context = DummyContext() + self._registerTraverserFactory(context) + view = DummyView(DummyResponse(), raise_exception=PredicateMismatch) + self._registerView(view, '', IViewClassifier, IRequest, + DummyContext) + please_dont_call_me_view = DummyView('abc') + self._registerView(self.config.derive_view(please_dont_call_me_view), + '', IViewClassifier, IRequest, IOtherContext) + router = self._makeOne() + environ = self._makeEnviron() + router = self._makeOne() + start_response = DummyStartResponse() + self.assertRaises(PredicateMismatch, router, environ, start_response) + class DummyPredicate(object): def __call__(self, info, request): return True -- cgit v1.2.3