diff options
| author | Chris McDonough <chrism@agendaless.com> | 2008-11-08 07:30:36 +0000 |
|---|---|---|
| committer | Chris McDonough <chrism@agendaless.com> | 2008-11-08 07:30:36 +0000 |
| commit | 738f325de6fac3551691d07ad0293891fb352b4e (patch) | |
| tree | 774cdef8619c87e7fdfd464bd45e99943178c7bc /docs | |
| parent | deb0dc316b64d5fb7bd0e15a1bafe269d3b33fbc (diff) | |
| download | pyramid-738f325de6fac3551691d07ad0293891fb352b4e.tar.gz pyramid-738f325de6fac3551691d07ad0293891fb352b4e.tar.bz2 pyramid-738f325de6fac3551691d07ad0293891fb352b4e.zip | |
Add makeRequest API.
Add minimal documentation of BFGTestCase.
Diffstat (limited to 'docs')
| -rw-r--r-- | docs/narr/unittesting.rst | 73 |
1 files changed, 67 insertions, 6 deletions
diff --git a/docs/narr/unittesting.rst b/docs/narr/unittesting.rst index 0ef04083f..eddae73d9 100644 --- a/docs/narr/unittesting.rst +++ b/docs/narr/unittesting.rst @@ -3,11 +3,72 @@ Unit Testing ============ -:mod:`repoze.bfg` provides helper facilities for writing -``unittest.TestCase`` -derived tests. A base class for these types of -tests as well as functions that help test BFG applications -specifically exist. See the :ref:`testing_module` chapter for the -API. +The suggested mechanism for unit testing :mod:`repoze.bfg` +applications is the Python ``unittest`` module. :mod:`repoze.bfg` +provides a number of facilities that make writing ``unittest`` -based +test cases easier to write. The facilities become particularly useful +when your code calls into :mod:`repoze.bfg` -related framework +functions. -XXX +The ``BFGTestCase`` Base Class +------------------------------ + +The ``repoze.bfg.testing`` module provides a class named +``BFGTestCase`` which you can use as a base class for unittest test +classes. + +.. code-block:: python + :linenos: + + def view_fn(context, request): + from repoze.bfg.chameleon_zpt import render_template_to_response + if 'say' in request.params: + return render_template_to_response('templates/submitted.pt', + say=request.params['say']) + return render_template_to_response('templates/show.pt', say='Hello') + + from repoze.bfg.testing import BFGTestCase + + class MyTest(BFGTestCase): + def test_view_fn_not_submitted(self): + template = self.registerTemplate('templates/show.pt') + request = self.makeRequest() + context = self.makeModel() + response = view_fn(context, request) + self.assertEqual(template.say, 'Hello') + + def test_view_fn_submitted(self): + template = self.registerTemplate('templates/submitted.pt') + request = self.makeRequest() + request.params['say'] = 'Yo' + context = self.makeModel() + response = view_fn(context, request) + self.assertEqual(template.say, 'Yo') + +In the above example, we create a ``MyTest`` test case that inherits +from ``BFGTestCase``. It has two test methods. The first test +method, ``test_view_fn_not_submitted`` tests the ``view_fn`` function +in the case that no "form" values (represented by request.params) have +been submitted. Its first line registers a "template" named +``templates/show.pt`` via the ``registerTemplate`` method (a +``BFGTestCase`` API); this function returns a DummyTemplate instance +which we hang on to for later. We then call ``makeRequest`` to get a +DummyRequest object, and ``makeModel`` to get a DummyModel object. We +call the function being tested with the manufactured context and +request. When the function is called, ``render_template_to_response`` +will call the "dummy" template object instead of the real template +object. When it's called, it will set attributes on itself +corresponding to the non-path keyword arguments provided to the +``render_template_to_response`` function. We check that the ``say`` +parameter sent into the template rendering function was ``Hello`` in +this specific example. The second test, named +``test_view_fn_submitted`` tests the alternate case, where the ``say`` +form value has already been set in the request and performs a similar +template registration and assertion. + +See the :ref:`testing_module` chapter for the entire +:mod:`repoze.bfg` -specific testing API. + +The ``BFGTestCase`` class inherits from ``unittest.TestCase``, so it +will be found by test finders. |
