Jenkins实现CI/CD流水线


一、环境准备与配置

  1. Jenkins插件安装

    1. 登录Jenkins → Manage JenkinsPlugins → 安装必备插件:

      • GitLab Plugin(集成GitLab)

      • HTML Publisher Plugin(展示测试报告)

      • Pipeline(定义流水线)

      • Pytest Report Plugin(解析pytest结果)

  2. 配置GitLab凭证

    1. Manage JenkinsCredentials → 添加GitLab API Token:

      • 类型:Secret text

      • Secret:从GitLab Settings → Access Tokens 生成(权限:apiread_repository


二、代码仓库与项目结构

  1. GitLab代码规范

    1. 在PyCharm中确保项目结构符合:

      bash 复制代码
      project-root/ ├── tests/ # 测试用例目录(test_*.py或*_test.py) ├── requirements.txt # Python依赖 ├── Jenkinsfile # Pipeline脚本 └── conftest.py # pytest配置
    2. 推送代码到GitLab仓库。

  2. 测试报告生成配置

    1. pytest执行命令中添加报告参数(Jenkinsfile中调用):

      bash 复制代码
      pytest --junitxml=test-results.xml --html=report.html

三、Jenkins流水线设置

步骤1:创建Pipeline任务
  • 新建任务 → 选**Pipeline** → 输入任务名

  • Pipeline配置

    • Definition: Pipeline script from SCM

    • SCM: Git → 填写GitLab仓库URL

    • Credentials: 选择已配置的GitLab Token

    • Script Path: Jenkinsfile(需在代码根目录)

步骤2:编写Jenkinsfile(核心脚本)
Groovy 复制代码
pipeline { agent any stages { // 拉取代码 stage('Checkout') { steps { checkout scm } } // 安装依赖 stage('Setup') { steps { sh 'python -m venv venv' sh 'source venv/bin/activate && pip install -r requirements.txt' } } // 执行测试 stage('Test') { steps { sh 'source venv/bin/activate && pytest tests/ --junitxml=test-results.xml --html=report.html' } } // 发布报告 stage('Report') { steps { publishHTML target: [ allowMissing: false, alwaysLinkToLastBuild: true, keepAll: true, reportDir: '.', reportFiles: 'report.html', reportName: 'HTML Report' ] junit 'test-results.xml' // 集成JUnit报告 } } } post { always { // 清理Python虚拟环境 sh 'rm -rf venv' } } }
步骤3:配置定时触发
  • 在Pipeline任务配置页 → Build Triggers → 勾选Build periodically

  • 日程表语法:H 22 * * *(每天22:00构建)


四、高级优化与异常处理

  1. 失败重试机制

    1. 安装插件pytest-rerunfailures,在pytest命令中添加:

      bash 复制代码
      pytest --reruns 3 --reruns-delay 2 # 失败重试3次,间隔2秒
  2. 多节点 并发 执行

    1. 使用pytest-xdist加速测试:

      bash 复制代码
      pytest -n 4 # 4进程并行
  3. GitLab Merge Request 验证

    1. 在GitLab项目设置 → Merge Request → 启用Pipelines must succeed

    2. Jenkins自动触发MR流水线(需在Jenkinsfile中定义when { changeRequest() }


五、验证与调试

  1. 手动触发测试

    1. Jenkins任务页 → Build Now → 查看Console Output日志
  2. 报告查看

    1. 构建完成后 → 左侧菜单**HTML Report**查看测试详情
  3. 常见问题排查

    1. 依赖安装失败 :确认requirements.txt路径正确

    2. 权限错误:Jenkins用户需有Python环境执行权限

    3. GitLab触发失败:检查API Token权限和Webhook配置(GitLab → Settings → Webhooks)


六、完整流程图示

html 复制代码
graph LR A[PyCharm代码推送GitLab] --> B[Jenkins定时/触发构建] B --> C1[拉取代码] --> C2[安装依赖] --> C3[执行pytest] C3 --> D{测试通过?} D -- 是 --> E[发布HTML报告] D -- 否 --> F[邮件通知失败] --> G[开发修复]

通过以上步骤,可实现每日自动执行接口测试、生成可视化报告,并通过Jenkins-GitLab集成确保代码合并质量。若需扩展容器化执行,可在agent中配置Docker节点。

相关推荐
测试那点事儿7 小时前
第3章零基础接口自动化到 Jenkins 持续集成【项目结构和核心模块入门】
ci/cd·自动化·jenkins
峥无7 小时前
Linux 文件系统底层探秘:磁盘物理结构→inode→Ext 架构全链路
linux·运维·笔记
测试那点事儿7 小时前
第5章 零基础接口自动化到 Jenkins 持续集成【参数关联与登录鉴权实战】
ci/cd·自动化·jenkins
测试那点事儿7 小时前
第6章 零基础接口自动化到 Jenkins 持续集成【报告查看与常见报错排查】
ci/cd·自动化·jenkins
minji...7 小时前
Linux 网络套接字编程(七)TCP服务端和客户端的实现——网络版本计算器
linux·运维·服务器·网络·c++·tcp/ip·udp
Misnice7 小时前
DevOps 介绍
运维·devops
liann1197 小时前
3.3_tasklist和netstat命令详解
运维·windows·计算机网络·安全·信息与通信
郝学胜-神的一滴7 小时前
epoll 反应堆模型深度拆解:从红黑树到回调闭环,手写高性能回射服务器
linux·运维·服务器·开发语言·c++·unix
sdszoe49227 小时前
Windows server服务器AD+DC网络服务器运维管理方式
运维·服务器·windows·ad+dc·集中式管理·域控制器dc
Agent手记7 小时前
药物研发数据处理或GSP合规管理医药Agent推荐:2026数智医药全链路自动化实战
运维·人工智能·ai·自动化