通过Jenkins Pipeline配合MeterSphere完成自动化接口测试

发布于 2022年02月24日

Jenkins作为一款开源、免费且方便扩展的自动化服务器,是很多团队DevOps流水线中的重要一环。通过不同开发者提供的众多插件,Jenkins可以集成持续集成和持续交付工具链中几乎所有的工具。

定位为一站式开源持续测试平台的MeterSphere同样也提供了对应的Jenkins插件(https://github.com/metersphere/jenkins-plugin)。通过这个插件我们可以在Jenkins上触发MeterSphere平台中维护的测试任务,将测试环节纳入到现有的流水线中,帮助我们实现持续测试的目标。

在Jenkins中主要有两种类型的任务:一种是通过UI交互完成任务配置的自由风格任务;另一种是通过Jenkins提供的特定语法编写脚本的Pipeline类型任务。Pipeline类型的任务不仅在创建和执行上更加灵活,而且由于所有构建过程都通过脚本方式来定义,我们可以很方便地把Pipeline脚本也纳入到代码仓库中进行管理,实现“Pipeline as Code”的效果。

MeterSphere提供的Jenkins插件对这两种任务类型都进行了支持。本文主要介绍Jenkins Pipeline类型的任务中如何使用该插件触发MeterSphere中的测试任务。

安装MeterSphere jenkins-plugin

首先,我们需要在Jenkins服务器上安装MeterSphere提供的Jenkins插件。安装该插件后就可以在Jenkins任务中添加MeterSphere构建的环节,然后在该环节中通过配置MeterSphere认证信息,并指定需要触发执行的接口测试、性能测试或测试计划。

不过目前该插件还没有上传到Jenkins的插件仓库中,我们需要手动下载插件文件并进行上传安装。插件下载及具体的安装流程可以参考jenkins-plugin(https://github.com/metersphere/jenkins-plugin)仓库中的“README”部分。

创建Pipeline任务

插件安装完成后,就可以在Jenkins中创建Pipeline任务了。

点击“新建Item”后,在该页面输入任务名称,并选择“Pipeline”类型,点击“OK”按钮,即可完成一个Pipeline任务的创建。

编写脚本

Jenkins Pipeline目前支持两种语法模式,即Declarative声明式(在Pipeline Plugin 2.5中引入)和Scripted Pipeline脚本式。关于这两种模式的差异可以进一步参考Jenkins的官方文档(https://www.jenkins.io/doc/book/pipeline/#pipeline-syntax-overview)。

以Declarative声明式语法为例,接下来我们将介绍如何在Jenkins Pipeline中使用MeterSphere插件。

MeterSphere插件共提供了以下参数供用户进行配置:

■ msEndpoint:MeterSphere服务地址(例如:https://demo.metersphere.com);

■ msAccessKey:MeterSphere上某个用户的API Access Key;

■ msSecretKey:上述Access Key对应的Secret Key;

■ workspaceId:需要触发执行的测试所在的工作空间id;

■ projectId:需要触发执行的测试所在的项目id;

■ method:触发执行的任务类型(testplan:执行整个测试计划,single:执行指定的某个测试任务);

■ testPlanId:测试计划id,method参数值为testplan时有效;

■ testCaseId:场景id/接口用例id/性能测试id,method参数值为single时有效;

■ mode:执行方式(serial:串行执行,parallel:并行执行);

■ resourcePoolId:执行测试使用的测试资源池id。

由于插件实现方式的问题,MeterSphere插件目前还不支持在声明式Pipeline中的直接引用。我们可以在声明式Pipeline中引入Script步骤, 然后在Script步骤块中引用MeterSphere插件。

具体如下图所示:

代码块如下:


pipeline {
    agent any //任意选择
    // agent { label 'local-host'}   //指定agent
    stages {
        stage('Build') {
            steps{
                echo "building"
            }
        }
        stage('Deploy') {
            steps{
                echo "deploying"
            }
        }
        stage('Test') {
            steps{
                 script {
                    meterSphere msEndpoint:'http://XXXX',
                    msAccessKey:'XXXXXX',
                    msSecretKey:'XXXXXX',
                    workspaceId:'XXXXXX',
                    projectId:'XXXXXX',
                    method:'testPlan',
                    testPlanId:'XXXXXX',
                    mode:'parallel',
                    resourcePoolId:'',
                    result:'metersphere'
                }
                script {
                    meterSphere msEndpoint:'http://XXXXXX',
                    msAccessKey:'XXXXXX',
                    msSecretKey:'XXXXXX',
                    workspaceId:'XXXXXX',
                    projectId:'XXXXXX',
                    method:'single',
                    testCaseId:'XXXXXX',
                    mode:'parallel',
                    resourcePoolId:'',
                    result:'metersphere'
                }
            }  
        }
    }
}

注意:Pipeline脚本可以直接写在编辑任务页面中;也可以存放在Git仓库的指定位置,在配置任务时再进行指定。

构建任务

Jenkins任务创建完成后可以点击“手动构建”按钮查看效果。在构建任务的控制台日志中,可以看到指定的测试计划和接口用例已经执行完成。

同时,我们进入MeterSphere持续测试平台进行查看,也可以看到接口测试已经执行成功,且测试计划报告已经生成。

① 接口用例执行结果;

② 测试计划报告已经生成。