summaryrefslogtreecommitdiff
path: root/tests/test_ext_doctest.py
blob: 020357879ca4cf3b8c714c699c0cbc6d366df700 (plain)
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
# -*- coding: utf-8 -*-
"""
    test_doctest
    ~~~~~~~~~~~~

    Test the doctest extension.

    :copyright: Copyright 2007-2018 by the Sphinx team, see AUTHORS.
    :license: BSD, see LICENSE for details.
"""
import pytest
from sphinx.ext.doctest import compare_version

cleanup_called = 0


@pytest.mark.sphinx('doctest', testroot='ext-doctest')
def test_build(app, status, warning):
    global cleanup_called
    cleanup_called = 0
    app.builder.build_all()
    if app.statuscode != 0:
        assert False, 'failures in doctests:' + status.getvalue()
    # in doctest.txt, there are two named groups and the default group,
    # so the cleanup function must be called three times
    assert cleanup_called == 3, 'testcleanup did not get executed enough times'


def test_compare_version():
    assert compare_version('3.3', '3.4', '<') is True
    assert compare_version('3.3', '3.2', '<') is False
    assert compare_version('3.3', '3.4', '<=') is True
    assert compare_version('3.3', '3.2', '<=') is False
    assert compare_version('3.3', '3.3', '==') is True
    assert compare_version('3.3', '3.4', '==') is False
    assert compare_version('3.3', '3.2', '>=') is True
    assert compare_version('3.3', '3.4', '>=') is False
    assert compare_version('3.3', '3.2', '>') is True
    assert compare_version('3.3', '3.4', '>') is False
    with pytest.raises(ValueError):
        compare_version('3.3', '3.4', '+')


def cleanup_call():
    global cleanup_called
    cleanup_called += 1