12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364 |
- # Copyright 2009 Canonical Ltd. All rights reserved.
- #
- # This file is part of lazr.uri
- #
- # lazr.uri is free software: you can redistribute it and/or modify it
- # under the terms of the GNU Lesser General Public License as published by
- # the Free Software Foundation, version 3 of the License.
- #
- # lazr.uri is distributed in the hope that it will be useful, but WITHOUT
- # ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- # FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public
- # License for more details.
- #
- # You should have received a copy of the GNU Lesser General Public License
- # along with lazr.uri. If not, see <http://www.gnu.org/licenses/>.
- """Test harness for doctests."""
- from __future__ import print_function
- __metaclass__ = type
- __all__ = [
- 'load_tests',
- ]
- import atexit
- import doctest
- import os
- from pkg_resources import (
- cleanup_resources,
- resource_exists,
- resource_filename,
- resource_listdir,
- )
- DOCTEST_FLAGS = (
- doctest.ELLIPSIS |
- doctest.NORMALIZE_WHITESPACE |
- doctest.REPORT_NDIFF)
- def find_doctests(suffix):
- """Find doctests matching a certain suffix."""
- doctest_files = []
- # Match doctests against the suffix.
- if resource_exists('lazr.uri', 'docs'):
- for name in resource_listdir('lazr.uri', 'docs'):
- if name.endswith(suffix):
- doctest_files.append(
- os.path.abspath(
- resource_filename('lazr.uri', 'docs/%s' % name)))
- return doctest_files
- def load_tests(loader, tests, pattern):
- """Load all the doctests."""
- atexit.register(cleanup_resources)
- tests.addTest(doctest.DocFileSuite(
- *find_doctests('.rst'),
- module_relative=False, optionflags=DOCTEST_FLAGS,
- globs={"print_function": print_function}))
- return tests
|