从零搭建Robot Framework+Jenkins持续集成环境

简介: 安装Jenkins系统环境:CentOS Linux release 7.3.1611 x86_64 GNU/Linux安装JDKJenkins是基于Java开发的持续集成系统(CI),所以运行环境必须安装JDK,安装JDK的方法有很多种,有些Linux系统可能会自带openjdk,需要注意的是较新版本的jenkins并不支持低版本的JDK.

安装Jenkins

系统环境:CentOS Linux release 7.3.1611 x86_64 GNU/Linux

安装JDK

Jenkins是基于Java开发的持续集成系统(CI),所以运行环境必须安装JDK,安装JDK的方法有很多种,有些Linux系统可能会自带openjdk,需要注意的是较新版本的jenkins并不支持低版本的JDK.

[root@JDu4e00u53f7 ~]# java --version
java version "1.7.0_131"
OpenJDK Runtime Environment (rhel-2.6.9.0.el6_8-x86_64 u131-b00)

如果命令的输出如上,则这需要先卸载自带的低版本openjdk,然后手动安装sunjdk,sunJDK1.8 官网下载地址,下载.rpm和.tar.g格式的安装包都可以,但是要注意jdk位数。

jdk-8u11-linux-x64.tar.gz百度云 密码: 7kxw

img_8c19c437ce47977b9a6a8d4468d43814.png

我在安装的时候,遇到了一个坑,截至到目前,JDK最新版本为9.0.1,但是Jenkins最新版本v2.86并不支持JDK 9。官方说明如下:

Jenkins packages (deb IIRC) declared a Java 7+ dependency, in some configurations that resulted in Java 9 being downloaded.We no longer declare Java dependencies for that reason, as Jenkins does not work with Java 9.

使用JDK9,安装Jenkins后可能会遇到下面的错误。

img_2caaa288c6a0ef4dea66e84f831e11ba.png

下载成功后,上传到服务器,JDK安装步骤如下:

[root@JDu4e00u53f7 ~]# cd ~
[root@JDu4e00u53f7 ~]# mkdir /usr/java
[root@JDu4e00u53f7 ~]# mv jdk-8u11-linux-x64.tar.gz /usr/java/
[root@JDu4e00u53f7 ~]# tar -zxvf jdk-8u11-linux-x64.tar.gz 

···配置全局环境变量(所有用户均可用)···
[root@JDu4e00u53f7 ~]# vi /etc/profile
添加如下内容:JAVA_HOME根据实际目录来
   export JAVA_HOME=/usr/java/jdk1.8.0_11
   export JRE_HOME=/usr/java/jdk1.8.0_11/jre
   export CLASSPATH=.:$JAVA_HOME/lib:$JRE_HOME/lib:$CLASSPATH
   export PATH=$JAVA_HOME/bin:$JRE_HOME/bin:$JAVA_HOME:$PATH
   
···重载配置文件···
[root@JDu4e00u53f7 ~]# source /etc/profile

安装完成后使用java - -version可以查看安装情况:

img_1ba34e7d6612673a864cf9044be96c8c.png

可能出现的错误信息: bash:./java: cannot execute binary file , 出现这个错误的可能原因是你在32位的操作系统上安装了64位的JDK.

安装Jenkins

Jenkins下载地址,推荐下载war包,如果对版本没特别要求,直接下载最新版本就好。The lastest version 为2.86,以下所有的介绍和说明都是基于此版本,Jenkins迭代速度非常快,若版本不同,页面可能会有区别。

img_663c02718e4adf5c99001367ac4dded8.png
Jenkins release

img_e81bdd9fb31c13f2ef07a3dbc3b8aa23.png

安装Jenkins的方式有两种 : 如果服务器上已安装了Servlet容器,如Tomcat, 直接把war包放到webapps目录下,然后启动Tomcat就可以了;如果服务器没有安装Servlet容器,那也没有关系,因为Jenkins的war包里内置了Jetty,只需运行以下命令:
java -jar jenkins.war --httpPort=8080
--httpPort用来指定Jenkins服务端口,默认8080 ,如果该端口已被占用,则可以用来更换端口。运行命令行后,当在终端的启动日志中看到这行信息时: INFO:Jenkins is fully up and running, 代表Jenkins服务已经启动。
img_08ca74ea4029803dfa861e50b76d954a.png

结合Linux nohup& 命令,我们可以让Jenkins服务永久的在服务器后台运行。
nohup java -jar jenkins.war --httpPort=8080 &
其中, nohup用来不挂断的运行命令(即忽略挂起信号,永久执行命令), & 加在结尾来让命令在后台运行,所以 nohup command & 的合起来使用的意思就是让command 永久的在后台执行。

可通过Jobs命令查看后台运行任务,如果想将某个程序调回前台控制,只需要 fg + 编号 即可,此时如果要终止程序,只需Ctrl+C 即可退出程序。

[1]+  Running         nohup java -jar jenkins.war --httpPort=8080 &

$ fg 1
nohup java -jar jenkins.war --httpPort=8080

Jenkins启动成功后,剩下的配置工作将全部在浏览器中进行,十分方便。

配置Jenkins

在浏览器上输入网址访问Jenkins: http://IP:Port ,如:http://localhost:8080

解锁服务

第一次启动Jenkins时,需要验证账户。只需要在给出的文件路径下将密码拷贝一份到表单中即可验证完成。
$ cat /root/.jenkins/secrets/initialAdminPassword

img_9a5d86166d1eff42c99acb5c166026c3.png
image

Customize Jenkins

正常情况下,会进入安装插件页面。点击Install suggested plugins,安装Jenkins建议安装的插件。

img_8e987da187a7f83e8b4f3cdef541152e.png
image
img_3d81fdde771264dbfeff3d8108712059.png
image

如果在进入这一步时,遇到了Offline问题,没有关系,这是由于你的Jenkins服务器没有科学上网,点击跳过插件安装就好,后续我们可以自行安装插件,详见下文“安装插件”部分的内容。

img_6e9e601825d4dac7c2a9bd2d5f0f6360.png
image

Create First Admin User

配置管理员用户账号/密码,这个账号密码一定要保存好,不然补救措施比较麻烦。

img_d7eb4a61ca54a1f6a3d84a16f664cfba.png
image

完成确认后,点击Start using Jenkins,进入Jenkins使用页面!
img_2150af7c9bb330b50c37d0bc1e042db1.png
image

补充:Jenkins的配置信息已经插件都会放到 ~/.jenkins/ 目录下,这个也是Jenkins的主目录,它默认是隐藏的。所以如果需要重新初始化安装Jenkins ,只需要清理掉 ~/.jenkins目录即可。

img_922992b6cbfebb1d8ce73f6fa4b8ab5a.png
image

关闭/重启Jenkins

我们用jar -jar jenkins.war 来启动jenkins服务器后,可以使用以下方法关闭或重启Jenkins服务。

关闭Jenkins 服务

只需要在访问Jenkins的url地址后加上exit,如http://localhost:8080/exit , 回车后会跳转到以下页面,点击Retry using POST按钮,即可关闭Jenkins.

img_7abab2cb56c66e13270fd4d1c0b075f2.png
image

重启Jenkins 服务

将上面的exit改为restart后就可以重新启动jenkins服务器。

重载Jenkins配置文件

将上面的restart改为reload就可以实现重新加载Jenkins配置信息。

安装插件

Jenkins安装插件时,既可以选择在线安装,也可以离线安装。

在线安装

在线安装首先要保证Jenkins服务器可以上网。安装方法为:点击 ‘系统管理(Configure System)->插件管理(Manage Jenkins),选择可选插件,搜索需要的插件后直接安装即可。

img_1fbc6911bdd78c3bcb1434b058d86fdc.png
image
img_b69d512f230b8ae42da4fd88d341ed4e.png
image

​ 如果出现插件无法安装或安装失败的情况,尝试修改Jenkins配置文件(.jenkins/是隐藏目录):
$ vi .jenkins/hudson.model.UpdateCenter.xml

把'https'修改为'http'后,重载Jenkins配置信息。

img_843683082336443170f2df181e75ffd9.png
image

如果仍不能解决问题,可能是Jenkins源的问题,可以尝试换一个源码,打开刚才的配置文件,把URL换成 http://mirror.esuni.jp/jenkins/updates/update-center.json ,重启Jenkins,查看是否可以成功安装插件。

若以上方法都不能解决问题,请尝试插件离线安装方法。

离线安装

首先下载所需的Jenkins插件, 然后打开:系统管理-插件管理-高级,点击上传插件,选择扩展名为.hpi的插件。

img_8332050ddfc72f3ab0294d30fb518b16.png
image
上传成功后,插件自动安装。安装成功后, 重启Jenkins后生效。

img_081c86e4acf091a4510119a7bf264e36.png
image

离线安装插件时,可能会因为依赖缺失的问题而导致安装失败。出现该种问题时,可以在Jenkins终端的输出日志中找到依赖的插件,先安装需要的依赖后,再安装插件。

由于是和rf集成,所以这里需要下载插件Robot Framework Plugin ,插件介绍详见Jenkins Wiki .

img_bdf6d2ed580868bc992dcc79eb80f18a.png
image

配置Slave

创建Slave

启动Jenkin服务的这台机器在Jenkins中被称为Master,而其他连到Master上的机器(物理机或虚拟机)被称为Slave. Master/Slave相当于 Server 和 Agent 的概念。Master 提供web接口让用户来管理 Job 和 Slave,Job 可以运行在Master本机或者被分配到Slave上运行。一个Master可以关联多个Slave用来为不同的Job或相同的Job的不同配置来服务。

img_ef60a2f573618ee30c5a37aadf58ca62.png
image

进入系统管理->管理节点页面点击左侧的新建节点,输入节点名称,并选择固定代理(Dumb Slave),如果已经添加过节点了,也可以选择复制现有节点,It doesn't matter.

img_fa3064aeadc082b5d498d84597be6a0f.png
image

点击OK后进入有节点设置页面,此页面上有一些配置项,概要说明如下。

img_4733a14522501e7b9035d278c65e7b52.png
image
  • 并发构建数(# of executors): 这个值控制着Jenkins并发构建的数量,如果是UI测试的Job,最好只允许1个,其他的可以设置为多个;

    img_a18826add54eb12080bf0579dcfd033f.png
    image
  • 远程工作目录: 设置此节点远程工作目录的路径,在这个节点上运行的Job都会保存到工作目录里,此配置项必须设置;

img_b9b9620865b279e5e2365e5882bfee31.png
image
  • 标签:作用等同于robot framework中的tags, 可以设置Jobs只在特定的执行机上运行。如果指定固定的某个Slave,可能上面已经有Job在运行了,此时就要等待了;但是如果有一批Slave使用同一个tag,只要此处配置Job要运行到这个tag上,那么哪台Slave空闲就会在哪台机器上执行。

    img_61f7014b391b6e607c4db4bd6b93a6c6.png
    image
  • 用法: 控制Jenkins如何在这台机器上安排构建,只有两个选项;

    img_e8ce2f6937723c40e85024326d64be5d.png
    image
  • 启动方式: 设置Jenkins Master如何启动Slave agents,当Job被分配到Slave上运行的时候,此时Master和Slave其实是建立的双向字节流的连接。默认情况下,是没有"通‘过Java web启动代理"这一选项的,需要手动配置Jenkins。

img_7c9f86fe5d844ceacdd531e10ae28594.png
image

配置Jenkins使其支持通过Java web启动代理的方法如下:

  1. 打开首页-系统管理-全局安全配置(Configure Global Security);

  2. 代理 - TCP port for JNLP agents设置为“随机选取”;

img_f854757319d1143237ae21e644f07905.png
image
  1. 点击代理协议,勾选全部选项;

    img_180dbe9e1ead97b7a58132ace2a55988.png
    image
  2. Hidden security warnings中的Enable Agent需要打钩选中;

    img_a3b17830a74e4ea69b53a74141d4689f.png
    image

保存后,配置节点时就可以看到"通‘过Java web启动代理" 这一选项了。

一般来说,选择通过Java Web这种方式启动Slave agents就可以了,这种方法需要你登录到Slave机器,详尽的启动步骤后面会描述。若在Master上运行cases,通常是隐藏进程运行的,这就导致如果我们的cases有UI层面的部分,很大可能会运行失败,这样的话我们就需要添加一个Slave节点来执行。大多数实际应用中,会有多台机器需要加入Jenkins,所以添加Slave更是必不可少的。

启动Slave

在Slave列表页可以看到,刚才创建的Slave图标上有一个红色的叉号,这代表当前此Slave处于offline状态。点击Slave名称,可以看到Jenkins给出了两种启动的方法,如下:

img_7f6e93b666bbc6f2f42fa1f4bdf7af78.png
image

windows系统下,个人觉得第一种方法比较简单,点击【Launch】,会下载一个名为 "Slave-agent.jnlp"的文件,然后双击该文件就可以启动Slave了。

img_d436068ea0291254b311857ad85d0995.png
image

正常情况下,此时再去查看Slave列表,会发现图标上面的红叉已经消失了。

img_f14b6e7f6db97913a517bf82ac80abd5.png
image

我的Slave节点的系统为win10,双击启动文件时,会报以下错误:

img_a6157b2c47d603c5b52c0a5e52f4967c.png
image

这个问题可能是由于工作目录丢失引起的,需要你在Slave远程工作目录下新建一个名为remoting的文件夹就可以正常启动了。

配置 Job

在Jenkins首页的左侧菜单栏,点击新建任务,输入一个任务名称,并选择“构建一个自由风格的软件项目”,点击确定进入配置Job页面。

img_2bd15ad8aac658bf2a546b4b03b6693e.png
image

配置Job页面分为六个部分,分别为General,源码管理,构建触发器,构建环境,构建,构建后操作,下面将会对这几部分的内容分别进行简要的说明。

General

  • 丢弃旧的构建

因为每构建一次Job都会有记录,如果构建次数很多,也可能会占用很多硬盘资源。因此,这个设置就是可以让我们控制丢弃旧的构建。
img_482ed0f147141a081cf56e7d14dfc736.png
image
  • 参数化构建过程

    此处可以设置增加一些不同类型的参数,在构建时通过修改这些参数的值,来方便的改动一些配置。比如说用来打包APP的 Job,就可以加上版本号、环境等参数,在运行Jobs时简单的修改参数值,就可以打出指定的版本号和环境等满足条件的安装包。

    img_1907dbcc5e15e889a8761352e1263116.png
    image
  • 关闭构建

    选中此项后,将不会执行此项目的新构建,这在某些情况下可能会很有用。

  • 在必要的时候并发构建

    选中此项后,当此项目有多个构建任务时可以并发执行。默认情况下,Jenkins默认是串行构建任务的,其他任何开始构建项目的请求都将保留在构建队列中,直到第一个构建完成为止。

  • 限制项目的运行节点

    选中此项后,需要输入一个标签表达式作为参数,意为指定当前Job只能在指定的Slave上执行。前面介绍Slave的时候也提到了标签,我推荐使用标签。因为如果直接使用Slave名称的话,可能会在Job比较多的时候造成拥堵,而使用标签后,只要是带有这个标签的Slave,哪个空闲就会安排那个执行,这样可以使资源充分利用,提高效率。

源码管理

Job中配置源码管理的前提是Jenkins服务器已经安装了对应的源码管理工具。Jenkins有很多种源码管理工具可以选择,但是需要下载响应的插件才可以,比如git,则需要安装Git client plugin 和 Git plugin插件。

img_b434b96053d37b44a2d99fd7f4750e5c.png
image

其实,此处没有设置版本管理工具也不是不行,这样的话就需要手动去做更新的动作,加大了人力成本,Jenkins也不推荐这样做。如果大家的Cases使用了版本管理,这样在Cases更新后,Job就会自动Fetch最新的代码来运行,十分方便。

SVN(Subversion)

img_4897f32dd3b45f0bbd23714e19ec1745.png
image
  • Repository URL :SVN库的地址;

  • Credentials: 证书设置,点击查看具体步骤;

  • Local module directory : 指定一个本地目录作为SVN检出到本地路径,可以为空。

  • Repository depth:需要检出的文件夹深度,默认设置为infinity(无穷大);

这几个配置好了,基本上就可以使用了。如果有多个不同的SVN库要检出的话,可以点击"Add moudle"来添加新的配置。

Git

Git的配置比较简单,只需要配置好Repository URL(Git库地址),Credentials(证书),并选择一个分支就可以了。

img_02834390018759e822fa8b0c854ffb10.png
image

构建触发器

可以手动来触发一个构建,也可以通过触发器来自动构建,这里的设置需要根据项目情况自行考虑设置。设置构建触发器时,支持同时设置多个不同类型的触发器;

  • Build after other projects are built

    这个选项是在其他Job构建之后,触发当前项目构建。在构建后操作中也有一个"Build other projects"选项,作用其实和这边是一样的。区别就在于,在此处配置,则当前Job是被触发的对象,而在构建后操作配置,则当前项目就是触发者;

    img_d02f29f5b4b1c3002b41c102253ed1d3.png
    image

    前面提到的"自动编译打包→自动部署→单元测试/代码扫描→自动测试"这一套流程,就是通过在这个地方进行配置的。对于自动化测试的Job来说,如果前面的Job没有构建成功,这里再构建也没什么必要,所以此处的可以选择"只在构建稳定时触发";

  • Build periodically

    此选项需要配置一个时间表达式,让Job在满足时间表达式的情况下执行构建,此处的语法遵循Linux cron服务的时间表达式语法(但有细微差别),并会自动检测语法正确性。点击文本框右边的问号就可以看到语法的帮助说明。

    img_2a75976208043b4dce03ed8433e6d850.png
    image
  • Poll SCM

    Poll SCM 这里配置的时间表达式和前一个是完全一样的,只不过这个选项是只有在检测到版本库有更新时,才会触发执行。如果版本库没有更新,即使满足了时间表达式,也不会触发Job的构建。

  • 触发远程构建

    ​PASS.

构建

这里可以选择增加构建步骤,如果Slave是Windows系统,建议选择"Execute Windows batch command"来执行dos命令进行构建,其他平台,如Linux,可以选择"Execute shell",如果项目集成了Ant或Maven,也可以选择对应的选项。

pybot完整的命令行参数,可以在cmd下输入pybot --help查看。

img_56aad824f815a70207d1b7f0ed74730e.png
图片.png

构建后操作

构建后操作可选的项同样有很多,根据用户安装的不同插件,可以实现不同的需求,如分析测试结果,发送邮件通知等。

由于我们的Jobs是和rf集成, 所以我们要增加构建后的步骤是Publishes Robot Framework test results, 只有安装了Robot Framework Plugin 插件才会出现该选项,界面如下所示:

img_4b96350aa7b3002f849b6748ebd78ee3.png
image

Directory of Robot output 可以为空,如果前面的pybot命令使用参数-d 指定了输出目录,那么这里也必须要进行设置,否则插件找不到output.xml文件,也就无法解析结果了。所以这里设置的路径是RF运行后产生的xml和html文件所在的目录。

Directory of Robot output 用来设置临界值,一般都设置为100%,表示只要有案例运行失败,则Job的状态就是unstable. 此参数的介绍如下:

Specify thresholds for marking a build unstable or passed. Thresholds are expressed in percentage of tests that passed compared to total amount of tests run. Builds with pass percentage under the blue threshold wild be marked unstable and pass percentage under yellow threshold will yield a failed build.

If "Use thresholds for critical tests only" is selected thresholds will be compared to the pass ratio of critical tests instead of all tests.

配置Jenkins邮件通知

Jenkins本身自带的邮件通知功能较弱,我们可以通过下载'Email Extension Plugin'' 插件来自定义更高级的邮件通知功能。

具体配置步骤,请参照:https://zhuanlan.zhihu.com/p/22810691

【To be continued...】

参考文档

  1. 使用Jenkins进行持续集成, 廖雪峰

  2. linux下利用nohup后台运行jar文件包程序 ,一汪清水

  3. 用Jenkins构建一个新工程,我们一起试一下 ,幕客老师

  4. Jenkins-持续集成平台(安装篇) ,幕客老师

  5. Jenkins入门系列之——01第一章 Jenkins是什么? ,wangmm0218

  6. Jenkins Master/Slave架构, iTech

  7. Jenkins Guided Tour

  8. 基于jenkins搭建一个持续集成服务器,YaiHo

  9. Jenkins常用插件说明(持续更新) ,小学徒V

  10. Jenkins使用教程之关联节点 ,MR_Hanjc

  11. Jenkins 2.19.4默认没有Launch agent via Java Web Start,可通过以下来设置: , jgw2008

  12. jenkins Error performing command: git ls-remote -h , wangfei0904306

  13. Jenkins入门总结 ,iTech

  14. Robot Framework自动化测试修炼宝典[书],齐涛 著

  15. Jenkins的Credentials(证书)管理 ,张侦毅

  16. 配置Jenkins邮件通知, 邓布利多·雪​

相关文章
|
2月前
|
jenkins Devops Java
DevOps实践:Jenkins在持续集成与持续部署中的价值
【10月更文挑战第27天】在快速发展的软件开发领域,DevOps实践日益重要。Jenkins作为一款流行的开源自动化服务器,在持续集成(CI)和持续部署(CD)中扮演关键角色。本文通过案例分析,探讨Jenkins在Java项目中的应用,展示其自动化构建、测试和部署的能力,提高开发效率和软件质量。
76 2
|
29天前
|
监控 jenkins Linux
从 Jenkins 持续集成出发:探究如何监控员工电脑屏幕
Jenkins 在企业信息化管理中用于自动化构建、测试和部署,提高开发效率。本文讨论了其重要性,并从技术角度探讨了屏幕监控的可能性,但明确反对非法监控,强调应合法合规地管理企业和尊重员工隐私。
69 12
|
2月前
|
存储 Prometheus 运维
在云原生环境中,阿里云ARMS与Prometheus的集成提供了强大的应用实时监控解决方案
在云原生环境中,阿里云ARMS与Prometheus的集成提供了强大的应用实时监控解决方案。该集成结合了ARMS的基础设施监控能力和Prometheus的灵活配置及社区支持,实现了全面、精准的系统状态、性能和错误监控,提升了应用的稳定性和管理效率。通过统一的数据视图和高级查询功能,帮助企业有效应对云原生挑战,促进业务的持续发展。
48 3
|
2月前
|
运维 jenkins Java
Jenkins在持续集成与持续部署中的价值
Jenkins在持续集成与持续部署中的价值
|
2月前
|
jenkins Devops 测试技术
DevOps实践:Jenkins在持续集成与持续部署中的价值
【10月更文挑战第26天】随着DevOps理念的普及,Jenkins作为一款开源自动化服务器,在持续集成(CI)与持续部署(CD)中发挥重要作用。本文通过某中型互联网企业的实际案例,展示了Jenkins如何通过自动化构建、持续集成和持续部署,显著提升开发效率、代码质量和软件交付速度,帮助企业解决传统手工操作带来的低效和错误问题。
92 4
|
3月前
|
jenkins Java 持续交付
Docker搭建jenkins环境
这篇文章详细介绍了如何利用Docker搭建Jenkins环境,包括拉取Jenkins镜像、配置端口映射及初始化设置的步骤。
247 0
Docker搭建jenkins环境
|
3月前
|
jenkins Shell 持续交付
Jenkins持续集成GitLab项目 GitLab提交分支后触发Jenkis任务 持续集成 CI/CD 超级详细 超多图(二)
Jenkins持续集成GitLab项目 GitLab提交分支后触发Jenkis任务 持续集成 CI/CD 超级详细 超多图(二)
86 0
|
3月前
|
jenkins Shell 持续交付
Jenkins持续集成GitLab项目 GitLab提交分支后触发Jenkis任务 持续集成 CI/CD 超级详细 超多图(一)
Jenkins持续集成GitLab项目 GitLab提交分支后触发Jenkis任务 持续集成 CI/CD 超级详细 超多图(一)
273 0
|
5月前
|
jenkins 持续交付 开发者
自动化部署:使用Jenkins和Docker实现持续集成与交付
【8月更文挑战第31天】本文旨在为读者揭示如何通过Jenkins和Docker实现自动化部署,从而加速软件开发流程。我们将从基础概念讲起,逐步深入到实际操作,确保即使是初学者也能跟上步伐。文章将提供详细的步骤说明和代码示例,帮助读者理解并应用这些工具来优化他们的工作流程。
|
5月前
|
jenkins 持续交付 网络安全
利用 Jenkins 实现持续集成与持续部署-代码拉取终端的配置
【8月更文挑战第30天】在Jenkins服务器中,git和Gitee是常用的代码拉取终端。Git作为分布式版本控制系统,具备出色的灵活性和可扩展性;而Gitee则在国内网络环境下表现更佳,适合团队协作。Git配置包括安装、设置用户信息及生成SSH密钥等步骤;Gitee配置也类似,需注册账号、创建仓库、配置基本信息并设置远程仓库地址。开发人员提交代码后,可通过Webhook、定时轮询或事件监听等方式触发Jenkins动作,确保持续集成和部署高效运行。正确配置这些触发机制并通过测试验证其有效性至关重要。
80 2