前情提要
目前的多端项目,在代码发布的时候,对于不同的端,需要进行不同的操作。尤其小程序端,每次都要在开发者工具中进行一次:
上传->填写版本信息->提交审核(确定上线时)
既然手动这么麻烦,能不能做成自动的?让开发节省重复操作时间,同时避免手动操作遗漏的可能性。
我翻阅资料,发现已经有大佬实现了上面的功能,我只需要站在巨人的肩膀上,结合实际需要,做些细微的调整即可。
功能计划
目前想要的功能比较简单,主要是自动化发版:
1、Taro打包后的小程序(原生小程序暂时不必要)
2、自动化版本发布、生成体验二维码
3、使用 git 昵称代替手工写入备注
第三方插件尝试
我找了两个功能各方面写的好且全面的插件,分别是Taro官方提供的 @tarojs/plugin-mini-ci 和 川哥写的 mini-ci
@tarojs/plugin-mini-ci
Taro 提供的这个插件接入很简单,官方文档写的很详细。
引入
因为我们目前只有微信小程序,所以里面只有关于微信小程序的配置。
安装
npm i @tarojs/plugin-mini-ci -D
本插件 Taro 3.x 版本均可使用,无需和其他 taro 包版本号保持一致;点击查看最新版本。
使用插件
/config/index.js文件中加入如下配置:
// 示例, 如果你使用 `vs code` 作为开发工具, 你还可以使用注释的语法引入插件包含的声明文件,可获得类似于typescript的友好提示
/**
* @typedef { import("@tarojs/plugin-mini-ci").CIOptions } CIOptions
* @type {CIOptions}
*/
const CIPluginOpt = {
weapp: {
appid: '微信小程序appid',
privateKeyPath: '密钥文件相对项目根目录的相对路径,例如 key/private.appid.key',
},
// 版本号
version: '1.0.0',
// 版本发布描述
desc: '版本描述',
}
const config = {
plugins: [['@tarojs/plugin-mini-ci', CIPluginOpt]],
}
除了给插件传入对象, 你也可以传入一个异步函数,在编译时动态返回相关配置。
const CIPluginFn = async () => {
// 可以在这里做一些异步事情, 比如请求接口获取配置
/**
* @typedef { import("@tarojs/plugin-mini-ci").CIOptions } CIOptions
* @type {CIOptions}
*/
return {
weapp: {
appid: '微信小程序appid',
privateKeyPath: '密钥文件相对项目根目录的相对路径,例如 key/private.appid.key',
},
swan: {
token: '鉴权需要的token令牌',
},
// 版本号
version: '1.0.0',
// 版本发布描述
desc: '版本描述',
}
}
const config = {
plugins: [['@tarojs/plugin-mini-ci', CIPluginFn]],
}
作为选项配合 build 命令使用
package.json 的 scripts 字段使用命令参数
{
"scripts": {
// 构建完后自动 “打开开发者工具”
"build:weapp": "taro build --type weapp --open",
// 构建完后自动 “上传代码作为开发版并生成预览二维码”
"build:weapp:preview": "taro build --type weapp --preview",
// 构建完后自动“上传代码作为体验版”
"build:weapp:upload": "taro build --type weapp --upload",
// 构建完后自动“上传 dist/xxx 目录的代码作为体验版”, `--projectPath` 参数 适用于 taro 和 原生混合的场景
"build:weapp:upload": "taro build --type weapp --upload --projectPath dist/xxx"
},
"taroConfig": {
"version": "1.0.0",
"desc": "上传描述"
}
}
插件小结
优点:接入简单,基础功能完善,支持多类小程序。
缺点:无法满足一些定制化的需求,比如指定机器人。
推荐指数:四颗星,适合除了上传预览,无需额外需求的场景
mini-ci
川哥写的这个组件也很好用,Git仓库里有使用的详细介绍,这里也按照Git仓库提供的使用流程,详细配置一下。
引入
首次使用前需先执行 mini-ci init 配置 mini.config.js 配置(更推荐)
执行 mini-ci init 会把 miniConfig 的配置拷贝生成到当前小程序项目(或者新项目)中。
在当前小程序项目(或者新项目)的目录下配置 mini.config.js,这个优先于 .env
首次使用前需先执行 mini-ci init 配置 mini.config.js 配置(更推荐)
执行 mini-ci init 会把 miniConfig 的配置拷贝生成到当前小程序项目(或者新项目)中。
在当前小程序项目(或者新项目)的目录下配置 mini.config.js,这个优先于 .env
参考当前项目中的 mini.config.js
按照微信小程序文档配置小程序密钥等,这样就能上传和预览了。如果没有微信小程序,可以自行免费开通个人的微信小程序。
或者配置 .env
在当前小程序项目(或者新项目)的目录下配置 .env
参考当前项目中的 .env
configPath 配置
如果需要单选或者多选时,需配置 configPath。
或者配置 .env
在当前小程序项目(或者新项目)的目录下配置 .env
首次使用前需先执行 mini-ci init 配置 mini.config.js 配置(更推荐)
执行 mini-ci init 会把 miniConfig 的配置拷贝生成到当前小程序项目(或者新项目)中。
在当前小程序项目(或者新项目)的目录下配置 mini.config.js,这个优先于 .env
参考当前项目中的 mini.config.js
按照微信小程序文档配置小程序密钥等,这样就能上传和预览了。如果没有微信小程序,可以自行免费开通个人的微信小程序。
或者配置 .env
在当前小程序项目(或者新项目)的目录下配置 .env
参考当前项目中的 .env
configPath 配置
如果需要单选或者多选时,需配置 configPath。
configPath 配置
首次使用前需先执行 mini-ci init 配置 mini.config.js 配置(更推荐)
执行 mini-ci init 会把 miniConfig 的配置拷贝生成到当前小程序项目(或者新项目)中。
在当前小程序项目(或者新项目)的目录下配置 mini.config.js,这个优先于 .env
参考当前项目中的 mini.config.js
按照微信小程序文档配置小程序密钥等,这样就能上传和预览了。如果没有微信小程序,可以自行免费开通个人的微信小程序。
或者配置 .env
在当前小程序项目(或者新项目)的目录下配置 .env
参考当前项目中的 .env
configPath 配置
如果需要单选或者多选时,需配置 configPath。
功能定制
获取 Git 昵称
因为自动发版使用的是微信提供的机器人,所以,提交版本无法区分是谁。这种情况下,可以在自定义备注中加入提交人的信息。
而手动录入,是有可能出现遗漏的情况。如果能直接获取 Git 登录名,可以直接把昵称默认值放到备注里。
GitHub API
我之前文章有一篇是写获取 git 的标签的,所以我写获取昵称的时候,也是往那个思路靠的。但是没有成功。
后来,还是 VS 插件 Git History 给我的灵感。使用 Git 提供的 API,获取当前登录者的信息。
import axios from 'axios';
function getContributors(remoteUrl) {
const remoteRepoPath = remoteUrl.replace(/.*?github.com(\/|:)/, '');
const repoPath = remoteRepoPath.replace(/\.git\/?$/, '');
const promise = axios.get(`https://api.github.com/repos/${repoPath}/contributors`);
return promise
.then(response => {
return response.data;
})
.catch(() => {
// Errors can be as follow
// 403 - max API limit has been exceeded by the client
// 404 - not found due to wrong path or its a private repository
return [];
});
}
getContributors('https://github.com/wxmp-project/wxmp-travel');
tips:
通常我找不到实现方案的时候,我就会去找有没有第三方插件有类似的功能,然后找到源码去看人家是怎么实现的。
像上面的功能,我也是找了很久没有找到实现方案。在 gitHistoryVSCode 源码中找到了实现方式。
GitLab API
同样的,GitLab也应该是有提供API的,我搜了一下果然有,官网地址 >>。
DevOps 发版小程序
我们使用的 DevOps 自动化运维平台,实现项目的部署。
自动化处理之前,不同端的部署,要在多个地方进行操作,H5的在DevOps 平台上进行发布操作,小程序在开发者工具里。
所以我修改了构建命令,加入了小程序发布的参数。
使用 jenkins 进行项目发布,可以在脚本中修改命令。因为我没有实际场景,所以没办法详细描述。需要的朋友可以检索一下。
总结
最终选择的 @tarojs/plugin-mini-ci,因为它已经满足我们的实际需求,且是同一个生态下的,接入成本低。
同时还做了功能定制,更加贴合实际业务需要。
作者:非职业「传道授业解惑」的开发者叶一一简介:「趣学前端」、「CSS畅想」系列作者,华夏美食、国漫、古风重度爱好者,刑侦、无限流小说初级玩家。如果看完文章有所收获,欢迎点赞👍 | 收藏⭐️ | 留言📝。