~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
4183.7.1 by Sabin Iacob
update FSF mailing address
15
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
1530.2.1 by Robert Collins
Start tests for api usage.
16
17
"""API Documentation for bzrlib.
18
19
This documentation is made up of doctest testable examples.
20
5891.1.2 by Andrew Bennetts
Fix a bunch of docstring formatting nits, making pydoctor a bit happier.
21
Look for `bzrlib/doc/api/*.txt` to read it.
1530.2.1 by Robert Collins
Start tests for api usage.
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
6379.6.7 by Jelmer Vernooij
Move importing from future until after doc string, otherwise the doc string will disappear.
27
from __future__ import absolute_import
28
1530.2.1 by Robert Collins
Start tests for api usage.
29
import doctest
30
import os
3193.1.9 by Vincent Ladeuil
Better test ids for bzrlib/doc/api doc tests.
31
32
from bzrlib import tests
33
3302.9.5 by Vincent Ladeuil
bzrlib.doc switch from test_suite() to load_tests().
34
def load_tests(basic_tests, module, loader):
35
    """This module creates its own test suite with DocFileSuite."""
36
1821.1.1 by Alexander Belchenko
win32 installer for bzr.dev.0.9
37
    dir_ = os.path.dirname(__file__)
38
    if os.path.isdir(dir_):
39
        candidates = os.listdir(dir_)
40
    else:
41
        candidates = []
1740.6.1 by Martin Pool
Remove Scratch objects used by doctests
42
    scripts = [candidate for candidate in candidates
1530.2.1 by Robert Collins
Start tests for api usage.
43
               if candidate.endswith('.txt')]
3302.9.27 by Vincent Ladeuil
Fixed as per Ian's review.
44
    # since this module doesn't define tests, we ignore basic_tests
3193.1.9 by Vincent Ladeuil
Better test ids for bzrlib/doc/api doc tests.
45
    suite = doctest.DocFileSuite(*scripts)
3193.1.11 by Vincent Ladeuil
Relax constraint on test ids, simplify implementation and update tests.
46
    # DocFileCase reduces the test id to the base name of the tested file, we
47
    # want the module to appears there.
3193.1.9 by Vincent Ladeuil
Better test ids for bzrlib/doc/api doc tests.
48
    for t in tests.iter_suite_tests(suite):
49
        def make_new_test_id():
3302.5.1 by Vincent Ladeuil
Give better IDs to doctests.
50
            new_id = '%s.DocFileTest(%s)' % ( __name__, t)
3193.1.9 by Vincent Ladeuil
Better test ids for bzrlib/doc/api doc tests.
51
            return lambda: new_id
52
        t.id = make_new_test_id()
53
    return suite