jenkins pipline 自动化测试

以下是一个典型的 Jenkins Pipeline 示例,用于执行自动化测试流程(支持单元测试、集成测试、代码质量扫描),包含多阶段执行和测试结果处理:

groovy 复制代码
pipeline {
    agent any
    environment {
        // 定义环境变量
        PROJECT_NAME = "my-project"
        TEST_RESULTS = "**/test-results/*.xml"
        ALLURE_REPORT = "allure-report"
    }
    stages {
        // 阶段1:代码检出
        stage('Checkout') {
            steps {
                git branch: 'main', 
                     url: 'https://github.com/your-org/${PROJECT_NAME}.git'
            }
        }

        // 阶段2:依赖安装
        stage('Install Dependencies') {
            steps {
                script {
                    // 根据项目类型选择安装方式
                    if (fileExists('pom.xml')) {
                        sh 'mvn clean install -DskipTests'
                    } else if (fileExists('package.json')) {
                        sh 'npm install'
                    }
                }
            }
        }

        // 阶段3:单元测试
        stage('Unit Tests') {
            steps {
                script {
                    try {
                        if (fileExists('pom.xml')) {
                            sh 'mvn test' // Java项目
                        } else if (fileExists('package.json')) {
                            sh 'npm run test:unit' // Node.js项目
                        }
                    } finally {
                        // 收集JUnit格式测试报告
                        junit allowEmptyResults: true, testResults: '**/surefire-reports/*.xml'
                    }
                }
            }
        }

        // 阶段4:集成测试
        stage('Integration Tests') {
            steps {
                script {
                    // 启动测试环境(例如Docker compose)
                    sh 'docker-compose -f docker-compose.test.yml up -d'
                    
                    // 执行集成测试
                    sh './run-integration-tests.sh'
                    
                    // 收集集成测试报告
                    junit '**/integration-test-results/*.xml'
                }
            }
            post {
                always {
                    // 清理测试环境
                    sh 'docker-compose -f docker-compose.test.yml down'
                }
            }
        }

        // 阶段5:代码质量检查
        stage('Code Quality') {
            steps {
                // 使用SonarQube进行代码扫描
                withSonarQubeEnv('sonar-server') {
                    sh 'mvn sonar:sonar' // 或对应语言的扫描命令
                }
            }
        }

        // 阶段6:生成Allure报告
        stage('Allure Report') {
            steps {
                script {
                    allure([
                        includeProperties: false,
                        jdk: '',
                        properties: [],
                        reportBuildPolicy: 'ALWAYS',
                        results: [[path: 'allure-results']]
                    ])
                }
            }
        }
    }
    post {
        always {
            // 清理工作空间
            cleanWs()
        }
        success {
            // 测试成功通知
            emailext body: '${PROJECT_NAME} 自动化测试通过,报告地址:${BUILD_URL}Allure_20Report/',
                    subject: 'SUCCESS: ${PROJECT_NAME} Build ${BUILD_NUMBER}',
                    to: 'team@example.com'
        }
        failure {
            // 测试失败通知
            emailext body: '${PROJECT_NAME} 自动化测试失败,详情:${BUILD_URL}console',
                    subject: 'FAILED: ${PROJECT_NAME} Build ${BUILD_NUMBER}',
                    to: 'team@example.com'
        }
    }
}

关键配置说明:

  1. 环境准备

    • 安装必要插件:
      • Pipeline
      • JUnit
      • Allure
      • Email Extension
      • SonarQube Scanner
    • 配置全局工具(JDK/Maven/npm等)
  2. 流程设计

    • 并行优化 :可将单元测试和代码质量检查改为并行执行

      groovy 复制代码
      stage('Parallel Stages') {
          parallel {
              stage('Unit Tests') { ... }
              stage('Code Quality') { ... }
          }
      }
    • 动态参数 :可通过 parameters 块添加分支选择等参数

  3. 测试报告集成

    • JUnit:自动解析XML报告显示趋势图
    • Allure:生成交互式测试报告(需提前配置Allure命令行工具)
    • SonarQube:代码质量门禁检查
  4. 通知机制

    • 邮件通知(推荐使用HTML模板)

    • 可扩展Slack/MS Teams通知:

      groovy 复制代码
      slackSend channel: '#automation', 
                 message: "Build ${currentBuild.result}: ${env.JOB_NAME} ${env.BUILD_NUMBER}"

项目适配建议:

  1. Java项目

    groovy 复制代码
    // Maven命令示例
    sh 'mvn test' 
    junit '**/surefire-reports/*.xml'
  2. Node.js项目

    groovy 复制代码
    // npm命令示例
    sh 'npm run test:coverage'
    junit '**/junit.xml'
  3. Python项目

    groovy 复制代码
    // pytest示例
    sh 'pytest --junitxml=test-results.xml'
    junit 'test-results.xml'

典型执行效果:

  1. 可视化阶段执行状态
  2. 自动关联测试报告
  3. 历史趋势分析(通过Jenkins图表)
  4. 邮件/Slack实时通知

建议根据实际项目结构调整测试命令和报告路径。可通过 Jenkins Blue Ocean 插件获得更直观的流水线可视化效果。

相关推荐
乘云数字DATABUFF3 天前
5分钟部署开源APM Databuff:OpenTelemetry全链路追踪入门实战
运维·后端
荣--5 天前
一键部署不是为了省时间 —— 它是把"买来的 PaaS"变成"自己的平台"的拐点
运维·zabbix·工程化·一键部署·平台化·边界设计
江华森5 天前
动手实战学 Docker — 从零到集群编排完全指南
运维
Avan_菜菜6 天前
FRP 内网穿透完整实战:从 HTTP 映射到 HTTPS 自签代理
运维·nginx·https
SelectDB7 天前
Litefuse 开源并推出单进程轻量模式,25 秒就能跑起来的 Agent 可观测与评估平台
运维·后端·自动化运维
XIAOHEZIcode8 天前
Linux系统鼠标偏移常见原因以及修复方案
linux·运维·游戏
用户0328472220709 天前
如何搭建本地yum源(上)
运维
大树8812 天前
金刚石散热越强,管路越先见顶
大数据·运维·服务器·人工智能·ai
摇滚侠12 天前
Linux CentOS7 rpm 安装 MySQL 5.7
linux·运维·mysql
霸道流氓气质12 天前
领域驱动设计(DDD)在 Spring Boot 微服务中的实践指南
运维·spring boot·微服务