taro-ci

基于微信:miniprogram-ci、支付宝:miniu开发,用于同时打包 weapp、alipay、weapp.third 多版本发布管理;第一个横线后半部分会作为环境变量注入到 Taro 框架小程序中【process.env.MODE_ENV=third】;执行 taro build 时置入的环境变量还包括 process.env.ROOT_PATH=当前文件包输出路径,例:dist/weapp.dev;process.env.PLATFORM_ENV=weapp|alipay;

Usage no npm install needed!

<script type="module">
  import taroCi from 'https://cdn.skypack.dev/taro-ci';
</script>

README

taro-ci

基于微信:miniprogram-ci支付宝:miniu开发,用于同时打包 weapp、alipay、weapp.third 多版本发布管理;第一个横线后半部分会作为环境变量注入到 Taro 框架小程序中【process.env.MODE_ENV=third】;执行 taro build 时置入的环境变量还包括 process.env.ROOT_PATH=当前文件包输出路径,例:dist/weapp.dev;process.env.PLATFORM_ENV=weapp|alipay;

扩展编译平台使用 taro-plugin-build,并在 taro-ci.config 中配置 useTaroPluginBuildBy="",插件编译时自动注册对应的编译平台,可实现多版本公用框架并针对特殊版本处理,具体可参考:Taro 跨平台开发

注意: 如需在项目中使用 MODE_ENV|PLATFORM_ENV

需要对 Taro 项目配置:

config/index.config.env.MODE_ENV=process.env.MODE_ENV

config/index.config.env.PLATFORM_ENV=process.env.PLATFORM_ENV

小程序开发必须基于Taro开发


小程序项目根目录下package.json 配置 script 命令 注意:目前 robot 仅支持[1,3]

{
  //...
  "script": {
    "dev": "taro-ci --watch", // 开发模式
    "build": "taro-ci", // 打包
    "ci:beta": "taro-ci --robot 1 --ci=toolId,privateKey --dd=accessToken,secret", // 发布 - 体验版
    "ci:rc": "taro-ci --robot 2 --ci=toolId,privateKey --dd=accessToken,secret", // 发布 - 候选版
    "ci:release": "taro-ci --robot 3 --ci=toolId,privateKey --dd=accessToken,secret" // 发布 - 正式版
  }
}
/**
 * 根目录增加配置文件 taro-ci.config.js
 */

module.exports = {
  name: "miniapp",
  version: "1.0.0",
  description: "通用描述信息",
  type: ["weapp", "alipay", "weapp.pro", "alipay.pro"],
  info: {
    weapp: {
      version: "1.1.0",
      description: "对应版本的针对性描述",
      appId: "wx.................",
    },
    "weapp-third": {
      appId: "wx.................",
      label: "普通", // 特殊版本的标签
      tag: "N", // 特殊版本的标签体现在版本号上 N1.2.0
      robot: 1, // 特殊版本微信上传使用的robot计算依据 1 + (robot-1) *2
    },
    alipay: {
      appId: "支付宝的APPID",
    },
  },
  useTaroPluginBuildBy: "normal", // type|mode|normal 自定义编译模式:mode - 按照MODE_ENV对应编译,type - 按照传入的全指令编译
  git: "", // 当前项目对应的git地址
  // 支付宝工具id与私钥
  // ci: {
  //   toolId: "",
  //   privateKey: ""
  // },
  // 钉钉通知(可配置到git项目的CI/CD变量配置中)
  // dd: {
  //   accessToken: "",
  //   secret: ""
  // }
};
/**
 * 根目录增加发布配置文件 taro-ci.release.${PLATFORM_ENV}.${MODE_ENV}.json
 */
["0.0.2-最新版描述信息-20211021", "0.0.1-上个版本描述信息-20211020"]

微信小程序生成上传秘钥文件 private.wx..................key 放到项目根目录下


支付宝小程序生成工具 id 与私钥 配置到 taro-ci.config.json 中的 ci 配置项 或者配置到命令行 --ci=toolId,privateKey


获取的钉钉通知消息所需的token 与秘钥:找到对应的群 >点击群设置 >智能群助手 >添加机器人 >选择自定义 >确认添加后,选择加签即可获得对应的 accessToken 与 secret,将值配置到 taro-ci.config.json 中的 dd 配置项 或者配置到命令行 --dd=accessToken,secret

使用许可

MIT © yymzy