React Native + jenkins 自动化构建

0.环境准备

由于 ios 打包需要使用 mac,所以使用的环境为 macOS
本文为使用jenkins 自动化构建的新手教程,记录了从0到1的配置过程

(1) 安装 Jenkins

Jenkins 的安装和配置这里就不再赘述,需要的同学可以移步:https://www.jianshu.com/p/d76c9fd8dac5

这里强烈推荐使用 brew 的方式进行 Jenkins 的安装。 在官网上下载 pkg 的方式会将 Jenkins 安装到全局,会有一下权限的问题,配置起来比较繁琐,使用 brew 会安装到你的家目录下,不会遇到权限问题,省去了不必要的麻烦。
安装命令:brew install jenkins

Jenkins基础插件:

  • Git Changelog
  • Git plugin
  • GitLab Plugin

(2) 配置 ios 证书

step1: 需要下载 Jenkins 插件:

  • Xcode integration
  • Keychains and Provisioning Profiles Management

step2: 下载完成后点击:系统管理 -> Keychains and Provisioning Profiles Management

pic1

step3: 上传 login.keychain 文件

pic2

Filename:需要上传的文件位置在/Users/{user}/Library/Keychains下,新版系统没有login.keychain,只有login.keychain-db,需要复制一个 login.keychain-db 文件,重命名为 login.keychain 然后将文件上传。

tips:可以将文件直接拖到 选择文件 的位置上传

Password:Password为Mac的开机密码。

Identities:使用钥匙串打开login.keychain可以看到相关信息。

step4: 上传 Provisioning Profiles

pic3

Provisioning Profiles 文件位置:/Users/{user}/Library/MobileDevice/Provisioning Profiles

将要打包的app对应的 mobileprovision 拖到选择文件处上传,Jenkins会自动填入 FilenameUUID

Provisioning Profiles Directory Path:填入 /Users/{user}/Library/MobileDevice/Provisioning Profiles

(3) 配置 Xcode 信息

step1: 点击 系统管理 -> 系统设置

step2: 填入开发者信息

pic4

(4) 配置安卓环境

step1: 需要下载 Jenkins 插件:

  • Gradle Plugin

step2: ANDROID_HOME

在打包安卓的时候会需要变量ANDROID_HOME,需要提前配置好,否则会报错:SDK location not found

配置步骤:系统管理(Manage Jenkins) -> 系统设置(Configure System) -> 点击 环境变量(Environment variables) -> 点击 Add

pic5

Name 填入:ANDROID_HOME
Value 填入你的安卓sdk目录,例如:/Users/{user}/Library/Android/sdk

1.创建项目

(1) 点击 New 任务(New Task)

pic6

输入项目名称,并选择 构建一个自由风格的软件项目

(2) 设置Git

pic7

在 Source Code Management 中选择 Git

Repository URL:gitlab项目的http地址

Credentials:点击 Add -> Jenkins -> 分别在 Username 和 Password 的位置填入的你 gitlab 的账号密码 -> 点击 添加 -> 下拉选择刚才填入的信息

(3) 设置语言环境

点击 Add build step,选择 执行 shell,添加代码:

export LANG=en_US.UTF-8

export LANGUAGE=en_US.UTF-8

export LC_ALL=en_US.UTF-8

(4) 下载React Native项目依赖

点击 Add build step,选择 执行 shell,添加代码:

cd ${WORKSPACE}

npm install

2. ios 配置

(1) 设置构建环境

pic8

勾选红框中的两项。

pic9

Mobile Provisioning Profiles 中需要选择该项目你使用的 Provisioning Profile。

(2) 添加 ios 构建选项

点击 Add build step,选择 Xcode

(3) General build settings

General build settings,点开 setting 按钮出现更多选项:

pic10
  • 选择 Development Team
  • 勾选 Clean before build
  • Configuration 填入 Release
  • Xcode Schema File 填入项目名称
pic11
  • 勾选 Pack application, build and sign .ipa
  • .ipa filename pattern 填入打包后你的 .ipa 文件的名称
  • Output directory 填入打包后文件的输出路径

(4) Code signing & OS X keychain options

pic12

勾选 Automatic Signing

(5) Advanced Xcode build options

pic13

Xcode Project DirectoryXcode Project File 需要填入项目信息

3. android 配置

(1) 添加 android 构建选项

点击 Add build step,选择 Invoke Gradle script

(2) 配置打包指令

pic14

Tasks: build

Switches: clean assembleRelease

Root Build script: ${WORKSPACE}/android/app

至此,一个可以走通的打包流程已经结束,下面会在介绍一下其他的功能

4. 自动上传 fir

配置方法在 fir 上有非常详细的说明,配置过程移步 fir

pic15

第一项为文件路径,会将该路径下的 .ipa .apk 文件自动上传到 fir。说明:该路径不能使用${WORKSPACE},请填入完整的路径

第二项为不上传的文件名,自己看着写吧。

5. git 分支参数化构建

(1) 下载插件

  • Git Parameter Plug-In

(2) 参数化构建过程

pic16

step1: 在项目配置中选择 参数化构建过程

step2: 点击 Add Parameter

step3: 选择 Git Parameter

step4: 在 Name 中填入变量名 gitBranch

step5: 根据实际情况选择 Parameter Type

step6: 将 Git 配置中的 Branches to build 改为变量 $gitBranch

pic17

构建时点击参数构建,会自动拉出分支等让你选择需要构建的分支。

pic18
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,222评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,455评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,720评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,568评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,696评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,879评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,028评论 3 409
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,773评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,220评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,550评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,697评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,360评论 4 332
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,002评论 3 315
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,782评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,010评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,433评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,587评论 2 350

推荐阅读更多精彩内容