React-Native 双平台应用的测试发布和 CodePush 热更新部署

初衷

最近在做一些基于 RN 的产品预研工作,当预研开发进行到一定程度时,就需要“平时多用用”了,但是继续 RN 的 debug 版本,不管是 Android 还是 ios平台,都会有烦人的 yellow box warning 提示,所以刚才完成掉一个原型产品的开发、测试、反馈闭环流程,也就是发布测试包、测试并使用、反馈以及重新发包。在 RN 的世界里,还多了一个 CodePush 热更新的内容,所以基本的流程会是 发布一个基线版本的正式包到应用分发平台(TestFlightTop) -> 反馈 -> 陆续发布基于该基线版本的 Codepush 热更新到热更新服务 -> 反馈 -> 发布更新基线版本产品形态怎么样再说,但是开发测试闭环对个人开发者来说是很重要的一点,当然最好还是将设计加入闭环。

增加 CodePush 功能和服务

客户端添加 react-native-code-push 组件

npm install --save react-native-code-push
react-native link react-native-code-push
? What is your CodePush deployment key for Android (hit <ENTER> to ignore) 
? What is your CodePush deployment key for iOS (hit <ENTER> to ignore) 
# 询问是否添加部署 key 值,这里先直接回车忽略,等部署时在生成和添加

服务端部署非微软 CodePush 服务

# 安装更新node-js和npm
sudo apt-get install nodejs-dev
sudo apt-get install npm
sudo npm install -g n
sudo n stable
node -v
npm -v

# 安装code-push-server
npm install code-push-server --save
sudo ln -s /data/codepush/node_modules/code-push-server/bin/db /usr/local/bin/code-push-server-db
sudo ln -s /data/codepush/node_modules/code-push-server/bin/www /usr/local/bin/code-push-server

# 初始化配置code-push-server, 传入 mysql 的用户名密码
code-push-server-db init --dbhost localhost --dbuser root --dbpassword xxxx

# 配置 config,将 mysql 用户名密码配置进去
node_modules/code-push-server/config/config.js

# 启动服务
export PORT=8080
export HOST=0.0.0.0
export NODE_ENV=production
code-push-server 1>/dev/null 2>&1 &

命令行登录 CodePush 服务

# 执行后会打开 web 管理页面,默认登录账号为 admin/123456, 登录后填入 token 值
code-push login http://app.airoubo.com:8080
Please login to Mobile Center in the browser window we've just opened.
Enter your token from the browser:  xxxxx
# 这以后,code-push 就都是针对本次登录操作了,如需更换,需要 code-push logout

注册待发布应用到 CodePush 服务

# ios 和 Android 需要单独添加
 » code-push app add fantuan-ios ios react-native
Successfully added the "fantuan-ios" app, along with the following default deployments:
┌────────────┬───────────────────────────────────────┐
│ Name       │ Deployment Key                        │
├────────────┼───────────────────────────────────────┤
│ Production │ tH1HvTgUq6FVrhqsv5MxCbZYLexxxxxsvXqog │
├────────────┼───────────────────────────────────────┤
│ Staging    │ yl1nhf3chhdcKDsMlczz5xxxxNxz4ksvOXqog │
└────────────┴───────────────────────────────────────┘
 » code-push app add fantuan-android android react-native

添加成功后,可以看到每个应用默认都会有两个版本线,staging(我们认为是内测版)和Production(正式版),但是为了方便,我会直接使用Production版本线进行发布。

部署热更并测试(Android)

  • 打一个使用 Production key 的 基线apk,版本号为1.0.0,安装。
// 注意codepushkey 和服务地址
new CodePush(CODEPUSH_KEY, getApplicationContext(), BuildConfig.DEBUG, "http://app.airoubo.com:8080/"),
  • 在1.0.0版本基线版本基础上修改 js 代码,生成基于该版本的热更并部署:
# 将一个基于1.0.0版本的热更新发布到 Android 的 Production 版本线上 
code-push release-react fantuan-android android --d Production --des "first codepush" --t 1.0.0
  • 由于我们将 codepush sync 的逻辑放在了主页面组件加载过程中,所以会在每次加载时都是查询热更,在下次启动时应用更新,更新成功后,通过 codepush 命令行可以看到升级信息:
componentDidMount() {
  //增加最简单的热更新触发方法
codePush.sync();
}

 » code-push deployment ls fantuan-android -k
image.png

部署热更并测试(IOS)

IOS 版本的测试,我使用了 TestFlight + CodePush 的方式,将1.0.0版本的正式包在 TestFlight 上分发,然后发布基于1.0.0版本的 CodePush 热更新。发布方式同 Android。

Apple TestFlight 也改良了,可以公开匿名邀请测试用户了:


image.png

但是继续配合 TestFlight Top 这样的平台进行测试行为的管理会更加方便,可更加方便整合 Android/IOS 两个平台的测试分发。

TestFlight.top

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

推荐阅读更多精彩内容