WordPress / openverse

Openverse is a search engine for openly-licensed media. This monorepo includes all application code.
https://openverse.org
MIT License
255 stars 204 forks source link

Update python dev dependencies (major) #5086

Closed openverse-bot closed 1 month ago

openverse-bot commented 1 month ago

This PR contains the following updates:

Package Type Update Change
myst-parser tool.pdm.dev-dependencies major >=3.0.1, <4 -> >=4, <5
pgcli tool.pdm.dev-dependencies major >=3.5.0, <4 -> >=4.1, <5
pytest (changelog) tool.pdm.dev-dependencies major ~=7.4 -> ~=8.3
pytest (changelog) tool.pdm.dev-dependencies major >=7.4.4, <8 -> >=8.3.3, <9
pytest-sugar tool.pdm.dev-dependencies major ~=0.9 -> ~=1.0
pytest-sugar tool.pdm.dev-dependencies major >=0.9.7, <0.10 -> >=1, <1.1
setuptools (changelog) tool.pdm.dev-dependencies major >=69.5.1,<70 -> >=75.2,<76
sphinx (changelog) tool.pdm.dev-dependencies major >=7.3.7, <8 -> >=8.1.3, <9
sphinxcontrib-mermaid (changelog) tool.pdm.dev-dependencies major >=0.9.2, <0.10 -> >=1, <1.1

Release Notes

executablebooks/MyST-Parser (myst-parser) ### [`v4.0.0`](https://redirect.github.com/executablebooks/MyST-Parser/blob/HEAD/CHANGELOG.md#400---2024-08-05) [Compare Source](https://redirect.github.com/executablebooks/MyST-Parser/compare/v3.0.1...v4.0.0) This release bumps the supported versions of: - Python to `3.10` and greater - Sphinx to `>=7,<9` - Docutils to `>=0.19,<0.22` Additionally, footnotes are now parsed similar to the corresponding reStructuredText, in that resolution (between definitions and references) and ordering is now deferred to transforms on the doctree (in ). This allows for the proper interaction with other docutils/sphinx transforms, including those that perform translations, and logging of warnings for duplicate/unreferenced footnote definitions and also for footnote references with no definitions. See the [footnotes guide](#syntax/footnotes) for more information. **Full Changelog**: [v3.0.1...v4.0.0](https://redirect.github.com/executablebooks/MyST-Parser/compare/v3.0.1...v4.0.0)
pytest-dev/pytest (pytest) ### [`v8.3.3`](https://redirect.github.com/pytest-dev/pytest/releases/tag/8.3.3) [Compare Source](https://redirect.github.com/pytest-dev/pytest/compare/8.3.2...8.3.3) # pytest 8.3.3 (2024-09-09) ## Bug fixes - [#​12446](https://redirect.github.com/pytest-dev/pytest/issues/12446): Avoid calling `@property` (and other instance descriptors) during fixture discovery -- by `asottile`{.interpreted-text role="user"} - [#​12659](https://redirect.github.com/pytest-dev/pytest/issues/12659): Fixed the issue of not displaying assertion failure differences when using the parameter `--import-mode=importlib` in pytest>=8.1. - [#​12667](https://redirect.github.com/pytest-dev/pytest/issues/12667): Fixed a regression where type change in \[ExceptionInfo.errisinstance]{.title-ref} caused \[mypy]{.title-ref} to fail. - [#​12744](https://redirect.github.com/pytest-dev/pytest/issues/12744): Fixed typing compatibility with Python 3.9 or less -- replaced \[typing.Self]{.title-ref} with \[typing_extensions.Self]{.title-ref} -- by `Avasam`{.interpreted-text role="user"} - [#​12745](https://redirect.github.com/pytest-dev/pytest/issues/12745): Fixed an issue with backslashes being incorrectly converted in nodeid paths on Windows, ensuring consistent path handling across environments. - [#​6682](https://redirect.github.com/pytest-dev/pytest/issues/6682): Fixed bug where the verbosity levels where not being respected when printing the "msg" part of failed assertion (as in `assert condition, msg`). - [#​9422](https://redirect.github.com/pytest-dev/pytest/issues/9422): Fix bug where disabling the terminal plugin via `-p no:terminal` would cause crashes related to missing the `verbose` option. \-- by `GTowers1`{.interpreted-text role="user"} ## Improved documentation - [#​12663](https://redirect.github.com/pytest-dev/pytest/issues/12663): Clarify that the \[pytest_deselected]{.title-ref} hook should be called from \[pytest_collection_modifyitems]{.title-ref} hook implementations when items are deselected. - [#​12678](https://redirect.github.com/pytest-dev/pytest/issues/12678): Remove erroneous quotes from \[tmp_path_retention_policy]{.title-ref} example in docs. ## Miscellaneous internal changes - [#​12769](https://redirect.github.com/pytest-dev/pytest/issues/12769): Fix typos discovered by codespell and add codespell to pre-commit hooks. ### [`v8.3.2`](https://redirect.github.com/pytest-dev/pytest/releases/tag/8.3.2) [Compare Source](https://redirect.github.com/pytest-dev/pytest/compare/8.3.1...8.3.2) ### pytest 8.3.2 (2024-07-24) #### Bug fixes - [#​12652](https://redirect.github.com/pytest-dev/pytest/issues/12652): Resolve regression \[conda]{.title-ref} environments where no longer being automatically detected. \-- by `RonnyPfannschmidt`{.interpreted-text role="user"} ### [`v8.3.1`](https://redirect.github.com/pytest-dev/pytest/releases/tag/8.3.1) [Compare Source](https://redirect.github.com/pytest-dev/pytest/compare/8.3.0...8.3.1) # pytest 8.3.1 (2024-07-20) The 8.3.0 release failed to include the change notes and docs for the release. This patch release remedies this. There are no other changes. ### [`v8.3.0`](https://redirect.github.com/pytest-dev/pytest/releases/tag/8.3.0) [Compare Source](https://redirect.github.com/pytest-dev/pytest/compare/8.2.2...8.3.0) ##### pytest 8.3.0 (2024-07-20) ##### New features - [#​12231](https://redirect.github.com/pytest-dev/pytest/issues/12231): Added \[--xfail-tb]{.title-ref} flag, which turns on traceback output for XFAIL results. - If the \[--xfail-tb]{.title-ref} flag is not given, tracebacks for XFAIL results are NOT shown. - The style of traceback for XFAIL is set with \[--tb]{.title-ref}, and can be \[auto|long|short|line|native|no]{.title-ref}. - Note: Even if you have \[--xfail-tb]{.title-ref} set, you won't see them if \[--tb=no]{.title-ref}. Some history: With pytest 8.0, \[-rx]{.title-ref} or \[-ra]{.title-ref} would not only turn on summary reports for xfail, but also report the tracebacks for xfail results. This caused issues with some projects that utilize xfail, but don't want to see all of the xfail tracebacks. This change detaches xfail tracebacks from \[-rx]{.title-ref}, and now we turn on xfail tracebacks with \[--xfail-tb]{.title-ref}. With this, the default \[-rx]{.title-ref}/ \[-ra]{.title-ref} behavior is identical to pre-8.0 with respect to xfail tracebacks. While this is a behavior change, it brings default behavior back to pre-8.0.0 behavior, which ultimately was considered the better course of action. - [#​12281](https://redirect.github.com/pytest-dev/pytest/issues/12281): Added support for keyword matching in marker expressions. Now tests can be selected by marker keyword arguments. Supported values are `int`{.interpreted-text role="class"}, (unescaped) `str`{.interpreted-text role="class"}, `bool`{.interpreted-text role="class"} & `None`{.interpreted-text role="data"}. See `marker examples `{.interpreted-text role="ref"} for more information. \-- by `lovetheguitar`{.interpreted-text role="user"} - [#​12567](https://redirect.github.com/pytest-dev/pytest/issues/12567): Added `--no-fold-skipped` command line option. If this option is set, then skipped tests in short summary are no longer grouped by reason but all tests are printed individually with their nodeid in the same way as other statuses. \-- by `pbrezina`{.interpreted-text role="user"} ##### Improvements in existing functionality - [#​12469](https://redirect.github.com/pytest-dev/pytest/issues/12469): The console output now uses the "third-party plugins" terminology, replacing the previously established but confusing and outdated reference to `setuptools `{.interpreted-text role="std:doc"} \-- by `webknjaz`{.interpreted-text role="user"}. - [#​12544](https://redirect.github.com/pytest-dev/pytest/issues/12544), [#​12545](https://redirect.github.com/pytest-dev/pytest/issues/12545): Python virtual environment detection was improved by checking for a `pyvenv.cfg`{.interpreted-text role="file"} file, ensuring reliable detection on various platforms -- by `zachsnickers`{.interpreted-text role="user"}. - [#​2871](https://redirect.github.com/pytest-dev/pytest/issues/2871): Do not truncate arguments to functions in output when running with \[-vvv]{.title-ref}. - [#​389](https://redirect.github.com/pytest-dev/pytest/issues/389): The readability of assertion introspection of bound methods has been enhanced \-- by `farbodahm`{.interpreted-text role="user"}, `webknjaz`{.interpreted-text role="user"}, `obestwalter`{.interpreted-text role="user"}, `flub`{.interpreted-text role="user"} and `glyphack`{.interpreted-text role="user"}. Earlier, it was like: ```console =================================== FAILURES =================================== _____________________________________ test _____________________________________ def test(): > assert Help().fun() == 2 E assert 1 == 2 E + where 1 = >() E + where > = .fun E + where = Help() example.py:7: AssertionError =========================== 1 failed in 0.03 seconds =========================== ``` And now it's like: ```console =================================== FAILURES =================================== _____________________________________ test _____________________________________ def test(): > assert Help().fun() == 2 E assert 1 == 2 E + where 1 = fun() E + where fun = .fun E + where = Help() test_local.py:13: AssertionError =========================== 1 failed in 0.03 seconds =========================== ``` - [#​7662](https://redirect.github.com/pytest-dev/pytest/issues/7662): Added timezone information to the testsuite timestamp in the JUnit XML report. ##### Bug fixes - [#​11706](https://redirect.github.com/pytest-dev/pytest/issues/11706): Fixed reporting of teardown errors in higher-scoped fixtures when using \[--maxfail]{.title-ref} or \[--stepwise]{.title-ref}. Originally added in pytest 8.0.0, but reverted in 8.0.2 due to a regression in pytest-xdist. This regression was fixed in pytest-xdist 3.6.1. - [#​11797](https://redirect.github.com/pytest-dev/pytest/issues/11797): `pytest.approx`{.interpreted-text role="func"} now correctly handles `Sequence `{.interpreted-text role="class"}-like objects. - [#​12204](https://redirect.github.com/pytest-dev/pytest/issues/12204), [#​12264](https://redirect.github.com/pytest-dev/pytest/issues/12264): Fixed a regression in pytest 8.0 where tracebacks get longer and longer when multiple tests fail due to a shared higher-scope fixture which raised -- by `bluetech`{.interpreted-text role="user"}. Also fixed a similar regression in pytest 5.4 for collectors which raise during setup. The fix necessitated internal changes which may affect some plugins: - `FixtureDef.cached_result[2]` is now a tuple `(exc, tb)` instead of `exc`. - `SetupState.stack` failures are now a tuple `(exc, tb)` instead of `exc`. - [#​12275](https://redirect.github.com/pytest-dev/pytest/issues/12275): Fixed collection error upon encountering an `abstract `{.interpreted-text role="mod"} class, including abstract \[unittest.TestCase]{.title-ref} subclasses. - [#​12328](https://redirect.github.com/pytest-dev/pytest/issues/12328): Fixed a regression in pytest 8.0.0 where package-scoped parameterized items were not correctly reordered to minimize setups/teardowns in some cases. - [#​12424](https://redirect.github.com/pytest-dev/pytest/issues/12424): Fixed crash with \[assert testcase is not None]{.title-ref} assertion failure when re-running unittest tests using plugins like pytest-rerunfailures. Regressed in 8.2.2. - [#​12472](https://redirect.github.com/pytest-dev/pytest/issues/12472): Fixed a crash when returning category `"error"` or `"failed"` with a custom test status from `pytest_report_teststatus`{.interpreted-text role="hook"} hook -- `pbrezina`{.interpreted-text role="user"}. - [#​12505](https://redirect.github.com/pytest-dev/pytest/issues/12505): Improved handling of invalid regex patterns in `pytest.raises(match=r'...') `{.interpreted-text role="func"} by providing a clear error message. - [#​12580](https://redirect.github.com/pytest-dev/pytest/issues/12580): Fixed a crash when using the cache class on Windows and the cache directory was created concurrently. - [#​6962](https://redirect.github.com/pytest-dev/pytest/issues/6962): Parametrization parameters are now compared using \[==]{.title-ref} instead of \[is]{.title-ref} (\[is]{.title-ref} is still used as a fallback if the parameter does not support \[==]{.title-ref}). This fixes use of parameters such as lists, which have a different \[id]{.title-ref} but compare equal, causing fixtures to be re-computed instead of being cached. - [#​7166](https://redirect.github.com/pytest-dev/pytest/issues/7166): Fixed progress percentages (the `[ 87%]` at the edge of the screen) sometimes not aligning correctly when running with pytest-xdist `-n`. ##### Improved documentation - [#​12153](https://redirect.github.com/pytest-dev/pytest/issues/12153): Documented using `PYTEST_VERSION`{.interpreted-text role="envvar"} to detect if code is running from within a pytest run. - [#​12469](https://redirect.github.com/pytest-dev/pytest/issues/12469): The external plugin mentions in the documentation now avoid mentioning `setuptools entry-points `{.interpreted-text role="std:doc"} as the concept is much more generic nowadays. Instead, the terminology of "external", "installed", or "third-party" plugins (or packages) replaces that. \-- by `webknjaz`{.interpreted-text role="user"} - [#​12577](https://redirect.github.com/pytest-dev/pytest/issues/12577): \[CI]{.title-ref} and \[BUILD_NUMBER]{.title-ref} environment variables role is discribed in the reference doc. They now also appear when doing \[pytest -h]{.title-ref} \-- by `MarcBresson`{.interpreted-text role="user"}. ##### Contributor-facing changes - [#​12467](https://redirect.github.com/pytest-dev/pytest/issues/12467): Migrated all internal type-annotations to the python3.10+ style by using the \[annotations]{.title-ref} future import. \-- by `RonnyPfannschmidt`{.interpreted-text role="user"} - [#​11771](https://redirect.github.com/pytest-dev/pytest/issues/11771), [#​12557](https://redirect.github.com/pytest-dev/pytest/issues/12557): The PyPy runtime version has been updated to 3.9 from 3.8 that introduced a flaky bug at the garbage collector which was not expected to fix there as the 3.8 is EoL. \-- by `x612skm`{.interpreted-text role="user"} - [#​12493](https://redirect.github.com/pytest-dev/pytest/issues/12493): The change log draft preview integration has been refactored to use a third party extension `sphinxcontib-towncrier`. The previous in-repo script was putting the change log preview file at `doc/en/_changelog_towncrier_draft.rst`{.interpreted-text role="file"}. Said file is no longer ignored in Git and might show up among untracked files in the development environments of the contributors. To address that, the contributors can run the following command that will clean it up: ```console $ git clean -x -i -- doc/en/_changelog_towncrier_draft.rst ``` \-- by `webknjaz`{.interpreted-text role="user"} - [#​12498](https://redirect.github.com/pytest-dev/pytest/issues/12498): All the undocumented `tox` environments now have descriptions. They can be listed in one's development environment by invoking `tox -av` in a terminal. \-- by `webknjaz`{.interpreted-text role="user"} - [#​12501](https://redirect.github.com/pytest-dev/pytest/issues/12501): The changelog configuration has been updated to introduce more accurate audience-tailored categories. Previously, there was a `trivial` change log fragment type with an unclear and broad meaning. It was removed and we now have `contrib`, `misc` and `packaging` in place of it. The new change note types target the readers who are downstream packagers and project contributors. Additionally, the miscellaneous section is kept for unspecified updates that do not fit anywhere else. \-- by `webknjaz`{.interpreted-text role="user"} - [#​12502](https://redirect.github.com/pytest-dev/pytest/issues/12502): The UX of the GitHub automation making pull requests to update the plugin list has been updated. Previously, the maintainers had to close the automatically created pull requests and re-open them to trigger the CI runs. From now on, they only need to click the \[Ready for review]{.title-ref} button instead. \-- by `webknjaz`{.interpreted-text role="user"} - [#​12522](https://redirect.github.com/pytest-dev/pytest/issues/12522): The `:pull:` RST role has been replaced with a shorter `:pr:` due to starting to use the implementation from the third-party `sphinx-issues`{.interpreted-text role="pypi"} Sphinx extension \-- by `webknjaz`{.interpreted-text role="user"}. - [#​12531](https://redirect.github.com/pytest-dev/pytest/issues/12531): The coverage reporting configuration has been updated to exclude pytest's own tests marked as expected to fail from the coverage report. This has an effect of reducing the influence of flaky tests on the resulting number. \-- by `webknjaz`{.interpreted-text role="user"} - [#​12533](https://redirect.github.com/pytest-dev/pytest/issues/12533): The `extlinks` Sphinx extension is no longer enabled. The `:bpo:` role it used to declare has been removed with that. BPO itself has migrated to GitHub some years ago and it is possible to link the respective issues by using their GitHub issue numbers and the `:issue:` role that the `sphinx-issues` extension implements. \-- by `webknjaz`{.interpreted-text role="user"} - [#​12562](https://redirect.github.com/pytest-dev/pytest/issues/12562): Possible typos in using the `:user:` RST role is now being linted through the pre-commit tool integration -- by `webknjaz`{.interpreted-text role="user"}. ### [`v8.2.2`](https://redirect.github.com/pytest-dev/pytest/releases/tag/8.2.2) [Compare Source](https://redirect.github.com/pytest-dev/pytest/compare/8.2.1...8.2.2) ### pytest 8.2.2 (2024-06-04) #### Bug Fixes - [#​12355](https://redirect.github.com/pytest-dev/pytest/issues/12355): Fix possible catastrophic performance slowdown on a certain parametrization pattern involving many higher-scoped parameters. - [#​12367](https://redirect.github.com/pytest-dev/pytest/issues/12367): Fix a regression in pytest 8.2.0 where unittest class instances (a fresh one is created for each test) were not released promptly on test teardown but only on session teardown. - [#​12381](https://redirect.github.com/pytest-dev/pytest/issues/12381): Fix possible "Directory not empty" crashes arising from concurent cache dir (`.pytest_cache`) creation. Regressed in pytest 8.2.0. #### Improved Documentation - [#​12290](https://redirect.github.com/pytest-dev/pytest/issues/12290): Updated Sphinx theme to use Furo instead of Flask, enabling Dark mode theme. - [#​12356](https://redirect.github.com/pytest-dev/pytest/issues/12356): Added a subsection to the documentation for debugging flaky tests to mention lack of thread safety in pytest as a possible source of flakyness. - [#​12363](https://redirect.github.com/pytest-dev/pytest/issues/12363): The documentation webpages now links to a canonical version to reduce outdated documentation in search engine results. ### [`v8.2.1`](https://redirect.github.com/pytest-dev/pytest/releases/tag/8.2.1) [Compare Source](https://redirect.github.com/pytest-dev/pytest/compare/8.2.0...8.2.1) # pytest 8.2.1 (2024-05-19) ## Improvements - [#​12334](https://redirect.github.com/pytest-dev/pytest/issues/12334): Support for Python 3.13 (beta1 at the time of writing). ## Bug Fixes - [#​12120](https://redirect.github.com/pytest-dev/pytest/issues/12120): Fix \[PermissionError]{.title-ref} crashes arising from directories which are not selected on the command-line. - [#​12191](https://redirect.github.com/pytest-dev/pytest/issues/12191): Keyboard interrupts and system exits are now properly handled during the test collection. - [#​12300](https://redirect.github.com/pytest-dev/pytest/issues/12300): Fixed handling of 'Function not implemented' error under squashfuse_ll, which is a different way to say that the mountpoint is read-only. - [#​12308](https://redirect.github.com/pytest-dev/pytest/issues/12308): Fix a regression in pytest 8.2.0 where the permissions of automatically-created `.pytest_cache` directories became `rwx------` instead of the expected `rwxr-xr-x`. ## Trivial/Internal Changes - [#​12333](https://redirect.github.com/pytest-dev/pytest/issues/12333): pytest releases are now attested using the recent [Artifact Attestation](https://github.blog/2024-05-02-introducing-artifact-attestations-now-in-public-beta/) support from GitHub, allowing users to verify the provenance of pytest's sdist and wheel artifacts. ### [`v8.2.0`](https://redirect.github.com/pytest-dev/pytest/releases/tag/8.2.0) [Compare Source](https://redirect.github.com/pytest-dev/pytest/compare/8.1.2...8.2.0) ### pytest 8.2.0 (2024-04-27) #### Deprecations - [#​12069](https://redirect.github.com/pytest-dev/pytest/issues/12069): A deprecation warning is now raised when implementations of one of the following hooks request a deprecated `py.path.local` parameter instead of the `pathlib.Path` parameter which replaced it: - `pytest_ignore_collect`{.interpreted-text role="hook"} - the `path` parameter - use `collection_path` instead. - `pytest_collect_file`{.interpreted-text role="hook"} - the `path` parameter - use `file_path` instead. - `pytest_pycollect_makemodule`{.interpreted-text role="hook"} - the `path` parameter - use `module_path` instead. - `pytest_report_header`{.interpreted-text role="hook"} - the `startdir` parameter - use `start_path` instead. - `pytest_report_collectionfinish`{.interpreted-text role="hook"} - the `startdir` parameter - use `start_path` instead. The replacement parameters are available since pytest 7.0.0. The old parameters will be removed in pytest 9.0.0. See `legacy-path-hooks-deprecated`{.interpreted-text role="ref"} for more details. #### Features - [#​11871](https://redirect.github.com/pytest-dev/pytest/issues/11871): Added support for reading command line arguments from a file using the prefix character `@`, like e.g.: `pytest @​tests.txt`. The file must have one argument per line. See `Read arguments from file `{.interpreted-text role="ref"} for details. #### Improvements - [#​11523](https://redirect.github.com/pytest-dev/pytest/issues/11523): `pytest.importorskip`{.interpreted-text role="func"} will now issue a warning if the module could be found, but raised `ImportError`{.interpreted-text role="class"} instead of `ModuleNotFoundError`{.interpreted-text role="class"}. The warning can be suppressed by passing `exc_type=ImportError` to `pytest.importorskip`{.interpreted-text role="func"}. See `import-or-skip-import-error`{.interpreted-text role="ref"} for details. - [#​11728](https://redirect.github.com/pytest-dev/pytest/issues/11728): For `unittest`-based tests, exceptions during class cleanup (as raised by functions registered with `TestCase.addClassCleanup `{.interpreted-text role="meth"}) are now reported instead of silently failing. - [#​11777](https://redirect.github.com/pytest-dev/pytest/issues/11777): Text is no longer truncated in the `short test summary info` section when `-vv` is given. - [#​12112](https://redirect.github.com/pytest-dev/pytest/issues/12112): Improved namespace packages detection when `consider_namespace_packages`{.interpreted-text role="confval"} is enabled, covering more situations (like editable installs). - [#​9502](https://redirect.github.com/pytest-dev/pytest/issues/9502): Added `PYTEST_VERSION`{.interpreted-text role="envvar"} environment variable which is defined at the start of the pytest session and undefined afterwards. It contains the value of `pytest.__version__`, and among other things can be used to easily check if code is running from within a pytest run. #### Bug Fixes - [#​12065](https://redirect.github.com/pytest-dev/pytest/issues/12065): Fixed a regression in pytest 8.0.0 where test classes containing `setup_method` and tests using `@staticmethod` or `@classmethod` would crash with `AttributeError: 'NoneType' object has no attribute 'setup_method'`. Now the `request.instance `{.interpreted-text role="attr"} attribute of tests using `@staticmethod` and `@classmethod` is no longer `None`, but a fresh instance of the class, like in non-static methods. Previously it was `None`, and all fixtures of such tests would share a single `self`. - [#​12135](https://redirect.github.com/pytest-dev/pytest/issues/12135): Fixed issue where fixtures adding their finalizer multiple times to fixtures they request would cause unreliable and non-intuitive teardown ordering in some instances. - [#​12194](https://redirect.github.com/pytest-dev/pytest/issues/12194): Fixed a bug with `--importmode=importlib` and `--doctest-modules` where child modules did not appear as attributes in parent modules. - [#​1489](https://redirect.github.com/pytest-dev/pytest/issues/1489): Fixed some instances where teardown of higher-scoped fixtures was not happening in the reverse order they were initialized in. #### Trivial/Internal Changes - [#​12069](https://redirect.github.com/pytest-dev/pytest/issues/12069): `pluggy>=1.5.0` is now required. - [#​12167](https://redirect.github.com/pytest-dev/pytest/issues/12167): `cache `{.interpreted-text role="ref"}: create supporting files (`CACHEDIR.TAG`, `.gitignore`, etc.) in a temporary directory to provide atomic semantics. ### [`v8.1.2`](https://redirect.github.com/pytest-dev/pytest/releases/tag/8.1.2) [Compare Source](https://redirect.github.com/pytest-dev/pytest/compare/8.1.1...8.1.2) ### pytest 8.1.2 (2024-04-26) #### Bug Fixes - [#​12114](https://redirect.github.com/pytest-dev/pytest/issues/12114): Fixed error in `pytest.approx`{.interpreted-text role="func"} when used with \[numpy]{.title-ref} arrays and comparing with other types. ### [`v8.1.1`](https://redirect.github.com/pytest-dev/pytest/releases/tag/8.1.1) [Compare Source](https://redirect.github.com/pytest-dev/pytest/compare/8.1.0...8.1.1) ### pytest 8.1.1 (2024-03-08) ::: {.note} ::: {.title} Note ::: This release is not a usual bug fix release -- it contains features and improvements, being a follow up to `8.1.0`, which has been yanked from PyPI. ::: #### Features - [#​11475](https://redirect.github.com/pytest-dev/pytest/issues/11475): Added the new `consider_namespace_packages`{.interpreted-text role="confval"} configuration option, defaulting to `False`. If set to `True`, pytest will attempt to identify modules that are part of [namespace packages](https://packaging.python.org/en/latest/guides/packaging-namespace-packages) when importing modules. - [#​11653](https://redirect.github.com/pytest-dev/pytest/issues/11653): Added the new `verbosity_test_cases`{.interpreted-text role="confval"} configuration option for fine-grained control of test execution verbosity. See `Fine-grained verbosity `{.interpreted-text role="ref"} for more details. #### Improvements - [#​10865](https://redirect.github.com/pytest-dev/pytest/issues/10865): `pytest.warns`{.interpreted-text role="func"} now validates that `warnings.warn`{.interpreted-text role="func"} was called with a \[str]{.title-ref} or a \[Warning]{.title-ref}. Currently in Python it is possible to use other types, however this causes an exception when `warnings.filterwarnings`{.interpreted-text role="func"} is used to filter those warnings (see [CPython #​103577](https://redirect.github.com/python/cpython/issues/103577) for a discussion). While this can be considered a bug in CPython, we decided to put guards in pytest as the error message produced without this check in place is confusing. - [#​11311](https://redirect.github.com/pytest-dev/pytest/issues/11311): When using `--override-ini` for paths in invocations without a configuration file defined, the current working directory is used as the relative directory. Previoulsy this would raise an `AssertionError`{.interpreted-text role="class"}. - [#​11475](https://redirect.github.com/pytest-dev/pytest/issues/11475): `--import-mode=importlib `{.interpreted-text role="ref"} now tries to import modules using the standard import mechanism (but still without changing :py`sys.path`{.interpreted-text role="data"}), falling back to importing modules directly only if that fails. This means that installed packages will be imported under their canonical name if possible first, for example `app.core.models`, instead of having the module name always be derived from their path (for example `.env310.lib.site_packages.app.core.models`). - [#​11801](https://redirect.github.com/pytest-dev/pytest/issues/11801): Added the `iter_parents() <_pytest.nodes.Node.iter_parents>`{.interpreted-text role="func"} helper method on nodes. It is similar to `listchain <_pytest.nodes.Node.listchain>`{.interpreted-text role="func"}, but goes from bottom to top, and returns an iterator, not a list. - [#​11850](https://redirect.github.com/pytest-dev/pytest/issues/11850): Added support for `sys.last_exc`{.interpreted-text role="data"} for post-mortem debugging on Python>=3.12. - [#​11962](https://redirect.github.com/pytest-dev/pytest/issues/11962): In case no other suitable candidates for configuration file are found, a `pyproject.toml` (even without a `[tool.pytest.ini_options]` table) will be considered as the configuration file and define the `rootdir`. - [#​11978](https://redirect.github.com/pytest-dev/pytest/issues/11978): Add `--log-file-mode` option to the logging plugin, enabling appending to log-files. This option accepts either `"w"` or `"a"` and defaults to `"w"`. Previously, the mode was hard-coded to be `"w"` which truncates the file before logging. - [#​12047](https://redirect.github.com/pytest-dev/pytest/issues/12047): When multiple finalizers of a fixture raise an exception, now all exceptions are reported as an exception group. Previously, only the first exception was reported. #### Bug Fixes - [#​11475](https://redirect.github.com/pytest-dev/pytest/issues/11475): Fixed regression where `--importmode=importlib` would import non-test modules more than once. - [#​11904](https://redirect.github.com/pytest-dev/pytest/issues/11904): Fixed a regression in pytest 8.0.0 that would cause test collection to fail due to permission errors when using `--pyargs`. This change improves the collection tree for tests specified using `--pyargs`, see `12043`{.interpreted-text role="pull"} for a comparison with pytest 8.0 and <8. - [#​12011](https://redirect.github.com/pytest-dev/pytest/issues/12011): Fixed a regression in 8.0.1 whereby `setup_module` xunit-style fixtures are not executed when `--doctest-modules` is passed. - [#​12014](https://redirect.github.com/pytest-dev/pytest/issues/12014): Fix the `stacklevel` used when warning about marks used on fixtures. - [#​12039](https://redirect.github.com/pytest-dev/pytest/issues/12039): Fixed a regression in `8.0.2` where tests created using `tmp_path`{.interpreted-text role="fixture"} have been collected multiple times in CI under Windows. #### Improved Documentation - [#​11790](https://redirect.github.com/pytest-dev/pytest/issues/11790): Documented the retention of temporary directories created using the `tmp_path` fixture in more detail. #### Trivial/Internal Changes - [#​11785](https://redirect.github.com/pytest-dev/pytest/issues/11785): Some changes were made to private functions which may affect plugins which access them: - `FixtureManager._getautousenames()` now takes a `Node` itself instead of the nodeid. - `FixtureManager.getfixturedefs()` now takes the `Node` itself instead of the nodeid. - The `_pytest.nodes.iterparentnodeids()` function is removed without replacement. Prefer to traverse the node hierarchy itself instead. If you really need to, copy the function from the previous pytest release. - [#​12069](https://redirect.github.com/pytest-dev/pytest/issues/12069): Delayed the deprecation of the following features to `9.0.0`: - `node-ctor-fspath-deprecation`{.interpreted-text role="ref"}. - `legacy-path-hooks-deprecated`{.interpreted-text role="ref"}. It was discovered after `8.1.0` was released that the warnings about the impeding removal were not being displayed, so the team decided to revert the removal. This is the reason for `8.1.0` being yanked. ### pytest 8.1.0 (YANKED) ::: {.note} ::: {.title} Note ::: This release has been **yanked**: it broke some plugins without the proper warning period, due to some warnings not showing up as expected. See [#​12069](https://redirect.github.com/pytest-dev/pytest/issues/12069). ::: ### [`v8.1.0`](https://redirect.github.com/pytest-dev/pytest/releases/tag/8.1.0) [Compare Source](https://redirect.github.com/pytest-dev/pytest/compare/8.0.2...8.1.0) ### pytest 8.1.0 (YANKED) > \[!IMPORTANT]\ > This release has been **yanked**: it broke some plugins without the proper warning period, due to some warnings not showing up as expected. See [#​12069](https://redirect.github.com/pytest-dev/pytest/issues/12069). #### Features - [#​11475](https://redirect.github.com/pytest-dev/pytest/issues/11475): Added the new `consider_namespace_packages`{.interpreted-text role="confval"} configuration option, defaulting to `False`. If set to `True`, pytest will attempt to identify modules that are part of [namespace packages](https://packaging.python.org/en/latest/guides/packaging-namespace-packages) when importing modules. - [#​11653](https://redirect.github.com/pytest-dev/pytest/issues/11653): Added the new `verbosity_test_cases`{.interpreted-text role="confval"} configuration option for fine-grained control of test execution verbosity. See `Fine-grained verbosity `{.interpreted-text role="ref"} for more details. #### Improvements - [#​10865](https://redirect.github.com/pytest-dev/pytest/issues/10865): `pytest.warns`{.interpreted-text role="func"} now validates that `warnings.warn`{.interpreted-text role="func"} was called with a \[str]{.title-ref} or a \[Warning]{.title-ref}. Currently in Python it is possible to use other types, however this causes an exception when `warnings.filterwarnings`{.interpreted-text role="func"} is used to filter those warnings (see [CPython #​103577](https://redirect.github.com/python/cpython/issues/103577) for a discussion). While this can be considered a bug in CPython, we decided to put guards in pytest as the error message produced without this check in place is confusing. - [#​11311](https://redirect.github.com/pytest-dev/pytest/issues/11311): When using `--override-ini` for paths in invocations without a configuration file defined, the current working directory is used as the relative directory. Previoulsy this would raise an `AssertionError`{.interpreted-text role="class"}. - [#​11475](https://redirect.github.com/pytest-dev/pytest/issues/11475): `--import-mode=importlib `{.interpreted-text role="ref"} now tries to import modules using the standard import mechanism (but still without changing :py`sys.path`{.interpreted-text role="data"}), falling back to importing modules directly only if that fails. This means that installed packages will be imported under their canonical name if possible first, for example `app.core.models`, instead of having the module name always be derived from their path (for example `.env310.lib.site_packages.app.core.models`). - [#​11801](https://redirect.github.com/pytest-dev/pytest/issues/11801): Added the `iter_parents() <_pytest.nodes.Node.iter_parents>`{.interpreted-text role="func"} helper method on nodes. It is similar to `listchain <_pytest.nodes.Node.listchain>`{.interpreted-text role="func"}, but goes from bottom to top, and returns an iterator, not a list. - [#​11850](https://redirect.github.com/pytest-dev/pytest/issues/11850): Added support for `sys.last_exc`{.interpreted-text role="data"} for post-mortem debugging on Python>=3.12. - [#​11962](https://redirect.github.com/pytest-dev/pytest/issues/11962): In case no other suitable candidates for configuration file are found, a `pyproject.toml` (even without a `[tool.pytest.ini_options]` table) will be considered as the configuration file and define the `rootdir`. - [#​11978](https://redirect.github.com/pytest-dev/pytest/issues/11978): Add `--log-file-mode` option to the logging plugin, enabling appending to log-files. This option accepts either `"w"` or `"a"` and defaults to `"w"`. Previously, the mode was hard-coded to be `"w"` which truncates the file before logging. - [#​12047](https://redirect.github.com/pytest-dev/pytest/issues/12047): When multiple finalizers of a fixture raise an exception, now all exceptions are reported as an exception group. Previously, only the first exception was reported. #### Bug Fixes - [#​11904](https://redirect.github.com/pytest-dev/pytest/issues/11904): Fixed a regression in pytest 8.0.0 that would cause test collection to fail due to permission errors when using `--pyargs`. This change improves the collection tree for tests specified using `--pyargs`, see `12043`{.interpreted-text role="pull"} for a comparison with pytest 8.0 and <8. - [#​12011](https://redirect.github.com/pytest-dev/pytest/issues/12011): Fixed a regression in 8.0.1 whereby `setup_module` xunit-style fixtures are not executed when `--doctest-modules` is passed. - [#​12014](https://redirect.github.com/pytest-dev/pytest/issues/12014): Fix the `stacklevel` used when warning about marks used on fixtures. - [#​12039](https://redirect.github.com/pytest-dev/pytest/issues/12039): Fixed a regression in `8.0.2` where tests created using `tmp_path`{.interpreted-text role="fixture"} have been collected multiple times in CI under Windows. #### Improved Documentation - [#​11790](https://redirect.github.com/pytest-dev/pytest/issues/11790): Documented the retention of temporary directories created using the `tmp_path` fixture in more detail. #### Trivial/Internal Changes - [#​11785](https://redirect.github.com/pytest-dev/pytest/issues/11785): Some changes were made to private functions which may affect plugins which access them: - `FixtureManager._getautousenames()` now takes a `Node` itself instead of the nodeid. - `FixtureManager.getfixturedefs()` now takes the `Node` itself instead of the nodeid. - The `_pytest.nodes.iterparentnodeids()` function is removed without replacement. Prefer to traverse the node hierarchy itself instead. If you really need to, copy the function from the previous pytest release. ### [`v8.0.2`](https://redirect.github.com/pytest-dev/pytest/releases/tag/8.0.2) [Compare Source](https://redirect.github.com/pytest-dev/pytest/compare/8.0.1...8.0.2) ### pytest 8.0.2 (2024-02-24) #### Bug Fixes - [#​11895](https://redirect.github.com/pytest-dev/pytest/issues/11895): Fix collection on Windows where initial paths contain the short version of a path (for example `c:\PROGRA~1\tests`). - [#​11953](https://redirect.github.com/pytest-dev/pytest/issues/11953): Fix an `IndexError` crash raising from `getstatementrange_ast`. - [#​12021](https://redirect.github.com/pytest-dev/pytest/issues/12021): Reverted a fix to \[--maxfail]{.title-ref} handling in pytest 8.0.0 because it caused a regression in pytest-xdist whereby session fixture teardowns may get executed multiple times when the max-fails is reached. ### [`v8.0.1`](https://redirect.github.com/pytest-dev/pytest/releases/tag/8.0.1) [Compare Source](https://redirect.github.com/pytest-dev/pytest/compare/8.0.0...8.0.1) ### pytest 8.0.1 (2024-02-16) #### Bug Fixes - [#​11875](https://redirect.github.com/pytest-dev/pytest/issues/11875): Correctly handle errors from `getpass.getuser`{.interpreted-text role="func"} in Python 3.13. - [#​11879](https://redirect.github.com/pytest-dev/pytest/issues/11879): Fix an edge case where `ExceptionInfo._stringify_exception` could crash `pytest.raises`{.interpreted-text role="func"}. - [#​11906](https://redirect.github.com/pytest-dev/pytest/issues/11906): Fix regression with `pytest.warns`{.interpreted-text role="func"} using custom warning subclasses which have more than one parameter in their \[\__init\_\_]{.title-ref}. - [#​11907](https://redirect.github.com/pytest-dev/pytest/issues/11907): Fix a regression in pytest 8.0.0 whereby calling `pytest.skip`{.interpreted-text role="func"} and similar control-flow exceptions within a `pytest.warns()`{.interpreted-text role="func"} block would get suppressed instead of propagating. - [#​11929](https://redirect.github.com/pytest-dev/pytest/issues/11929): Fix a regression in pytest 8.0.0 whereby autouse fixtures defined in a module get ignored by the doctests in the module. - [#​11937](https://redirect.github.com/pytest-dev/pytest/issues/11937): Fix a regression in pytest 8.0.0 whereby items would be collected in reverse order in some circumstances. ### [`v8.0.0`](https://redirect.github.com/pytest-dev/pytest/releases/tag/8.0.0): pytest 8.0.0 (2024-01-27) [Compare Source](https://redirect.github.com/pytest-dev/pytest/compare/7.4.4...8.0.0) See [8.0.0rc1](https://redirect.github.com/pytest-dev/pytest/releases/tag/8.0.0rc1) and [8.0.0rc2](https://redirect.github.com/pytest-dev/pytest/releases/tag/8.0.0rc2) for the full changes since pytest 7.4! ##### Bug Fixes - [#​11842](https://redirect.github.com/pytest-dev/pytest/issues/11842): Properly escape the `reason` of a `skip `{.interpreted-text role="ref"} mark when writing JUnit XML files. - [#​11861](https://redirect.github.com/pytest-dev/pytest/issues/11861): Avoid microsecond exceeds `1_000_000` when using `log-date-format` with `%f` specifier, which might cause the test suite to crash.
Teemu/pytest-sugar (pytest-sugar) ### [`v1.0.0`](https://redirect.github.com/Teemu/pytest-sugar/releases/tag/v1.0.0): pytest-sugar 1.0.0 [Compare Source](https://redirect.github.com/Teemu/pytest-sugar/compare/v0.9.7...v1.0.0) - Add support for pytest 8.x - Drop support for Python 3.7 Thanks to folks to contributed to this release: [@​suutari-ai](https://redirect.github.com/suutari-ai), [@​hugovk](https://redirect.github.com/hugovk), [@​kianmeng](https://redirect.github.com/kianmeng), [@​mattcristal](https://redirect.github.com/mattcristal), and [@​justinmayer](https://redirect.github.com/justinmayer)
pypa/setuptools (setuptools) ### [`v75.2.0`](https://redirect.github.com/pypa/setuptools/compare/v75.1.0...v75.2.0) [Compare Source](https://redirect.github.com/pypa/setuptools/compare/v75.1.0...v75.2.0) ### [`v75.1.0`](https://redirect.github.com/pypa/setuptools/compare/v75.0.0...v75.1.0) [Compare Source](https://redirect.github.com/pypa/setuptools/compare/v75.0.0...v75.1.0) ### [`v75.0.0`](https://redirect.github.com/pypa/setuptools/compare/v74.1.3...v75.0.0) [Compare Source](https://redirect.github.com/pypa/setuptools/compare/v74.1.3...v75.0.0) ### [`v74.1.3`](https://redirect.github.com/pypa/setuptools/compare/v74.1.2...v74.1.3) [Compare Source](https://redirect.github.com/pypa/setuptools/compare/v74.1.2...v74.1.3) ### [`v74.1.2`](https://redirect.github.com/pypa/setuptools/compare/v74.1.1...v74.1.2) [Compare Source](https://redirect.github.com/pypa/setuptools/compare/v74.1.1...v74.1.2) ### [`v74.1.1`](https://redirect.github.com/pypa/setuptools/compare/v74.1.0...v74.1.1) [Compare Source](https://redirect.github.com/pypa/setuptools/compare/v74.1.0...v74.1.1) ### [`v74.1.0`](https://redirect.github.com/pypa/setuptools/compare/v74.0.0...v74.1.0) [Compare Source](https://redirect.github.com/pypa/setuptools/compare/v74.0.0...v74.1.0) ### [`v74.0.0`](https://redirect.github.com/pypa/setuptools/compare/v73.0.1...v74.0.0) [Compare Source](https://redirect.github.com/pypa/setuptools/compare/v73.0.1...v74.0.0) ### [`v73.0.1`](https://redirect.github.com/pypa/setuptools/compare/v73.0.0...v73.0.1) [Compare Source](https://redirect.github.com/pypa/setuptools/compare/v73.0.0...v73.0.1) ### [`v73.0.0`](https://redirect.github.com/pypa/setuptools/compare/v72.2.0...v73.0.0) [Compare Source](https://redirect.github.com/pypa/setuptools/compare/v72.2.0...v73.0.0) ### [`v72.2.0`](https://redirect.github.com/pypa/setuptools/compare/v72.1.0...v72.2.0) [Compare Source](https://redirect.github.com/pypa/setuptools/compare/v72.1.0...v72.2.0) ### [`v72.1.0`](https://redirect.github.com/pypa/setuptools/compare/v72.0.0...v72.1.0) [Compare Source](https://redirect.github.com/pypa/setuptools/compare/v72.0.0...v72.1.0) ### [`v72.0.0`](https://redirect.github.com/pypa/setuptools/compare/v71.1.0...v72.0.0) [Compare Source](https://redirect.github.com/pypa/setuptools/compare/v71.1.0...v72.0.0) ### [`v71.1.0`](https://redirect.github.com/pypa/setuptools/compare/v71.0.4...v71.1.0) [Compare Source](https://redirect.github.com/pypa/setuptools/compare/v71.0.4...v71.1.0) ### [`v71.0.4`](https://redirect.github.com/pypa/setuptools/compare/v71.0.3...v71.0.4) [Compare Source](https://redirect.github.com/pypa/setuptools/compare/v71.0.3...v71.0.4) ### [`v71.0.3`](https://redirect.github.com/pypa/setuptools/compare/v71.0.2...v71.0.3) [Compare Source](https://redirect.github.com/pypa/setuptools/compare/v71.0.2...v71.0.3) ### [`v71.0.2`](https://redirect.github.com/pypa/setuptools/compare/v71.0.1...v71.0.2) [Compare Source](https://redirect.github.com/pypa/setuptools/compare/v71.0.1...v71.0.2) ### [`v71.0.1`](https://redirect.github.com/pypa/setuptools/compare/v71.0.0...v71.0.1) [Compare Source](https://redirect.github.com/pypa/setuptools/compare/v71.0.0...v71.0.1) ### [`v71.0.0`](https://redirect.github.com/pypa/setuptools/compare/v70.3.0...v71.0.0) [Compare Source](https://redirect.github.com/pypa/setuptools/compare/v70.3.0...v71.0.0) ### [`v70.3.0`](https://redirect.github.com/pypa/setuptools/compare/v70.2.0...v70.3.0) [Compare Source](https://redirect.github.com/pypa/setuptools/compare/v70.2.0...v70.3.0) ### [`v70.2.0`](https://redirect.github.com/pypa/setuptools/compare/v70.1.1...v70.2.0) [Compare Source](https://redirect.github.com/pypa/setuptools/compare/v70.1.1...v70.2.0) ### [`v70.1.1`](https://redirect.github.com/pypa/setuptools/compare/v70.1.0...v70.1.1) [Compare Source](https://redirect.github.com/pypa/setuptools/compare/v70.1.0...v70.1.1) ### [`v70.1.0`](https://redirect.github.com/pypa/setuptools/compare/v70.0.0...v70.1.0) [Compare Source](https://redirect.github.com/pypa/setuptools/compare/v70.0.0...v70.1.0) ### [`v70.0.0`](https://redirect.github.com/pypa/setuptools/compare/v69.5.1...v70.0.0) [Compare Source](https://redirect.github.com/pypa/setuptools/compare/v69.5.1...v70.0.0)
sphinx-doc/sphinx (sphinx) ### [`v8.1.3`](https://redirect.github.com/sphinx-doc/sphinx/releases/tag/v8.1.3): Sphinx 8.1.3 [Compare Source](https://redirect.github.com/sphinx-doc/sphinx/compare/v8.1.2...v8.1.3) Changelog: https://www.sphinx-doc.org/en/master/changes/8.1.html ## Bugs fixed - [#​13013](https://redirect.github.com/sphinx-doc/sphinx/issues/13013): Restore support for `cut_lines()` with no object type. Patch by Adam Turner. ### [`v8.1.2`](https://redirect.github.com/sphinx-doc/sphinx/releases/tag/v8.1.2): Sphinx 8.1.2 [Compare Source](https://redirect.github.com/sphinx-doc/sphinx/compare/v8.1.1...v8.1.2) Changelog: https://www.sphinx-doc.org/en/master/changes/8.1.html ## Bugs fixed - [#​13012](https://redirect.github.com/sphinx-doc/sphinx/issues/13012): Expose `sphinx.errors.ExtensionError` in `sphinx.util` for backwards compatibility. This will be removed in Sphinx 9, as exposing the exception in `sphinx.util` was never intentional. `ExtensionError` has been part of `sphinx.errors` since Sphinx 0.9. Patch by Adam Turner. ### [`v8.1.1`](https://redirect.github.com/sphinx-doc/sphinx/releases/tag/v8.1.1): Sphinx 8.1.1 [Compare Source](https://redirect.github.com/sphinx-doc/sphinx/compare/v8.1.0...v8.1.1) Changelog: https://www.sphinx-doc.org/en/master/changes/8.1.html ## Bugs fixed - [#​13006](https://redirect.github.com/sphinx-doc/sphinx/issues/13006): Use the preferred https://www.cve.org/ URL for the `:cve:` role. Patch by Hugo van Kemenade. - [#​13007](https://redirect.github.com/sphinx-doc/sphinx/issues/13007): LaTeX: Improve resiliency when the required `fontawesome` or `fontawesome5` packages are not installed. Patch by Jean-François B. ### [`v8.1.0`](https://redirect.github.com/sphinx-doc/sphinx/releases/tag/v8.1.0): Sphinx 8.1.0 [Compare Source](https://redirect.github.com/sphinx-doc/sphinx/compare/v8.0.2...v8.1.0) Changelog: https://www.sphinx-doc.org/en/master/changes/8.1.html ## Dependencies - [#​12756](https://redirect.github.com/sphinx-doc/sphinx/issues/12756): Add lower-bounds to the `sphinxcontrib-*` dependencies. Patch by Adam Turner. - [#​12833](https://redirect.github.com/sphinx-doc/sphinx/issues/12833): Update the LaTeX `parskip` package from 2001 to 2018. Patch by Jean-François B. ## Incompatible changes - [#​12763](https://redirect.github.com/sphinx-doc/sphinx/issues/12763): Remove unused internal class `sphinx.util.Tee`. Patch by Adam Turner. - [#​12822](https://redirect.github.com/sphinx-doc/sphinx/issues/12822): LaTeX: for Unicode engines, the `fvset` default is changed to `'\\fvset{fontsize=auto}'` from `'\\fvset{fontsize=\\small}'`. Code-blocks are unchanged as FreeMono is now loaded with `Scale=0.9`. An adjustment to existing projects is needed only if they used a custom `fontpkg` configuration and did not set `fvset`. Patch by Jean-François B. - [#​12875](https://redirect.github.com/sphinx-doc/sphinx/issues/12875): Disable smartquotes for languages: `zh_CN` and `zh_TW` by default. Patch by A. Rafey Khan. ## Deprecated - [#​12762](https://redirect.github.com/sphinx-doc/sphinx/issues/12762): Deprecate `sphinx.util.import_object`. Use `importlib.import_module()` instead. Patch by Adam Turner. - [#​12766](https://redirect.github.com/sphinx-doc/sphinx/issues/12766): Deprecate `sphinx.util.FilenameUniqDict` and `sphinx.util.DownloadFiles`. Patch by Adam Turner. ## Features added - [#​11328](https://redirect.github.com/sphinx-doc/sphinx/issues/11328): Mention evaluation of templated content during production of static output files. Patch by James Addison. - [#​12704](https://redirect.github.com/sphinx-doc/sphinx/issues/12704): LaTeX: make `contents`, `topic`, and `sidebar` directives separately customizable for PDF output. Patch by Jean-François B. and Bénédikt Tran. - [#​12474](https://redirect.github.com/sphinx-doc/sphinx/issues/12474): Support type-dependent search result highlighting via CSS. Patch by Tim Hoffmann. - [#​12652](https://redirect.github.com/sphinx-doc/sphinx/issues/12652): LaTeX: Add `math_numsep` support to latex builder. Patch by Thomas Fanning and Jean-François B. - [#​12743](https://redirect.github.com/sphinx-doc/sphinx/issues/12743): No longer exit on the first warning when `--fail-on-warning` is used. Instead, exit with a non-zero status if any warnings were generated during the build. Patch by Adam Turner. - [#​12743](https://redirect.github.com/sphinx-doc/sphinx/issues/12743): Add `sphinx-build --exception-on-warning`, to raise an exception when warnings are emitted during the build. Patch by Adam Turner and Jeremy Maitin-Shepard. - [#​12907](https://redirect.github.com/sphinx-doc/sphinx/issues/12907): Add `html_last_updated_use_utc` to allow using universal time (GMT/UTC) instead of local time for the date-time supplied to `html_last_updated_fmt`. Patch by Adam Turner. - [#​12910](https://redirect.github.com/sphinx-doc/sphinx/issues/12910): Copyright entries now support the `'%Y'` placeholder to substitute the current year. This is helpful for reducing the reliance on Python modules such as `time` or `datetime` in `conf.py`. Patch by Adam Turner. - [#​11781](https://redirect.github.com/sphinx-doc/sphinx/issues/11781): Add roles for referencing CVEs (`:cve:`) and CWEs (`:cwe:`). Patch by Hugo van Kemenade. - [#​11809](https://redirect.github.com/sphinx-doc/sphinx/issues/11809): Improve the formatting for RFC section anchors. Patch by Jakub Stasiak and Adam Turner. - [#​12852](https://redirect.github.com/sphinx-doc/sphinx/issues/12852): Support a `.Builder.supported_linkcode` attribute for builders to enable use of `sphinx.ext.linkcode`-generated references. Patch by James Knight. - [#​12949](https://redirect.github.com/sphinx-doc/sphinx/issues/12949): Print configuration options that differ from the pickled environment. This can be helpful in diagnosing the cause of a full rebuild. Patch by Adam Turner. ## Bugs fixed - [#​12514](https://redirect.github.com/sphinx-doc/sphinx/issues/12514): intersphinx: fix the meaning of a negative value for `intersphinx_cache_limit`. Patch by Shengyu Zhang. - [#​12722](https://redirect.github.com/sphinx-doc/sphinx/issues/12722): LaTeX: avoid TeX reporting `Overfull \hbox` from too long strings in a codeline when the problem has actually been solved thanks to `latexsphinxsetupforcewraps`. Patch by Jean-François B. - [#​12730](https://redirect.github.com/sphinx-doc/sphinx/issues/12730): The `UnreferencedFootnotesDetector` transform has been improved to more consistently detect unreferenced footnotes. Note, the priority of the transform has been changed from 200 to 622, so that it now runs after the docutils `Footnotes` resolution transform. Patch by Chris Sewell. - [#​12778](https://redirect.github.com/sphinx-doc/sphinx/issues/12778): LaTeX: let `'sphinxsetup'` `div.topic_box-shadow` key if used with only one dimension set both x-offset and y-offset as per documentation. Patch by Jean-François B. - [#​12587](https://redirect.github.com/sphinx-doc/sphinx/issues/12587): Do not warn when potential ambiguity detected during Intersphinx resolution occurs due to duplicate targets that differ case-insensitively. Patch by James Addison. - [#​12639](https://redirect.github.com/sphinx-doc/sphinx/issues/12639): Fix singular and plural search results text. Patch by Hugo van Kemenade. - [#​12645](https://redirect.github.com/sphinx-doc/sphinx/issues/12645): Correctly support custom gettext output templates. Patch by Jeremy Bowman. - [#​12717](https://redirect.github.com/sphinx-doc/sphinx/issues/12717): LaTeX: let `-q` (quiet) option for `sphinx-build -M latexpdf` or `make latexpdf` (`O=-q`) get passed to `latexmk`. Let `-Q` (silent) apply as well to the PDF build phase. Patch by Jean-François B. - [#​12744](https://redirect.github.com/sphinx-doc/sphinx/issues/12744): LaTeX: Classes injected by a custom interpreted text role now give rise to nested `\DUrole`'s, rather than a single one with comma separated classes. Patch by Jean-François B. - [#​12831](https://redirect.github.com/sphinx-doc/sphinx/issues/12831): LaTeX: avoid large voids sometimes occurring at page bottoms. Patch by Jean-François B. - [#​11970](https://redirect.github.com/sphinx-doc/sphinx/issues/11970), [#​12551](https://redirect.github.com/sphinx-doc/sphinx/issues/12551): singlehtml builder: make target URIs to be same-document references in the sense of RFC 3986, §4.4, e.g., `index.html#foo` becomes `#foo`. (note: continuati

Configuration

📅 Schedule: Branch creation - "before 4am on the first day of the month" (UTC), Automerge - At any time (no schedule defined).

🚦 Automerge: Disabled by config. Please merge this manually once you are satisfied.

Rebasing: Whenever PR becomes conflicted, or you tick the rebase/retry checkbox.

👻 Immortal: This PR will be recreated if closed unmerged. Get config help if that's undesired.



This PR has been generated by Renovate Bot.

openverse-bot commented 1 month ago

Edited/Blocked Notification

Renovate will not automatically rebase this PR, because it does not recognize the last commit author and assumes somebody else may have edited the PR.

You can manually request rebase by checking the rebase/retry box above.

⚠️ Warning: custom changes will be lost.

github-actions[bot] commented 1 month ago

Full-stack documentation: https://docs.openverse.org/_preview/5086

Please note that GitHub pages takes a little time to deploy newly pushed code, if the links above don't work or you see old versions, wait 5 minutes and try again.

You can check the GitHub pages deployment action list to see the current status of the deployments.

Changed files :arrows_counterclockwise::