~bzr-pqm/bzr/bzr.dev

2052.3.1 by John Arbash Meinel
Add tests to cleanup the copyright of all source files
1
# Copyright (C) 2005, 2006 Canonical Ltd
1887.1.1 by Adeodato Simó
Do not separate paragraphs in the copyright statement with blank lines,
2
#
1530.2.1 by Robert Collins
Start tests for api usage.
3
# This program is free software; you can redistribute it and/or modify
4
# it under the terms of the GNU General Public License as published by
5
# the Free Software Foundation; either version 2 of the License, or
6
# (at your option) any later version.
1887.1.1 by Adeodato Simó
Do not separate paragraphs in the copyright statement with blank lines,
7
#
1530.2.1 by Robert Collins
Start tests for api usage.
8
# This program is distributed in the hope that it will be useful,
9
# but WITHOUT ANY WARRANTY; without even the implied warranty of
10
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
11
# GNU General Public License for more details.
1887.1.1 by Adeodato Simó
Do not separate paragraphs in the copyright statement with blank lines,
12
#
1530.2.1 by Robert Collins
Start tests for api usage.
13
# You should have received a copy of the GNU General Public License
14
# along with this program; if not, write to the Free Software
15
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
16
17
"""API Documentation for bzrlib.
18
19
This documentation is made up of doctest testable examples.
20
21
Look for bzrlib/doc/api/*.txt to read it.
22
23
This documentation documents the current best practice in using the library.
24
For details on specific apis, see pydoc on the api, or read the source.
25
"""
26
27
import doctest
28
import os
3193.1.9 by Vincent Ladeuil
Better test ids for bzrlib/doc/api doc tests.
29
30
from bzrlib import tests
31
1530.2.1 by Robert Collins
Start tests for api usage.
32
def test_suite():
1821.1.1 by Alexander Belchenko
win32 installer for bzr.dev.0.9
33
    dir_ = os.path.dirname(__file__)
34
    if os.path.isdir(dir_):
35
        candidates = os.listdir(dir_)
36
    else:
37
        candidates = []
1740.6.1 by Martin Pool
Remove Scratch objects used by doctests
38
    scripts = [candidate for candidate in candidates
1530.2.1 by Robert Collins
Start tests for api usage.
39
               if candidate.endswith('.txt')]
3193.1.9 by Vincent Ladeuil
Better test ids for bzrlib/doc/api doc tests.
40
    suite = doctest.DocFileSuite(*scripts)
3193.1.11 by Vincent Ladeuil
Relax constraint on test ids, simplify implementation and update tests.
41
    # DocFileCase reduces the test id to the base name of the tested file, we
42
    # want the module to appears there.
3193.1.9 by Vincent Ladeuil
Better test ids for bzrlib/doc/api doc tests.
43
    for t in tests.iter_suite_tests(suite):
44
        def make_new_test_id():
3302.5.1 by Vincent Ladeuil
Give better IDs to doctests.
45
            new_id = '%s.DocFileTest(%s)' % ( __name__, t)
3193.1.9 by Vincent Ladeuil
Better test ids for bzrlib/doc/api doc tests.
46
            return lambda: new_id
47
        t.id = make_new_test_id()
48
    return suite