Skip to content

Latest commit

 

History

History
857 lines (665 loc) · 38.8 KB

CHANGELOG.rst

File metadata and controls

857 lines (665 loc) · 38.8 KB

gcovr Release History and Change Log

.. program::  gcovr

Next Release

Known bugs:

Breaking changes:

  • Replace setup.py with hatchling. To install from source at least version 21.3 of pip is needed. (:issue:`1026`)
  • Drop support for Python 3.8. (:issue:`1030`)

New features and notable changes:

Bug fixes and small improvements:

  • Fixed an error handling bug throwing a TypeError exception on a gcov merge assertion failure instead of reporting the error and (if requested by the user) continuing execution. (:issue:`997`)
  • Check format version of external generated gcov JSON files. (:issue:`999`)
  • Fix crash on Windows when trying to fix the case of the files. (:issue:`1000`)
  • Fix LCOV report. Excluded lines where added with a count of 0. (:issue:`1012`)
  • Fix line exclusion not clearing all child coverage data. (:issue:`1018`)
  • Fix summary stats in JaCoCo report. (:issue:`1022`)
  • Fix path issue when reading/writing Coveralls report. (:issue:`1037`)

Documentation:

  • Update documentation for developing with Docker. (:issue:`1013`)

Internal changes:

8.2 (13 October 2024)

Known bugs:

Breaking changes:

New features and notable changes:

Bug fixes and small improvements:

Documentation:

  • Fix documentation build issue.

Internal changes:

8.1 (13 October 2024)

Known bugs:

Breaking changes:

New features and notable changes:

  • If a internal generated function is excluded the lines, if present, are excluded as well. (:issue:`991`)

Bug fixes and small improvements:

  • Fix exclusion of internal functions. (:issue:`987`)
  • Only print info on the first undefined block number in data model. (:issue:`990`)

Documentation:

Internal changes:

8.0 (07 October 2024)

Known bugs:

  • Exclusion of internal function not working. (:issue:`984`)

Breaking changes:

  • Changes related to added support of gcov JSON intermediate format:
    • The function return count is removed from internal data model, HTML and JSON output because missing in gcov JSON intermediate format. (:issue:`935`)
    • Renamed name key in in data model and JSON report to demangled_name. If gcov JSON intermediate format is used the name key will contained the mangled name. The keys are now aligned with the gcov JSON intermediate format. (:issue:`974`)
  • If block information is missing in gcov legacy text format block 0 is assumed. (:issue:`976`)

New features and notable changes:

Bug fixes and small improvements:

  • Implement consistent sorting of files with no lines, or one line with zero coverage (:issue:`918`)
  • Use replacement value of 0 for function call count NAN %. (:issue:`910`)
  • Fix erroneous deprecation warning. (:issue:`912`)
  • Fix display filename in HTML report. (:issue:`920`)
  • Fix bundle of standalone executable with Python 3.12. (:issue:`924`)
  • Fix merging of function coverage data. (:issue:`925`)
  • Fix inefficient regular expression. (:issue:`933`)
  • Fix missing output of gcov if execution fails. (:issue:`956`)

Documentation:

  • Update Sphinx config because of deprecated context injection from Read The Docs. (:issue:`936`)

Internal changes:

7.2 (24 February 2024)

Fix tagging issue of 7.1, no functional change.

7.1 (24 February 2024)

Known bugs:

Breaking changes:

New features and notable changes:

Bug fixes and small improvements:

Documentation:

  • Add nox session to generate the screenshots from the HTML files. (:issue:`877`)

Internal changes:

  • Improve Dockerfile for faster rebuilds by using cache. (:issue:`878`)
  • Fix deprecation warnings from GitHub actions. (:issue:`880`)
  • Add pipeline job to apply tag if new version is bumped. (:issue:`879`)
  • Improve test coverage and generate coverage report if executed in local environment. (:issue:`891`)

7.0 (25 January 2024)

Known bugs:

Breaking changes:

  • Dropped support for Python 3.7 (:issue:`869`)
  • The exit code for an error of the reader module is changed from 8 to 64 and for a writer from 7 to 128. (:issue:`773`)

New features and notable changes:

Bug fixes and small improvements:

  • Print calls and decision statistics in summary only if values are gathered. (:issue:`749`)
  • Log the thread name if :option:`-j` is used. (:issue:`752`)
  • Collapse also root directory if needed in nested HTML report. (:issue:`750`)
  • Handle special case of absolute source file paths in gcov output. (:issue:`776`)
  • Ignore exit code 6 when running gcov (output write error introduced gcc-12). (:issue:`781`)
  • Change coveralls value from 0.0 to 1.0 if no code lines or branches are present. (:issue:`796`)
  • Fix symlinked root directories on Windows. (:issue:`814`)
  • Extend :option:`--gcov-ignore-errors` to be able to ignore specific gcov errors. (:issue:`787`)
  • Fix reading of choices options from configuration files (e.g. gcov-ignore-parse-errors). (:issue:`816`)
  • Fix TypeError during decision analysis. (:issue:`784`)
  • Use relative paths if possible when running gcov. (:issue:`820`)
  • Respect :option`--merge-mode-functions`when merging coverage data. (:issue:`844`)

Documentation:

  • Fix wrong command in How to create a standalone application docs. (:issue:`792`)
  • Update output html to add github style themes. (:issue:`818`)

Internal changes:

6.0 (08 March 2023)

Known bugs:

Breaking changes:

New features and notable changes:

Bug fixes and small improvements:

Documentation:

  • Add detailed reference for the JSON output format. (:issue:`663`)

Internal changes:

  • Select the :option:`--html-theme` using CSS classes. (:issue:`650`)
  • Change and extend cmake tests. (:issue:`676`)
  • Detect gcc version for running tests. (:issue:`686`)
  • Use scrubbed data for --update_reference option. (:issue:`698`)
  • Install ninja with package manager instead of GitHub action. (:issue:`699`)
  • Rename the reference files coverage.xml to cobertura.xml and the test from xml to cobertura. (:issue:`721`)
  • Add support for clang-14 in our test suite and improve startup performance of docker image. (:issue:`731`)
  • Compare files by extension in test suite. (:issue:`733`)
  • Split HTML templates into one file for each part of the page. (:issue:`735`)
  • Change docker image to be able to use it like the nox command itself. (:issue:`734`)

5.2 (06 August 2022)

New features and notable changes:

  • Log additional info on gcov parsing errors. (:issue:`589`)
  • Add support for branch exclude markers. (:issue:`644`)
  • Additional options to configure the thresholds for lines and branches in HTML separate. (:issue:`645`)

Bug fixes and small improvements:

  • Remove function coverage from sonarqube report. (:issue:`591`)
  • Fix parallel processing of gcov data. (:issue:`592`)
  • Better diagnostics when dealing with corrupted input files. (:issue:`593`)
  • Accept metadata lines without values (introduced in gcc-11). (:issue:`601`)
  • Properly close <a> element in detailed HTML report. (:issue:`602`)
  • Use ≥ sign instead of >= in HTML legend. (:issue:`603`)
  • Using :option:`--add-tracefile` will now correctly merge branch coverage. (:issue:`600`)
  • Fix package-level function coverage statistics in Cobertura XML reports. (:issue:`605`)
  • Respect excluded/noncode lines for aggregated branch coverage. (:issue:`611`)
  • Fix list options in configuration file (search-path). (:issue:`612`)
  • Fix assert and key error in --decisions flag. (:issue:`642`)
  • Fix adding none existing lines by decision analysis to data model. (:issue:`617`)
  • Always treat relative paths in config files as relative to the directory of the file. (:issue:`615`)
  • More flexible .gcov parsing to support files generated by third party tools. (:issue:`621`, :issue:`623`)

Internal changes:

  • Fix black check to fail on format errors. (:issue:`594`)
  • Change session black with no arguments to format all files. (:issue:`595`)
  • Add gcc-10 and gcc-11 to the test suite. (:issue:`597`)
  • Improved internal coverage data model to simplify processing. (:issue:`600`)
  • Use pretty print for cobertura and coveralls in test suite. (:issue:`606`)
  • Forward nox options --reuse-existing-virtualenvs and --no-install to call inside docker. (:issue:`616`)

5.1 (26 March 2022)

Breaking changes:

  • Dropped support for Python 3.6 (:issue:`550`)
  • Changed xml configuration key to cobertura (:issue:`552`)
  • JSON summary output: all percentages are now reported from 0 to 100 (:issue:`570`)

New features and notable changes:

Bug fixes and small improvements:

  • Gcov is invoked without localization by setting LC_ALL=C (:issue:`513`)
  • Gcov is invoked without temporary directories (:issue:`525`)
  • Gcov: solved problems with file name limitations. (:issue:`528`)
  • Fixed "root" path in JSON summary report. (:issue:`548`)
  • Correctly resolve relative filters in configuration files. (:issue:`568`)
  • HTML output: indicate lines with excluded coverage (:issue:`503`)
  • HTML output: fixed sanity check to support empty files (:issue:`571`)
  • HTML output: support jinja2 >= 3.1 (:issue:`576`)

Documentation:

Internal changes:

5.0 (11 June 2021)

Breaking changes:

  • Dropped support for Python 2 and Python 3.5. From now on, gcovr will only support Python versions that enjoy upstream support.

Improvements and new features:

Documentation:

Internal changes:

  • Add makefile + dockerfile for simpler testing.
  • Add .gitbugtraq to link comments to issue tracker in GUIs. (:issue:`429`)
  • Add GitHub actions to test PRs and master branch. (:issue:`404`)
  • Remove Travis CI. (:issue:`419`)
  • Remove Appveyor CI and upload coverage report from Windows and Ubuntu from the GitHub actions. (:issue:`455`)
  • Add check if commit is mentioned in the CHANGELOG.rst. (:issue:`457`)
  • Move flake8 config to setup.cfg and add black code formatter. (:issue:`444`)
  • Fix filter/exclude relative path issue in Windows. (:issue:`320`, :issue:`479`)
  • Extend test framework for CI:
    • Set make variable TEST_OPTS as environment variable inside docker. (:issue:`372`)
    • Add make variable USE_COVERAGE to extend flags for coverage report in GitHub actions. (:issue:`404`)
    • Extend tests to use an unified diff in the assert. Add test options --generate_reference, --update_reference and --skip_clean. (:issue:`379`)
    • Support multiple output patterns in integration tests. (:issue:`383`)
    • New option --archive_differences to save the different files as ZIP. Use this ZIP as artifact in AppVeyor. (:issue:`392`)
    • Add support for gcc-8 to test suite and docker tests. (:issue:`423`)
    • Run as limited user inside docker container and add test with read only directory. (:issue:`445`)

4.2 (6 November 2019)

Breaking changes:

  • Dropped support for Python 3.4.
  • Format flag parameters like :option:`--xml` or :option:`--html` now take an optional output file name. This potentially changes the interpretation of search paths. In gcovr --xml foo, previous gcovr versions would search the foo directory for coverage data. Now, gcovr will try to write the Cobertura report to the foo file. To keep the old meaning, separate positional arguments like gcovr --xml -- foo.

Improvements and new features:

Known issues:

Documentation:

Internal changes:

4.1 (2 July 2018)

  • Fixed/improved --exclude-directories option. (:issue:`266`)
  • New "Cookbook" section in the documentation. (:issue:`265`)

4.0 (17 June 2018)

Breaking changes:

  • This release drops support for Python 2.6. (:issue:`250`)
  • PIP is the only supported installation method.
  • No longer encoding-agnostic under Python 2.7. If your source files do not use the system encoding (probably UTF-8), you will have to specify a --source-encoding. (:issue:`148`, :issue:`156`, :issue:`256`)
  • Filters now use forward slashes as path separators, even on Windows. (:issue:`191`, :issue:`257`)
  • Filters are no longer normalized into pseudo-paths. This could change the interpretation of filters in some edge cases.

Improvements and new features:

Internal changes:

3.4 (12 February 2018)

3.3 (6 August 2016)

  • Added CI testing using TravisCI
  • Added more tests for out of source builds and other nested builds
  • Avoid common file prefixes in HTML output (:issue:`103`)
  • Added the --execlude-directories argument to exclude directories from the search for symlinks (:issue:`87`)
  • Added branches taken/not taken to HTML (:issue:`75`)
  • Use --object-directory to scan for gcov data files (:issue:`72`)
  • Improved logic for nested makefiles (:issue:`135`)
  • Fixed unexpected semantics with --root argument (:issue:`108`)
  • More careful checks for covered lines (:issue:`109`)

3.2 (5 July 2014)

  • Adding a test for out of source builds
  • Using the starting directory when processing gcov filenames. (:issue:`42`)
  • Making relative paths the default in html output.
  • Simplify html bar with coverage is zero.
  • Add option for using existing gcov files (:issue:`35`)
  • Fixing --root argument processing (:issue:`27`)
  • Adding logic to cover branches that are ignored (:issue:`28`)

3.1 (6 December 2013)

  • Change to make the -r/--root options define the root directory for source files.
  • Fix to apply the -p option when the --html option is used.
  • Adding new option, '--exclude-unreachable-branches' that will exclude branches in certain lines from coverage report.
  • Simplifying and standardizing the processing of linked files.
  • Adding tests for deeply nested code, and symbolic links.
  • Add support for multiple —filter options in same manner as —exclude option.

3.0 (10 August 2013)

  • Adding the '--gcov-executable' option to specify the name/location of the gcov executable. The command line option overrides the environment variable, which overrides the default 'gcov'.
  • Adding an empty "<methods/>" block to <classes/> in the XML output: this makes out XML compliant with the Cobertura DTD. (#3951)
  • Allow the GCOV environment variable to override the default 'gcov' executable. The default is to search the PATH for 'gcov' if the GCOV environment variable is not set. (#3950)
  • Adding support for LCOV-style flags for excluding certain lines from coverage analysis. (#3942)
  • Setup additional logic to test with Python 2.5.
  • Added the --html and --html-details options to generate HTML.
  • Sort output for XML to facilitate baseline tests.
  • Added error when the --object-directory option specifies a bad directory.
  • Added more flexible XML testing, which can ignore XML elements that frequently change (e.g. timestamps).
  • Added the '—xml-pretty' option, which is used to generate pretty XML output for the user manual.
  • Many documentation updates

2.4 (13 April 2012)

  • New approach to walking the directory tree that is more robust to symbolic links (#3908)
  • Normalize all reported path names
    • Normalize using the full absolute path (#3921)
    • Attempt to resolve files referenced through symlinks to a common project-relative path
  • Process gcno files when there is no corresponding gcda file to provide coverage information for unexecuted modules (#3887)
  • Windows compatibility fixes
    • Fix for how we parse source: file names (#3913)
    • Better handling od EOL indicators (#3920)
  • Fix so that gcovr cleans up all .gcov files, even those filtered by command line arguments
  • Added compatibility with GCC 4.8 (#3918)
  • Added a check to warn users who specify an empty --root option (see #3917)
  • Force gcov to run with en_US localization, so the gcovr parser runs correctly on systems with non-English locales (#3898, #3902).
  • Segregate warning/error information onto the stderr stream (#3924)
  • Miscellaneous (Python 3.x) portability fixes
  • Added the master svn revision number as part of the version identifier

2.3.1 (6 January 2012)

  • Adding support for Python 3.x

2.3 (11 December 2011)

  • Adding the --gcov-filter and --gcov-exclude options.

2.2 (10 December 2011)

  • Added a test driver for gcovr.
  • Improved estimation of the <sources> element when using gcovr with filters.
  • Added revision and date keywords to gcovr so it is easier to identify what version of the script users are using (especially when they are running a snapshot from trunk).
  • Addressed special case mentioned in [comment:ticket:3884:1]: do not truncate the reported file name if the filter does not start matching at the beginning of the string.
  • Overhaul of the --root / --filter logic. This should resolve the issue raised in #3884, along with the more general filter issue raised in [comment:ticket:3884:1]
  • Overhaul of gcovr's logic for determining gcc/g++'s original working directory. This resolves issues introduced in the original implementation of --object-directory (#3872, #3883).
  • Bugfix: gcovr was only including a <sources> element in the XML report if the user specified -r (#3869)
  • Adding timestamp and version attributes to the gcovr XML report (see #3877). It looks like the standard Cobertura output reports number of seconds since the epoch for the timestamp and a doted decimal version string. Now, gcovr reports seconds since the epoch and "gcovr ``"+``__version__ (e.g. "gcovr 2.2") to differentiate it from a pure Cobertura report.

2.1 (26 November 2010)

  • Added the --object-directory option, which allows for a flexible specification of the directory that contains the objects generated by gcov.

  • Adding fix to compare the absolute path of a filename to an exclusion pattern.

  • Adding error checking when no coverage results are found. The line and branch counts can be zero.

  • Adding logic to process the -o/--output option (#3870).

  • Adding patch to scan for lines that look like:

    creating `foo'
    

    as well as

    creating 'foo'
    
  • Changing the semantics for EOL to be portable for MS Windows.

  • Add attributes to xml format so that it could be used by hudson/bamboo with cobertura plug-in.

2.0 (22 August 2010)

  • Initial release as a separate package. Earlier versions of gcovr were managed within the 'fast' Python package.