目录
前言:
Jenkins 是一种开源的持续集成工具,可以帮助我们更加方便地进行软件开发和测试工作。通过 API 远程管理 Jenkins 可以帮助我们更加方便地进行 Jenkins 的配置和管理工作,并且可以更加灵活地进行 Jenkins 环境的搭建和部署。
背景介绍
最近接到一个需求,需要对公司内部的 Android 性能测试平台的分支管理模块进行改造。
在该系统中,Jenkins 负责定时检测代码库(Code Repository
)的代码更新情况,当检测到有新的代码提交时,自动采用最新的代码进行构建,并采用构建得到的包(apk)触发自动化测试平台(DroidTestbed
)执行测试任务。
然后再说下分支管理模块。
由于我们的持续集成平台通常不止监控一个产品,而每个产品又不止监控一个 tag(例如/trunk,/projects/cn/10.9.8),因此,我们的持续集成平台需要有分支管理的功能,即针对每一个产品的每一个 tag,单独创建一个分支,并针对各个分支单独指定测试用例集合测试设备。
具体实现方面,出于单一职责的原则,我们对功能进行了如下划分:
- 在 Jenkins 端针对每一个分支创建一个 Job;
- 在
DroidTestbed
端配置测试资源,针对每一个分支分别绑定测试用例集和测试设备,每一个分支会存在一个单独的 branch_id; - 在 Jenkins 端的 Job 配置中,保存该分支在
DroidTestbed
中对应的branch_id
,实现Jenkins
与DroidTestbed
的关联。
整个过程看上去并没有什么问题,那为什么需要对分支管理模块进行改造呢?
问题就出现在分支配置上面。
试想一下,每次要新增或修改一个分支的时候,由于 Jenkins 端和 DroidTestbed 端的配置是独立的,那么我们就只能在两个平台上分别进行配置。
另一方面,配置工作本身也较为复杂,例如,在 Jenkins 端就需要设置的参数包括:repository_url,tag,ref_tag,ref_revision,branch_id,schedule,user_name 等