summaryrefslogtreecommitdiff
path: root/coverage
Commit message (Collapse)AuthorAgeFilesLines
* fix: proper tracing of call/return for Python 3.11.0a4Ned Batchelder2022-01-152-16/+56
| | | | | Version 3.11.0a4 introduced RESUME, so returns and calls are different now. This change also fixes some mishandling of yield-from in previous releases.
* fix: update pytracer.py for Python 3.11Ned Batchelder2022-01-151-5/+25
|
* debug: reprs make debugging easierNed Batchelder2022-01-151-1/+3
|
* fix: 3.11 now traces decorator lines as the decorators executeNed Batchelder2022-01-152-2/+12
| | | | See: https://bugs.python.org/issue46234
* fix: don't write a .gitignore unless the directory is emptyNed Batchelder2022-01-111-3/+6
|
* style: minor cleanups realized while reviewing a pull requestNed Batchelder2022-01-052-10/+10
|
* refactor: no need to special-case spec.origin == "namespace"Ned Batchelder2022-01-031-2/+1
| | | | | Namespace packages used to have this value, but that was changed in 3.7: https://bugs.python.org/issue32305
* refactor: we no longer need to protect against UnicodeError, it was only on 3.6Ned Batchelder2022-01-031-7/+1
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This was the failure it was protecting against on Python 3.6: ``` ___________________________ ProcessTest.test_lang_c ____________________________ [gw0] linux -- Python 3.6.15 /home/runner/work/coveragepy/coveragepy/.tox/py36/bin/python self = <tests.test_process.ProcessTest object at 0x7fe57e63b198> @pytest.mark.skipif(env.PYPY, reason="PyPy is unreliable with this test") # Jython as of 2.7.1rc3 won't compile a filename that isn't utf-8. @pytest.mark.skipif(env.JYTHON, reason="Jython can't handle this test") def test_lang_c(self): # LANG=C forces getfilesystemencoding on Linux to 'ascii', which causes # failures with non-ascii file names. We don't want to make a real file # with strange characters, though, because that gets the test runners # tangled up. This will isolate the concerns to the coverage.py code. # https://github.com/nedbat/coveragepy/issues/533 self.make_file("weird_file.py", r""" globs = {} code = "a = 1\nb = 2\n" exec(compile(code, "wut\xe9\xea\xeb\xec\x01\x02.py", 'exec'), globs) print(globs['a']) print(globs['b']) """) self.set_environ("LANG", "C") out = self.run_command("coverage run weird_file.py") > assert out == "1\n2\n" E assert 'Traceback (m...ion by zero\n' == '1\n2\n' E - 1 E - 2 E + Traceback (most recent call last): E + File "/home/runner/work/coveragepy/coveragepy/coverage/files.py", line 149, in abs_file E + path = os.path.realpath(path) E + File "/opt/hostedtoolcache/Python/3.6.15/x64/lib/python3.6/posixpath.py", line 395, in realpath E + path, ok = _joinrealpath(filename[:0], filename, {}) E + File "/opt/hostedtoolcache/Python/3.6.15/x64/lib/python3.6/posixpath.py", line 429, in _joinrealpath E + if not islink(newpath): E + File "/opt/hostedtoolcache/Python/3.6.15/x64/lib/python3.6/posixpath.py", line 171, in islink E + st = os.lstat(path) E + UnicodeEncodeError: 'ascii' codec can't encode characters in position 3-6: ordinal not in range(128) ```
* build(test): PyContracts doesn't work on 3.11Ned Batchelder2022-01-021-1/+5
| | | | and I don't think it ever will.
* refactor: remove code that was only needed for Python 3.6Ned Batchelder2021-12-312-27/+8
|
* build: drop Python 3.6 supportNed Batchelder2021-12-311-1/+1
|
* build: bump versionNed Batchelder2021-11-261-1/+1
|
* docs: prep for 6.26.2Ned Batchelder2021-11-261-1/+1
|
* docs: tweak the description of --concurrencyNed Batchelder2021-11-261-1/+1
|
* feat: multiple --concurrency values. #1012 #1082nedbat/multi-concurrencyNed Batchelder2021-11-255-54/+69
|
* test(fix): keep SourceIncludeOmitTest's from clobbering each otherNed Batchelder2021-11-241-0/+3
| | | | | | | | Because they cd'd into a folder in the shared source tree, their data files would collide, leading to flaky tests. Also, add a check that the tests collected some data, and add sys.path to the debug=trace output.
* test(fix): skip tests that trip a specific Mac 3.9 eventlet bugNed Batchelder2021-11-241-0/+1
|
* refactor: this is nicer as a setNed Batchelder2021-11-241-2/+2
|
* refactor: super-nit-picky tweaks from mypyNed Batchelder2021-11-212-3/+3
|
* fix: suffix=False will suppress the suffix even with multiprocessing. #989Ned Batchelder2021-11-181-1/+6
|
* refactor: remove comparison methods only needed for Python 2Ned Batchelder2021-11-171-16/+4
|
* refactor: move this so I can use it ad-hoc more easilyNed Batchelder2021-11-162-26/+26
|
* refactor: filename_suffix() is only used by CoverageData, so move itNed Batchelder2021-11-162-23/+23
|
* docs: clarify the CoverageData(basename=) argument. #985Ned Batchelder2021-11-151-1/+1
| | | | [skip actions]
* refactor: specialize exceptionsNed Batchelder2021-11-1414-58/+79
| | | | | | CoverageException is fine as a base class, but not good to use for raising (and catching sometimes). Introduce specialized exceptions that allow third-party tools to integrate better.
* docs: document the exceptionsNed Batchelder2021-11-144-12/+12
| | | | ... and make some of them private.
* debug: the `coverage debug` command no longer accepts multiple topicsNed Batchelder2021-11-131-24/+26
|
* fix: suppress exceptions when finding source= modules. #1203Ned Batchelder2021-11-131-1/+1
|
* style(docs): make note:: uses uniformNed Batchelder2021-11-131-3/+5
|
* refactor: a plural helperNed Batchelder2021-11-133-14/+19
|
* feat: 'debug data' now enumerates combinable files alsoNed Batchelder2021-11-132-34/+55
|
* refactor: no need for __nonzero__, that was py2 onlyNed Batchelder2021-11-132-6/+2
|
* fix: don't overwrite a .gitignore in the html output directory. #1244nedbat/1244-againNed Batchelder2021-11-121-2/+4
|
* style: convert more string formatting to f-stringsNed Batchelder2021-11-116-7/+7
|
* refactor: we no longer need to treat 'class' lines speciallyNed Batchelder2021-11-111-15/+0
| | | | | Originally, this tokenizing code was paired with bytecode analysis. But now we use AST instead, so class lines don't need to be handled differently.
* fix: colons in decorators shouldn't stop an exclusionNed Batchelder2021-11-101-2/+7
|
* build: bump versionNed Batchelder2021-11-101-1/+1
|
* build: prep for 6.1.2Ned Batchelder2021-11-101-1/+1
|
* fix: CPython 3.11 support. #1241Ned Batchelder2021-11-101-1/+7
| | | | | | | | | | | The fix for CTracer is egregious and will need to be updated when there's a supported way to do it. The fullcoverage skip is noted in https://github.com/nedbat/coveragepy/issues/1278 The raise_through_with skip is noted in https://github.com/nedbat/coveragepy/issues/1270
* style: make these macros more bullet-proofNed Batchelder2021-11-102-5/+5
|
* fix: warn about more source file problemsNed Batchelder2021-11-092-7/+8
|
* fix: remapping paths during combining needs to follow relative_files=True. #1147Ned Batchelder2021-11-062-3/+6
|
* fix: give a default value to the name argument for Matchers. #1273Ned Batchelder2021-11-051-3/+3
|
* fix: don't report branches to exclusions as missing. #1271Ned Batchelder2021-11-051-1/+2
|
* refactor(test): don't even import contracts if not using PyContractsNed Batchelder2021-11-043-10/+11
| | | | | | | | On CPython 3.11, PyContracts fails on import, so we need to shut it off more completely. PyContracts is unmaintained these days, so we'll probably get rid of it completely soon.
* build: bump versionNed Batchelder2021-10-311-1/+1
|
* build: prep for 6.1.1Ned Batchelder2021-10-311-1/+1
|
* fix: don't warn about already imported files for namespace packages #888Ned Batchelder2021-10-311-0/+4
| | | | Ignore namespace packages in the already-imported check. #888
* fix: don't mention the p shortcut if not doing branchesNed Batchelder2021-10-301-1/+4
|
* fix: sticky HTML header only worked with branch coverageNed Batchelder2021-10-301-15/+23
|