File: coverage_testing.rst

package info (click to toggle)
nipy 0.1.2%2B20100526-2
  • links: PTS, VCS
  • area: main
  • in suites: squeeze
  • size: 11,992 kB
  • ctags: 13,434
  • sloc: python: 47,720; ansic: 41,334; makefile: 197
file content (78 lines) | stat: -rw-r--r-- 3,083 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78

Coverage Testing
----------------

Coverage testing is a technique used to see how much of the code is
exercised by the unit tests. It is important to remember that a high
level of coverage is a necessary but not sufficient condition for
having effective tests. Coverage testing can be useful for identifying
whole functions or classes which are not tested, or for finding
certain conditions which are never tested.

This is an excellent task for nose_ - the automated test runner we are
using.  Nose can run the `python coverage tester`_.  First make sure
you have the coverage tester installed on your system.  Download the
tarball from the link, extract and install ``python setup.py
install``. Or on Ubuntu you can install from apt-get: ``sudo apt-get
install python-coverage``.

Run nose with coverage testing arguments::

   nosetests -sv --with-coverage path_to_code

For example, this command::
    
    nosetests -sv --with-coverage test_coordinate_map.py

will report the following::

 Name                                            Stmts   Exec  Cover   Missing
 -----------------------------------------------------------------------------
 nipy                                       21     14    66%   70-74, 88-89
 nipy.core                                   4      4   100%   
 nipy.core.reference                         8      8   100%   
 nipy.core.reference.array_coords          100     90    90%   133-134, 148-151, 220, 222, 235, 242
 nipy.core.reference.coordinate_map        188    187    99%   738
 nipy.core.reference.coordinate_system      61     61   100%   
 nipy.core.reference.slices                 34     34   100%   
 nipy.core.transforms                        0      0   100%   
 nipy.core.transforms.affines               14     14   100%   


The coverage report will cover any python source module imported after
the start of the test.  This can be noisy and difficult to focus on
the specific module for which you are writing nosetests.  For
instance, the above report also included coverage of most of
``numpy``.  To focus the coverage report, you can provide nose with
the specific package you would like output from using the
``--cover-package``.  For example, in writing tests for the
coordinate_map module::

    nosetests --with-coverage --cover-package=nipy.core.reference.coordinate_map test_coordinate_map.py

Since that's a lot to type, I wrote a tool called ``sneeze`` to that
simplifies coverage testing with nose.


Sneeze
^^^^^^

Sneeze runs nose with coverage testing and reports only the package
the test module is testing.  It requires the test module follow a
simple naming convention:

#. Prefix ``test_``
#. The package name you are testing
#. Suffix ``.py``

For example, the test module for the ``coordinate_map`` module is
named ``test_coordinate_map.py``.  Then testing coverage is as simple as::

      sneeze.py test_coordinate_map.py

Sneeze is included in the ``tools`` directory in the nipy_
source. Simply run the ``setup.py`` to install sneeze in your local
bin directory.


.. include:: ../../links_names.txt