Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/codecov/example-cpp11-cmake
https://github.com/codecov/example-cpp11-cmake
cmake codecov coverage cpp cpp11
Last synced: about 3 hours ago
JSON representation
- Host: GitHub
- URL: https://github.com/codecov/example-cpp11-cmake
- Owner: codecov
- License: mit
- Created: 2017-01-13T18:12:49.000Z (almost 8 years ago)
- Default Branch: master
- Last Pushed: 2024-01-22T21:36:03.000Z (10 months ago)
- Last Synced: 2024-04-16T04:50:09.500Z (7 months ago)
- Topics: cmake, codecov, coverage, cpp, cpp11
- Language: CMake
- Size: 43.9 KB
- Stars: 143
- Watchers: 19
- Forks: 63
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
README
# [Codecov][1] CI CMake g++ cpp11 lcov Example
[![Travis CI logo][travis-image]][travis-link]
[![Codecov logo][codecov-image]][codecov-link]
[![FOSSA Status](https://app.fossa.com/api/projects/git%2Bgithub.com%2Fcodecov%2Fexample-cpp11-cmake.svg?type=shield)](https://app.fossa.com/projects/git%2Bgithub.com%2Fcodecov%2Fexample-cpp11-cmake?ref=badge_shield)[![Build Status][travis-badge]][travis-link]
[![codecov][codecov-badge]][codecov-link]
[![MIT License][license-badge]](LICENSE.md)The goal of this project is to build project with following tools:
* C++ version: `C++11`
* Build system: [`CMake`](https://cmake.org/)
* C++ compiler: `g++` or Visual Studio
* Libraries: `STL` only
* Code coverage report: [`lcov`](http://ltp.sourceforge.net/coverage/lcov.php) and [`OpenCppCoverage`](https://github.com/OpenCppCoverage/OpenCppCoverage)(note: it should show the code coverage is below 100%)
* [`CodeCov`](https://codecov.io/) (code coverage is measured by CodeCov).
* Source: multiple files## Special Thanks
Goes to [Richel Bilderbeek](https://github.com/richelbilderbeek) for inspiration and all work on [Travis CI tutorials](https://github.com/richelbilderbeek/travis_cpp_tutorial).
Here is a [link](https://github.com/richelbilderbeek/travis_cmake_gcc_cpp11) to a project with the same structure (without `lcov`),
and here is a [list](https://github.com/richelbilderbeek/travis_cpp_tutorial/blob/master/statuses.md) of all his Travis configuration examples.## Prerequisites
To build the project you need to install `CMake`. ([Install instructions](https://cmake.org/install/))
To display a code coverage report in the console, install `lcov`. ([`Download lcov`](http://ltp.sourceforge.net/coverage/lcov.php), [`Instructions`](http://ltp.sourceforge.net/coverage/lcov/readme.php))## Guide
1. Compile with code coverage instrumentation enabled [(GCC)](https://gcc.gnu.org/onlinedocs/gcc/Instrumentation-Options.html).
2. Execute the tests to generate the coverage data.
3. (Optionally) generate and customize reports with `lcov`.
4. Upload to CodeCov using the bash uploader.### Travis Setup Using lcov
Add to your `.travis.yml` file:
```yml
addons:
apt:
packages: lcovafter_success:
# Create lcov report
- lcov --capture --directory . --output-file coverage.info
- lcov --remove coverage.info '/usr/*' --output-file coverage.info # filter system-files
- lcov --list coverage.info # debug info
# Uploading report to CodeCov
- bash <(curl -s https://codecov.io/bash) -f coverage.info || echo "Codecov did not collect coverage reports"
```### Travis Setup without lcov
By default the bash uploader processes the coverage data using gcov when no file is supplied.
```yml
after_success:
- bash <(curl -s https://codecov.io/bash) || echo "Codecov did not collect coverage reports"
```## Caveats
### Private Repos
Add to your `.travis.yml` file:
```yml
after_success:
- bash <(curl -s https://codecov.io/bash) -t uuid-repo-token
```## Example details
This repo can serve as the starting point for a new project. The following is worth noticing:
1. Use of a build script instead of putting the commands into `.travis.yml`
- Allows local testing
- Allows usage of `set -e` to error out with meaningfull messages on any command failure
2. Separate testing source tree
- Allows to easily enable/disable testing
- Allows usage in parent projects (you don't want to build the tests if you are consumed)
- You may want to exclude coverage of test files which is easier when they are in a separate folder.
Remember to use **full paths** for patterns (like `'*/tests/*'`)
3. Use of travis cache to cache manually build 3rd-party dependencies (like boost)
- Speeds up build
- More can be added (e.g. `ccache`)
- Those need to be excluded from coverage info too## Authors
* **RokKos** - [RokKos](https://github.com/RokKos)
* **Rolf Eike Beer** - [DerDakon](https://github.com/DerDakon)
* **Alexander Grund** - [Flamefire](https://github.com/Flamefire)## License
This project is licensed under the MIT License - see the [LICENSE](https://github.com/RokKos/classes-c-/blob/master/LICENSE) file for details.1. More documentation at https://docs.codecov.io
2. Configure codecov through the `codecov.yml` https://docs.codecov.io/docs/codecov-yamlWe are happy to help if you have any questions. Please email our Support at [[email protected]](mailto:[email protected])
[1]: https://codecov.io/
[travis-badge]: https://travis-ci.org/codecov/example-cpp11-cmake.svg?branch=master
[travis-link]: https://travis-ci.org/codecov/example-cpp11-cmake
[travis-image]: https://github.com/codecov/example-cpp1-cmake/blob/master/img/TravisCI.png
[license-badge]: https://img.shields.io/badge/license-MIT-007EC7.svg
[codecov-badge]: https://codecov.io/gh/codecov/example-cpp11-cmake/branch/master/graph/badge.svg
[codecov-link]: https://codecov.io/gh/codecov/example-cpp11-cmake
[codecov-image]: https://github.com/codecov/example-cpp1-cmake/blob/master/img/Codecov.png[![FOSSA Status](https://app.fossa.com/api/projects/git%2Bgithub.com%2Fcodecov%2Fexample-cpp11-cmake.svg?type=large)](https://app.fossa.com/projects/git%2Bgithub.com%2Fcodecov%2Fexample-cpp11-cmake?ref=badge_large)