mirror of
https://github.com/sphinx-doc/sphinx.git
synced 2025-02-25 18:55:22 -06:00
Merge pull request #6135 from bz2/changes_module_1.8
Fix UnboundLocalError when building changes (1.8)
This commit is contained in:
commit
7c50f8f08b
@ -85,8 +85,7 @@ class ChangesBuilder(Builder):
|
|||||||
entry = '<b>%s</b>: <i>%s</i>.' % (descname, ttext)
|
entry = '<b>%s</b>: <i>%s</i>.' % (descname, ttext)
|
||||||
apichanges.append((entry, changeset.docname, changeset.lineno))
|
apichanges.append((entry, changeset.docname, changeset.lineno))
|
||||||
elif descname or changeset.module:
|
elif descname or changeset.module:
|
||||||
if not changeset.module:
|
module = changeset.module or _('Builtins')
|
||||||
module = _('Builtins')
|
|
||||||
if not descname:
|
if not descname:
|
||||||
descname = _('Module level')
|
descname = _('Module level')
|
||||||
if context:
|
if context:
|
||||||
|
20
tests/roots/test-changes/base.rst
Normal file
20
tests/roots/test-changes/base.rst
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
Version markup
|
||||||
|
--------------
|
||||||
|
|
||||||
|
.. versionadded:: 0.6
|
||||||
|
Some funny **stuff**.
|
||||||
|
|
||||||
|
.. versionchanged:: 0.6
|
||||||
|
Even more funny stuff.
|
||||||
|
|
||||||
|
.. deprecated:: 0.6
|
||||||
|
Boring stuff.
|
||||||
|
|
||||||
|
.. versionadded:: 1.2
|
||||||
|
|
||||||
|
First paragraph of versionadded.
|
||||||
|
|
||||||
|
.. versionchanged:: 1.2
|
||||||
|
First paragraph of versionchanged.
|
||||||
|
|
||||||
|
Second paragraph of versionchanged.
|
24
tests/roots/test-changes/c-api.rst
Normal file
24
tests/roots/test-changes/c-api.rst
Normal file
@ -0,0 +1,24 @@
|
|||||||
|
.. highlightlang:: c
|
||||||
|
|
||||||
|
|
||||||
|
Memory
|
||||||
|
======
|
||||||
|
|
||||||
|
.. c:function:: void* Test_Malloc(size_t n)
|
||||||
|
|
||||||
|
Allocate *n* bytes of memory.
|
||||||
|
|
||||||
|
.. versionchanged:: 0.6
|
||||||
|
|
||||||
|
Can now be replaced with a different allocator.
|
||||||
|
|
||||||
|
System
|
||||||
|
------
|
||||||
|
|
||||||
|
Access to the system allocator.
|
||||||
|
|
||||||
|
.. versionadded:: 0.6
|
||||||
|
|
||||||
|
.. c:function:: void* Test_SysMalloc(size_t n)
|
||||||
|
|
||||||
|
Allocate *n* bytes of memory using system allocator.
|
6
tests/roots/test-changes/conf.py
Normal file
6
tests/roots/test-changes/conf.py
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
# -*- coding: utf-8 -*-
|
||||||
|
|
||||||
|
project = 'Sphinx ChangesBuilder tests'
|
||||||
|
copyright = '2007-2019 by the Sphinx team, see AUTHORS'
|
||||||
|
version = '0.6'
|
||||||
|
release = '0.6alpha1'
|
13
tests/roots/test-changes/contents.rst
Normal file
13
tests/roots/test-changes/contents.rst
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
Index for ChangesBuilder tests
|
||||||
|
==============================
|
||||||
|
|
||||||
|
Contents:
|
||||||
|
|
||||||
|
.. toctree::
|
||||||
|
:maxdepth: 2
|
||||||
|
:caption: Table of Contents
|
||||||
|
:name: mastertoc
|
||||||
|
|
||||||
|
base
|
||||||
|
c-api
|
||||||
|
library/utils
|
25
tests/roots/test-changes/library/utils.rst
Normal file
25
tests/roots/test-changes/library/utils.rst
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
:mod:`utils` --- Fake utilities module for tests
|
||||||
|
================================================
|
||||||
|
|
||||||
|
.. module:: utils
|
||||||
|
:synopsis: Utility functions
|
||||||
|
|
||||||
|
--------------
|
||||||
|
|
||||||
|
The :mod:`utils` module is a pretend python module for changes testing.
|
||||||
|
|
||||||
|
|
||||||
|
Classes
|
||||||
|
-------
|
||||||
|
|
||||||
|
.. class:: Path
|
||||||
|
|
||||||
|
Class for handling paths.
|
||||||
|
|
||||||
|
.. versionadded:: 0.5
|
||||||
|
|
||||||
|
Innovative new way to handle paths.
|
||||||
|
|
||||||
|
.. deprecated:: 0.6
|
||||||
|
|
||||||
|
So, that was a bad idea it turns out.
|
@ -61,13 +61,13 @@ def nonascii_srcdir(request, rootdir, sphinx_test_tempdir):
|
|||||||
|
|
||||||
|
|
||||||
# note: this test skips building docs for some builders because they have independent testcase.
|
# note: this test skips building docs for some builders because they have independent testcase.
|
||||||
# (html, epub, latex, texinfo and manpage)
|
# (html, changes, epub, latex, texinfo and manpage)
|
||||||
@pytest.mark.parametrize(
|
@pytest.mark.parametrize(
|
||||||
"buildername",
|
"buildername",
|
||||||
[
|
[
|
||||||
# note: no 'html' - if it's ok with dirhtml it's ok with html
|
# note: no 'html' - if it's ok with dirhtml it's ok with html
|
||||||
'dirhtml', 'singlehtml', 'pickle', 'json', 'text', 'htmlhelp', 'qthelp',
|
'dirhtml', 'singlehtml', 'pickle', 'json', 'text', 'htmlhelp', 'qthelp',
|
||||||
'applehelp', 'changes', 'xml', 'pseudoxml', 'linkcheck',
|
'applehelp', 'xml', 'pseudoxml', 'linkcheck',
|
||||||
],
|
],
|
||||||
)
|
)
|
||||||
@mock.patch('sphinx.builders.linkcheck.requests.head',
|
@mock.patch('sphinx.builders.linkcheck.requests.head',
|
||||||
|
43
tests/test_build_changes.py
Normal file
43
tests/test_build_changes.py
Normal file
@ -0,0 +1,43 @@
|
|||||||
|
# -*- coding: utf-8 -*-
|
||||||
|
"""
|
||||||
|
test_build_changes
|
||||||
|
~~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
|
Test the ChangesBuilder class.
|
||||||
|
|
||||||
|
:copyright: Copyright 2007-2019 by the Sphinx team, see AUTHORS.
|
||||||
|
:license: BSD, see LICENSE for details.
|
||||||
|
"""
|
||||||
|
|
||||||
|
import pytest
|
||||||
|
|
||||||
|
|
||||||
|
@pytest.mark.sphinx('changes', testroot='changes')
|
||||||
|
def test_build(app):
|
||||||
|
app.build()
|
||||||
|
|
||||||
|
# TODO: Use better checking of html content
|
||||||
|
htmltext = (app.outdir / 'changes.html').text()
|
||||||
|
assert 'New in version 0.6: Some funny stuff.' in htmltext
|
||||||
|
assert 'Changed in version 0.6: Even more funny stuff.' in htmltext
|
||||||
|
assert 'Deprecated since version 0.6: Boring stuff.' in htmltext
|
||||||
|
|
||||||
|
path_html = (
|
||||||
|
'<b>Path</b>: <i>deprecated:</i> Deprecated since version 0.6:'
|
||||||
|
' So, that was a bad idea it turns out.')
|
||||||
|
assert path_html in htmltext
|
||||||
|
|
||||||
|
malloc_html = (
|
||||||
|
'<b>Test_Malloc</b>: <i>changed:</i> Changed in version 0.6:'
|
||||||
|
' Can now be replaced with a different allocator.</a>')
|
||||||
|
assert malloc_html in htmltext
|
||||||
|
|
||||||
|
|
||||||
|
@pytest.mark.sphinx(
|
||||||
|
'changes', testroot='changes', srcdir='changes-none',
|
||||||
|
confoverrides={'version': '0.7', 'release': '0.7b1'})
|
||||||
|
def test_no_changes(app, status):
|
||||||
|
app.build()
|
||||||
|
|
||||||
|
assert 'no changes in version 0.7.' in status.getvalue()
|
||||||
|
assert not (app.outdir / 'changes.html').exists()
|
Loading…
Reference in New Issue
Block a user