mirror of
				https://github.com/django/django.git
				synced 2025-10-24 22:26:08 +00:00 
			
		
		
		
	Fixed #36485 -- Added lint-docs check in Tox and GitHub Actions.
The `check` docs target now runs spelling, black, and lint, so all current documentation quality checks can be run with a single command. Also documented the lint-docs check's availability and usage.
This commit is contained in:
		
							
								
								
									
										16
									
								
								.github/workflows/docs.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										16
									
								
								.github/workflows/docs.yml
									
									
									
									
										vendored
									
									
								
							| @@ -58,3 +58,19 @@ jobs: | ||||
|               echo "💥 📢 Code blocks in documentation must be reformatted with blacken-docs 📢 💥" | ||||
|           fi; | ||||
|           exit $RESULT | ||||
|  | ||||
|   lint-docs: | ||||
|     runs-on: ubuntu-latest | ||||
|     name: lint-docs | ||||
|     steps: | ||||
|       - name: Checkout | ||||
|         uses: actions/checkout@v4 | ||||
|       - name: Set up Python | ||||
|         uses: actions/setup-python@v5 | ||||
|         with: | ||||
|           python-version: '3.13' | ||||
|       - run: python -m pip install sphinx-lint | ||||
|       - name: Build docs | ||||
|         run: | | ||||
|           cd docs | ||||
|           make lint | ||||
|   | ||||
| @@ -181,6 +181,6 @@ lint: | ||||
| 	@echo | ||||
| 	@echo "Documentation lint complete." | ||||
|  | ||||
| check: spelling black | ||||
| check: spelling black lint | ||||
| 	@echo | ||||
| 	@echo "Style and spelling checks completed." | ||||
|   | ||||
| @@ -69,11 +69,11 @@ command from any place in the Django source tree: | ||||
|     $ tox | ||||
|  | ||||
| By default, ``tox`` runs the test suite with the bundled test settings file for | ||||
| SQLite, ``black``, ``blacken-docs``, ``flake8``, ``isort``, and the | ||||
| documentation spelling checker. In addition to the system dependencies noted | ||||
| elsewhere in this documentation, the command ``python3`` must be on your path | ||||
| and linked to the appropriate version of Python. A list of default environments | ||||
| can be seen as follows: | ||||
| SQLite, ``black``, ``blacken-docs``, ``flake8``, ``isort``, ``lint-docs`` and | ||||
| the documentation spelling checker. In addition to the system dependencies | ||||
| noted elsewhere in this documentation, the command ``python3`` must be on your | ||||
| path and linked to the appropriate version of Python. A list of default | ||||
| environments can be seen as follows: | ||||
|  | ||||
| .. console:: | ||||
|  | ||||
| @@ -84,6 +84,7 @@ can be seen as follows: | ||||
|     flake8>=3.7.0 | ||||
|     docs | ||||
|     isort>=5.1.0 | ||||
|     lint-docs | ||||
|  | ||||
| Testing other Python versions and database backends | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|   | ||||
| @@ -158,8 +158,9 @@ Documentation quality checks | ||||
| ---------------------------- | ||||
|  | ||||
| Several checks help maintain Django's documentation quality, including | ||||
| :ref:`spelling <documentation-spelling-check>` and | ||||
| :ref:`code block formatting <documentation-code-block-format-check>`. | ||||
| :ref:`spelling <documentation-spelling-check>`, | ||||
| :ref:`code block formatting <documentation-code-block-format-check>`, and | ||||
| :ref:`documentation style <documentation-lint-check>`. | ||||
|  | ||||
| These checks are run automatically in CI and must pass before documentation | ||||
| changes can be merged. They can also be run locally with a single command: | ||||
| @@ -215,6 +216,31 @@ installed, run the following command from the ``docs`` directory: | ||||
| The formatter will report any issues by printing them to the terminal and will | ||||
| reformat code blocks where possible. | ||||
|  | ||||
| .. _documentation-lint-check: | ||||
|  | ||||
| Documentation lint check | ||||
| ~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
|  | ||||
| Django's documentation is checked for reStructuredText style and formal issues | ||||
| using :pypi:`sphinx-lint`. This helps catch problems like stray tabs, trailing | ||||
| whitespace, excessive line length, and similar formatting problems. | ||||
|  | ||||
| Once ``sphinx-lint`` is installed, the check can be run with the following | ||||
| command from the ``docs`` directory: | ||||
|  | ||||
| .. console:: | ||||
|  | ||||
|      $ make lint | ||||
|  | ||||
| The command prints any violations to the terminal in the form | ||||
| ``path:line: message``. If problems are encountered: | ||||
|  | ||||
| * Read the message and fix the indicated issue (for example, remove trailing | ||||
|   whitespace, adjust backticks, or replace tabs with spaces). | ||||
| * For long lines consider wrapping text onto new lines or breaking long inline | ||||
|   links into named references. The custom line length check should already skip | ||||
|   common false positives such as headings, tables and long links. | ||||
|  | ||||
| .. _documentation-link-check: | ||||
|  | ||||
| Link check | ||||
|   | ||||
| @@ -205,6 +205,7 @@ if "%1" == "lint" ( | ||||
| ) | ||||
|  | ||||
| if "%1" == "check" ( | ||||
| 	call :run_lint | ||||
| 	call :run_black | ||||
| 	call :run_spelling | ||||
| 	echo. | ||||
|   | ||||
| @@ -39,6 +39,7 @@ backport | ||||
| backported | ||||
| backports | ||||
| backtick | ||||
| backticks | ||||
| backtraces | ||||
| balancer | ||||
| basename | ||||
|   | ||||
							
								
								
									
										11
									
								
								tox.ini
									
									
									
									
									
								
							
							
						
						
									
										11
									
								
								tox.ini
									
									
									
									
									
								
							| @@ -13,6 +13,7 @@ envlist = | ||||
|     flake8 | ||||
|     docs | ||||
|     isort | ||||
|     lint-docs | ||||
|  | ||||
| # Add environment to use the default python3 installation | ||||
| [testenv:py3] | ||||
| @@ -87,3 +88,13 @@ allowlist_externals = | ||||
| commands = | ||||
|     npm install | ||||
|     npm test | ||||
|  | ||||
| [testenv:lint-docs] | ||||
| basepython = python3 | ||||
| usedevelop = false | ||||
| allowlist_externals = | ||||
|     make | ||||
| deps = sphinx-lint | ||||
| changedir = docs | ||||
| commands = | ||||
|     make lint | ||||
|   | ||||
		Reference in New Issue
	
	Block a user