A number of changes have been made to file path handling, including pattern matching and path remapping with the [paths] setting (see [paths]). These changes might affect you, and require you to update your settings.
When remapping file paths with [paths], a path will be remapped only if the resulting path exists. The documentation has long said the prefix had to exist, but it was never enforced. This fixes issue 608, improves issue 649, and closes issue 757.
Reporting operations now implicitly use the [paths] setting to remap file paths within a single data file. Combining multiple files still requires the coverage combine step, but this simplifies some single-file situations. Closes issue 1212 and issue 713.
The coverage report command now has a --format= option. The original style is now --format=text, and is the default.
Using --format=markdown will write the table in Markdown format, thanks to Steve Oswald, closing issue 1418.
Using --format=total will write a single total number to the output. This can be useful for making badges or writing status updates.
Combining data files with coverage combine now hashes the data files to skip files that add no new information. This can reduce the time needed. Many details affect the speed-up, but for coverage.py’s own test suite, combining is about 40% faster. Closes issue 1483.
When searching for completely un-executed files, coverage.py uses the presence of __init__.py files to determine which directories have source that could have been imported. However, implicit namespace packages don’t require __init__.py. A new setting [report] include_namespace_packages tells coverage.py to consider these directories during reporting. Thanks to Felix Horvat for the contribution. Closes issue 1383 and issue 1024.
Fixed environment variable expansion in pyproject.toml files. It was overly broad, causing errors outside of coverage.py settings, as described in issue 1481 and issue 1345. This is now fixed, but in rare cases will require changing your pyproject.toml to quote non-string values that use environment substitution.
An empty file has a coverage total of 100%, but used to fail with --fail-under. This has been fixed, closing issue 1470.
The text report table no longer writes out two separator lines if there are no files listed in the table. One is plenty.
Fixed a mis-measurement of a strange use of wildcard alternatives in match/case statements, closing issue 1421.
Fixed internal logic that prevented coverage.py from running on implementations other than CPython or PyPy (issue 1474).
The deprecated [run] note setting has been completely removed.
A number of changes have been made to file path handling, including pattern
matching and path remapping with the [paths] setting (see
:ref:config_paths). These changes might affect you, and require you to
update your settings.
(This release includes the changes from 6.6.0b1 <changes_6-6-0b1_>_, since
6.6.0 was never released.)
Changes to file pattern matching, which might require updating your
configuration:
Previously, * would incorrectly match directory separators, making
precise matching difficult. This is now fixed, closing issue 1407_.
Now ** matches any number of nested directories, including none.
Improvements to combining data files when using the
... (truncated)
Commits
c5cda3a docs: releases take a little bit longer now
Dependabot will resolve any conflicts with this PR as long as you don't alter it yourself. You can also trigger a rebase manually by commenting @dependabot rebase.
Dependabot commands and options
You can trigger Dependabot actions by commenting on this PR:
- `@dependabot rebase` will rebase this PR
- `@dependabot recreate` will recreate this PR, overwriting any edits that have been made to it
- `@dependabot merge` will merge this PR after your CI passes on it
- `@dependabot squash and merge` will squash and merge this PR after your CI passes on it
- `@dependabot cancel merge` will cancel a previously requested merge and block automerging
- `@dependabot reopen` will reopen this PR if it is closed
- `@dependabot close` will close this PR and stop Dependabot recreating it. You can achieve the same result by closing it manually
- `@dependabot ignore this major version` will close this PR and stop Dependabot creating any more for this major version (unless you reopen the PR or upgrade to it yourself)
- `@dependabot ignore this minor version` will close this PR and stop Dependabot creating any more for this minor version (unless you reopen the PR or upgrade to it yourself)
- `@dependabot ignore this dependency` will close this PR and stop Dependabot creating any more for this dependency (unless you reopen the PR or upgrade to it yourself)
Bumps coverage[toml] from 6.5.0 to 7.0.1.
Release notes
Sourced from coverage[toml]'s releases.
... (truncated)
Changelog
Sourced from coverage[toml]'s changelog.
... (truncated)
Commits
c5cda3a
docs: releases take a little bit longer now9d4226e
docs: latest sample HTML report8c77758
docs: prep for 7.0.1da1b282
fix: also look into .whl files for sourced327a70
fix: more information when mapping rules aren't working right.35e249f
fix: certain strange characters caused reporting to fail. #1512152cdc7
fix: don't forbid plus signs in file names. #151331513b4
chore: make upgrade873b059
test: don't run tests on Windows PyPy-3.95c5caa2
build: PyPy wheel now installs on 3.7, 3.8, and 3.9. #1510Dependabot will resolve any conflicts with this PR as long as you don't alter it yourself. You can also trigger a rebase manually by commenting
@dependabot rebase
.Dependabot commands and options
You can trigger Dependabot actions by commenting on this PR: - `@dependabot rebase` will rebase this PR - `@dependabot recreate` will recreate this PR, overwriting any edits that have been made to it - `@dependabot merge` will merge this PR after your CI passes on it - `@dependabot squash and merge` will squash and merge this PR after your CI passes on it - `@dependabot cancel merge` will cancel a previously requested merge and block automerging - `@dependabot reopen` will reopen this PR if it is closed - `@dependabot close` will close this PR and stop Dependabot recreating it. You can achieve the same result by closing it manually - `@dependabot ignore this major version` will close this PR and stop Dependabot creating any more for this major version (unless you reopen the PR or upgrade to it yourself) - `@dependabot ignore this minor version` will close this PR and stop Dependabot creating any more for this minor version (unless you reopen the PR or upgrade to it yourself) - `@dependabot ignore this dependency` will close this PR and stop Dependabot creating any more for this dependency (unless you reopen the PR or upgrade to it yourself)