使用VSTS/TFS搭建iOS持续集成环境

TFS 自2015版开始支持跨平台的持续集成环境,通过提供开源的build agent为 Windows / Linux / macOS 提供了统一的持续集成环境管理能力。这篇文章给大家介绍一下如何使用 VSTS/TFS 来搭建 iOS 持续集成环境。

苹果的iOS开发平台是一个相对封闭的生态,开发人员必须使用macOS和XCode才能完成应用程序的编译和打包操作,但这并不妨碍你使用其它的操作系统进行编码和测试。比如使用跨平台开发技术,如 Apache Cordova, React, Xamarin 等你完全可以使用 Windows 作为你的开发环境,使用自己喜欢的IDE,如: Visual Studio, Eclipse, IntelliJ甚至 Visual Studio Code, Sublime等进行编码开发,只是在最后需要打包成ipa的时候你还是需要一台macOS才能完成。所以,我们今天就按照最典型的原生应用的开发方式,看看如何使用VSTS/TFS来搭建持续集成环境。

另外,在后续的文章里,我还给大家介绍如何使用VSTS/TFS将打包好的iOS应用直接发布到 Apple Store上。

#1 创建项目或者获取项目代码

为了演示方便我在github上放置了代码
https://github.com/ups216/FoodTracker

打开Xcode 获取代码

ios-ci-01

#2 在TFS中创建 git repo并添加到项目的remote地址中

ios-ci-02

从新建的repo上获取地址

ios-ci-03

在XCode中添加remote

ios-ci-04

ios-ci-05

然后push代码到tfs中

ios-ci-06

ios-ci-07

#3 从github下载vsts-agent并链接到我们的tfs项目

下载地址: https://github.com/Microsoft/vsts-agent/releases

并按照以上页面中的说明进行安装

~/$ mkdir myagent && cd myagent
~/myagent$ tar xzf ~/Downloads/vsts-agent-osx.10.11-x64-2.107.0.tar.gz

安装完成后,运行config.sh配置代理

ios-ci-08

这里需要填写2个关键参数,一个是服务器地址,另外一个是agent pool(构建代理池)的名称

构建代理池可以在tfs的后台配置页面中进行配置,记得要把运行代理的帐户添加到代理池的服务帐户中

ios-ci-09

现在我们就可以运行 run.sh 来启动我们的构建代理了

ios-ci-10

#4 创建持续集成定义

在TFS的生成页面中点击新建按钮,并选择 Xcode 构建模版

ios-ci-11

在选择存储库页面中选择我们刚刚推送过代码的FoodTracker存储库,并勾选“持续集成”选项,这样每次我们推送代码到这个存储库就会自动触发生成。

ios-ci-12

创建完成后,我们首先切换到“变量”页面中配置以下参数

ios-ci-13

注意这里的最后一个参数 P12_PWD,这里我使用了一个加密的变量保存了我的开发者账号P12证书的秘密,这样我就不必将开发者证书分发给所有需要的开发人员,而只在服务器上保留这个证书。这对于使用企业证书进行开发的团队尤其有用,避免了企业证书的外泄。

完成后我们进入“生成”页面,对XCode构建任务进行配置,注意以下我在certificate这个代码目录中保存了从XCode或者苹果开发者中心导出的 Provision Profile 和 P12证书文件,但是证书的密码这一栏填入了以上配置的参数 $(P12_PWD)。这样,我们就可以在CI的过程中完成 ipa 的签名操作了。

ios-ci-14

#5 运行生成

你可以在Xcode修改代码并推送到 TFS,这时构建代理将被自动触发运行,或者也可以手动运行。

ios-ci-15

运行成功后,可以在构建页面中点击“项目”即可下载编译打包好的ipa文件

ios-ci-16

ios-ci-17

简单总结一下,使用VSTS/TFS我们不仅仅可以管理Windows环境上的项目开发,也可以很好的管理 macOS 和 Linux上的开发过程。新版的TFS中内置了很多针对跨平台开发的构建任务,而且这些任务的源代码都是开源的,这样我们可以对不同平台的开发团队进行统一的管理,并进行统一的代码质量度量。

对于iOS开发来说,开发者证书的管理是很多稍具规模的团队都很头疼的事情,如果不把证书分发给每个开发者,就无法打包,但是分发了证书就意味着任何获取了证书的开发者都可以使用企业的证书分发应用。使用集中的CI来完成证书签名操作就很好的解决了这个问题。

相关内容:

 

请关注微信公众号 【devopshub】,获取更多关于DevOps研发运维一体化的信息

qrcode_for_gh_b7c158df1fd1_430