File: CONTRIBUTING.rst

package info (click to toggle)
sphinxcontrib-restbuilder 0.3-4
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 640 kB
  • sloc: python: 1,048; makefile: 20; sh: 6
file content (130 lines) | stat: -rw-r--r-- 4,241 bytes parent folder | download | duplicates (3)
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
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
Thank you for contributing!
===========================

Thank you for considering a contribution to Sphinx reStructuredText
builder/writer, and for reading this document.

Use issues for bug reports, feature requests, or any sort of feedback
that you may have.

If you are able to spend the time to create a pull request, that is
most appreciated.


Testing your code
=================

* Run `pytest`_ to run all tests using your default Python version and
  Sphinx version.

* Run `pytest -k testName` to only run the test called testName.

* For testing, Sphinx is run for each test in the `tests/datasets`
  directory, and the output is written to the `output` directory.
  The result is then compared to the expected output in
  `tests/expected`.

* Rather than a byte-by-byte comparison, `output` and `tests/expected`
  are compared after reading the file with docutils (which contains a
  basic reStructuredText parser), to allow for slight variations in
  layout.

* If a test fails, the XML version of the parsed documents is written
  to the `output` directory. `test-file.expected.xml` for
  `test-file.rst` in `tests/expected`, and `test-file.output.xml` for
  `test-file.rst` in `output`.

* Optionally run `pytest -v -r A -W d` for a very verbose output,
  including stdout and stderr for all tests (note that some tests like
  nonexistent-target.rst are expected to give a warning), and including
  all Python warnings.

* To test with multiple Python version and Sphinx versions, run `tox`_.

* Run `tox -e python3.9-sphinx3.4` to run tox with a specific Python
  and Sphinx version.

* Each commit to master, and each pull request to the master branch is
  tested with a few different tests. See the actions tab for the
  results of each run, or click on the checkmark (✔ or ✘) listed with
  each commit.

.. _pytest: https://www.pytest.org/
.. _tox: https://tox.readthedocs.io/


Supported versions
==================

* See `.github/workflows/tests.yml` for a list of which version are
  tested for by GitHub after each pull request.

* See `tox.ini` for a list of which version are tested for by `tox`.
  These two files should be kept in sync.

* As a rule of thumb, this project supports all Sphinx versions
  starting from the one that came with the previous stable Debian
  distribution (`oldstable/sphinx-doc`_) till the most recent version.
  It supports all Python versions starting with the one that came with
  the previous stable Debian distribution (`oldstable/python3`_).

* Python 2 is no longer supported, and no test is run for it.
  We will consider small pull requests to add Python 2.7 support, if
  you really want to spend this effort.

.. _`oldstable/sphinx-doc`: https://packages.debian.org/oldstable/sphinx-doc
.. _`oldstable/python`: https://packages.debian.org/oldstable/python3


Publishing versions
===================

The code is available on the Python package index at
https://pypi.org/project/sphinxcontrib-restbuilder/.

This section is only relevant for administrators.

Creating a release
------------------

Change the following files::

    CHANGES.rst
    CONTRIBUTORS.txt   (Add new contributors, if any)
    setup.py           (Change version constant)

Commit the changes, add a tag, and upload the changes::

    git add CHANGES.rst CONTRIBUTORS.txt setup.py
    git commit -m "Bump version number to x.y.z"
    git tag -a version-x.y.z HEAD
    git push --tags

Publish a release at GitHub
---------------------------

* Go to https://github.com/sphinx-contrib/restbuilder/releases
* Click the "Draft a new release" button
* Select the tag, and add a Release title (e.g. Sphinx Restbuilder x.y)
  and release notes. I usually only list the most important changes,
  with optional link to CHANGES.rst for more details.

Publish a release at PyPI
-------------------------

Follow the process described at https://packaging.python.org/tutorials/distributing-packages/.

Install requirements::

    pip install --upgrade pip
    pip install setuptools wheel twine

Create both a source (.tar.gz) and wheel (.whl) distribution::

    python setup.py sdist
    python setup.py bdist_wheel --universal

Upload all that was created to PyPI::

    ls dist/
    twine upload dist/*