值得一看
双11 12
广告
广告

如何为C++项目配置持续集成?GitHub Actions工作流示例

为c++++项目配置持续集成的核心是自动化构建、测试和代码质量检查。1. 工作流在main分支推送或拉取请求时触发,在ubuntu-latest上运行,安装依赖、配置cmake、构建并运行测试;2. 要支持不同编译器,如windows上的msvc,需更改runs-on为windows-latest,并使用choco安装visual studio工具,同时指定cmake生成器;3. 集成clang-tidy进行代码质量检查,添加步骤运行该工具并传递源文件与包含路径;4. 使用actions/cache缓存build目录,以cmakelists.txt哈希值作为缓存键,加快后续构建速度。

如何为C++项目配置持续集成?GitHub Actions工作流示例

为C++项目配置持续集成,核心在于自动化构建、测试和代码质量检查。GitHub Actions提供了一种便捷的方式来实现这一点,它允许你在代码仓库中定义工作流,并在特定事件(例如推送、拉取请求)发生时自动执行。

如何为C++项目配置持续集成?GitHub Actions工作流示例

解决方案

如何为C++项目配置持续集成?GitHub Actions工作流示例

以下是一个C++项目使用CMake构建,并进行简单测试的GitHub Actions工作流示例:

立即学习“C++免费学习笔记(深入)”;

name: C++ CI
on:
push:
branches: [ "main" ]
pull_request:
branches: [ "main" ]
jobs:
build:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- name: Install Dependencies
run: |
sudo apt-get update
sudo apt-get install -y cmake g++ libgtest-dev
cd /usr/src/gtest
sudo cmake CMakeLists.txt
sudo make
sudo cp libgtest*.a /usr/lib
- name: Configure CMake
run: cmake -B ${{github.workspace}}/build -DCMAKE_BUILD_TYPE=Debug
- name: Build
run: cmake --build ${{github.workspace}}/build
- name: Run Tests
run: ${{github.workspace}}/build/your_test_executable  # 替换为你的测试可执行文件名

这个工作流做了什么?首先,它在main分支的推送和拉取请求时触发。然后在ubuntu-latest虚拟机上运行。它安装了CMake、g++和Google Test(gtest)依赖,配置CMake构建,构建项目,并运行测试。

如何为C++项目配置持续集成?GitHub Actions工作流示例

如何针对不同的编译器进行配置?

你可以通过修改runs-on和安装依赖的步骤来支持不同的编译器。例如,要在Windows上使用MSVC,可以将runs-on更改为windows-latest,并使用choco包管理器安装Visual Studio构建工具。

runs-on: windows-latest
steps:
- uses: actions/checkout@v3
- name: Install MSVC
run: choco install visualstudio2019buildtools -y
- name: Configure CMake
run: cmake -B ${{github.workspace}}/build -DCMAKE_BUILD_TYPE=Debug -G "Visual Studio 16 2019"
- name: Build
run: cmake --build ${{github.workspace}}/build --config Debug
- name: Run Tests
run: ${{github.workspace}}/build/Debug/your_test_executable.exe

注意-G “Visual Studio 16 2019″参数,它指定了CMake使用的生成器。

如何集成代码质量检查工具?

可以使用静态分析工具(如Clang-Tidy)来提高代码质量。在工作流中添加一个步骤来运行Clang-Tidy,并检查是否有任何警告或错误。

- name: Run Clang-Tidy
run: |
clang-tidy $(find . -name "*.cpp" -o -name "*.h") -- -I${{github.workspace}}/include -I${{github.workspace}}/build

这个步骤会递归地查找所有.cpp和.h文件,并将它们传递给Clang-Tidy。-I标志指定了头文件的包含路径。 当然,需要先安装clang-tidy。

如何处理依赖项缓存?

依赖项缓存可以显著加快构建速度。GitHub Actions提供了一个缓存操作,可以用来缓存CMake生成的构建文件和已下载的依赖项。

- uses: actions/cache@v3
with:
path: ${{github.workspace}}/build
key: ${{ runner.os }}-cmake-${{ hashFiles('**/CMakeLists.txt') }}
restore-keys: |
${{ runner.os }}-cmake-

这个操作会缓存build目录,并使用CMakeLists.txt文件的哈希值作为缓存键。如果CMakeLists.txt文件发生更改,缓存将失效。

温馨提示: 本文最后更新于2025-06-25 22:30:10,某些文章具有时效性,若有错误或已失效,请在下方留言或联系易赚网
文章版权声明 1 本网站名称: 创客网
2 本站永久网址:https://new.ie310.com
1 本文采用非商业性使用-相同方式共享 4.0 国际许可协议[CC BY-NC-SA]进行授权
2 本站所有内容仅供参考,分享出来是为了可以给大家提供新的思路。
3 互联网转载资源会有一些其他联系方式,请大家不要盲目相信,被骗本站概不负责!
4 本网站只做项目揭秘,无法一对一教学指导,每篇文章内都含项目全套的教程讲解,请仔细阅读。
5 本站分享的所有平台仅供展示,本站不对平台真实性负责,站长建议大家自己根据项目关键词自己选择平台。
6 因为文章发布时间和您阅读文章时间存在时间差,所以有些项目红利期可能已经过了,能不能赚钱需要自己判断。
7 本网站仅做资源分享,不做任何收益保障,创业公司上收费几百上千的项目我免费分享出来的,希望大家可以认真学习。
8 本站所有资料均来自互联网公开分享,并不代表本站立场,如不慎侵犯到您的版权利益,请联系79283999@qq.com删除。

本站资料仅供学习交流使用请勿商业运营,严禁从事违法,侵权等任何非法活动,否则后果自负!
THE END
喜欢就支持一下吧
点赞10赞赏 分享
评论 抢沙发

请登录后发表评论

    暂无评论内容