File: //proc/self/root/usr/lib/python3/dist-packages/lazr/uri/tests/test_docs.py
# 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__ = [
    'additional_tests',
    ]
import atexit
import doctest
import os
import pkg_resources
import unittest
DOCTEST_FLAGS = (
    doctest.ELLIPSIS |
    doctest.NORMALIZE_WHITESPACE |
    doctest.REPORT_NDIFF)
def additional_tests():
    "Run the doc tests (README.txt and docs/*, if any exist)"
    doctest_files = [
        os.path.abspath(
            pkg_resources.resource_filename('lazr.uri', 'README.txt'))]
    if pkg_resources.resource_exists('lazr.uri', 'docs'):
        for name in pkg_resources.resource_listdir('lazr.uri', 'docs'):
            if name.endswith('.txt'):
                doctest_files.append(
                    os.path.abspath(
                        pkg_resources.resource_filename(
                            'lazr.uri', 'docs/%s' % name)))
    kwargs = dict(
        module_relative=False, optionflags=DOCTEST_FLAGS,
        globs={"print_function": print_function},
        )
    atexit.register(pkg_resources.cleanup_resources)
    return unittest.TestSuite((
        doctest.DocFileSuite(*doctest_files, **kwargs)))