@style3d/taro-deploy
v1.0.0-alpha.20
Published
Auto deploy taro app
Downloads
7
Readme
taro-deploy 是什么?
如果你使用 Taro 开发小程序项目,可以使用本项目提供的命令行工具,进行一键自动化构建发布,并将构建结果推送到钉钉群里。
为什么要用 taro-deploy?
Taro 小程序开发者常有这种痛点:开发好代码想要发布提测,需要进行以下一系列步骤(以支付宝、微信小程序平台为例):
整个流程将近十分钟,其中还有不少需要手动操作的环节,可以说这种原始的发布方式效率非常低。
taro-deploy 就是为了解决这个痛点出现的,它集成了支付宝和微信提供的命令行工具,自动化地完成上述流程。
用了 taro-deploy,开发者在发布提测时只需两步:
- 运行一次命令 taro-deploy
- 去喝杯茶歇一下
构建发布完了,钉钉上就会收到构建结果的推送了,全程无需人工干预。
以下为钉钉推送消息的截图。
可以看到除了发布生成的小程序二维码,推送消息里还附带了构建机器、构建分支、项目最近的 git commit 日志等,打包信息更清楚。
NOTE: git commit 日志目前只会展示 feat
和 fix
关键词开头的 commit
使用步骤
Step 1 - 安装
npm i -g taro-deploy
Step 2 - 平台相关的准备步骤
Step 3 - 创建钉钉机器人
参考官方文档创建钉钉机器人,安全设置记得选择“自定义关键词”并填上“小程序构建”即可。
创建完成后,会得到一个形如 https://oapi.dingtalk.com/robot/send?access_token=XXXXXX
的 webhook url,后续会用到。
Step 4 - 准备配置文件
在你的 Taro 项目根目录新建一个 deploy-config.js 文件,按下述模版填入内容。
// deploy-config.js
// 该文件应放在 Taro 项目的根目录下
module.exports = {
// 构建结果的输出目录,该脚本产生的日志也会输出到这里
// outDir: './deploy-out',
// 微信相关配置
weapp: {
// 如果为 false,则不会运行微信的构建流程
enable: true,
// 这里填你们配置的 Taro 编译后微信程序包的输出路径
projectPath: './dist/weapp',
// Step 2 里获得的私钥文件的存放路径
keyPath: './weapp.key',
// 微信小程序 appId
appId: 'wx82xxxxxx',
// 微信体验版图片地址
// 与支付宝不同,不管上传多少个新版本,微信的体验版地址是一直不变的
// 因此需要在这里配置该二维码图片的链接
// 直接从微信公众平台上复制的体验版图片地址貌似无法在钉钉里正常展示
// 建议转存到自己的 CDN 上,再将 cdn url 填到下面这里来
qrcodeImageUrl: 'https://xxxcdn.con/image/weapp-exp-qrcode.jpg',
// 小程序版本号
// 由于微信的命令行 sdk 不支持设置某个版本为体验版,要改设体验版需要在网页上手动操作
// 所以只能曲线救国,先在网页上将本工具上传的版本设为体验版(找到 ci机器人1 上传的那个版本)
// 然后每次上传都指定同一个版本号,以覆盖旧的版本,最终实现发布新体验版的效果
version: '1.1.0',
// true 则将跳过编译阶段,即 taro build 命令,
skipBuild: false,
},
// 支付宝相关配置
alipay: {
// 如果为 false,则不会运行支付宝的构建流程
enable: true,
// 这里填你们配置的 Taro 编译后支付宝程序包的输出路径
projectPath: './dist/alipay',
// Step 2 里获得的私钥文件的存放路径
keyPath: './alipay.key',
// Step 2 里获得的 toolId
toolId: 'f48xxx',
// 支付宝小程序 appId
appId: '202xxx',
// true 则将跳过 taro build 命令,即编译阶段
skipBuild: false,
},
// 默认发体验版,填 false 则发布为预览版
// 注意如果发布为预览版,需要实现 uploadImage 的函数,否则钉钉无法展示预览版的二维码
isExperience: true,
// 是否在构建前运行 npm install
preInstall: false,
// 指定环境变量,会在编译阶段,即 taro build 的指令中注入指定的环境变量
env: {
BUILD_ENV: 'test' // 仅作 demo,实际应填入你项目编译需要用的环境变量
},
// Step 3 中获取的钉钉机器人 webhook url
dingTalkUrl: 'https://oapi.dingtalk.com/robot/send?access_token=xxx',
// 如果你只需要构建发布体验版小程序,则可忽略以下函数
// 如果你需要构建发布预览版小程序,则需要实现该函数,将本地二维码图片文件转换为图片链接,否则无法将预览版二维码推送到钉钉群里
// 其中 objectName 形如 {platform}-{timestamp}.jpg,作为建议保存的文件名
// filePath 为本地预览版二维码图片的路径
uploadImage: async function(objectName, filePath) {
return ''
// 如果你使用阿里云 oss 作 cdn,可以参考以下代码进行上传
// const OSS = require('ali-oss')
// const client = new OSS({
// region: 'oss-cn-xxx',
// accessKeyId: 'xxx',
// accessKeySecret: 'xxx',
// bucket: 'xxx',
// })
// await client.put(`preview/${objectName}`, filePath, {
// 'Cache-Control': 'max-age=31536000'
// })
// return `https://xxx-oss-cdn.com/preview/${objectName}`
}
}
Step 5
# cd 到你们的项目并运行
taro-deploy
注意事项
- taro-deploy 目前只支持推送钉钉消息,否则只能完成自动化构建、上传、设置体验版,没法完成最后的推送步骤。如果有推送其它IM工具的需求,可以尝试自行实现
- taro-deploy 目前只支持发布预览版和体验版,不支持发布生产版,不会影响到生产环境。