gitlab runner 实现 微信小程序自动化部署

微信小程序多人开发的情况下,开发人员都只能在本机上发布体验版,且需要到小程序管理后台自行切换到自己发布的版本,会出现体验版本覆盖的问题。给开发测试带来问题。

miniprogram-ci 的发布,使得开发人员可以通过命令行上传小程序代码,二结合gitlab 的CI,开发人员就可以实现小程序自动发布。

实现目标:

1、代码提交到 master分支即自动上传小程序体验版。

2、每次上传代码自动递增修正版本号

3、提交代码的注释内容作为版本发布时的备注。

实现:

1、在小程序代码中新增一个version.txt内容为当前开发的小程序版本号前2位

复制代码
1.0

2、在小程序管理后台申请代码上传私钥和配置IP白名单

3、在gitlab 服务上全局安装 miniprogram-ci ,如果没有按照nodejs先安装nodejs

4、.gitlab-ci.yml配置

先创建这两个文件

/home/mp-version/p.txt 内容为 1

/home/mp-version/v.txt 内容为 1.0

私钥放到相应的位置

/home/private-key/private.key

复制代码
stages:
  - build
job-prod:
  stage: build
  only:
    - master
  script:
    - node -v
    - npm i
    - p=$(cat /home/mp-version/p.txt)
    - v=$(cat /home/mp-version/v.txt)
    - v1=$(cat ./version.txt)
    - if [ "$v" == "$v1" ]; then 
    - p1=$(expr $p + 1) 
    - echo "patch version add $p1"
    - else 
    - p1=0 
    - echo "patch version rest $p1"
    - fi
    - ud=$(echo $(git log -1 --format=%B) | cut -d ":" -f 2)
    - by=$(git log -1 --format=%an)
    - miniprogram-ci pack-npm --pp $(pwd) --pkp /home/private-key/private.key --appid wxxxxxxxxxxx
    - miniprogram-ci upload --pp $(pwd) --pkp /home/private-key/private.key --appid wxxxxxxxxxxx --pi [node_modules/**/*] --ud "$ud by:$by" --use-project-config true --uv "$v1.$p1"
    - echo $p1 > /home/mp-version/p.txt
    - echo $v1 > /home/mp-version/v.txt
    - echo "upload version: $v1.$p1 desc:$ud"
相关推荐
拉不动的猪5 小时前
移动端调试工具VConsole初始化时的加载阻塞问题
前端·javascript·微信小程序
梦想很大很大8 小时前
拒绝“盲猜式”调优:在 Go Gin 项目中落地 OpenTelemetry 链路追踪
运维·后端·go
Sinclair9 小时前
内网服务器离线安装 Nginx+PHP+MySQL 的方法
运维
叶落阁主9 小时前
Tailscale 完全指南:从入门到私有 DERP 部署
运维·安全·远程工作
甲鱼9292 天前
MySQL 实战手记:日志管理与主从复制搭建全指南
运维
WangHappy2 天前
不写 Canvas 也能搞定!小程序图片导出的 WebView 通信方案
前端·微信小程序
小时前端3 天前
微信小程序选不了本地文件?用 web-view + H5 一招搞定
前端·微信小程序·uni-app
icebreaker4 天前
Weapp-vite:原生模式之外,多一种 Vue SFC 选择
前端·vue.js·微信小程序
icebreaker4 天前
重走 Vue 长征路 Weapp-vite:编译链路与 Wevu 运行时原理拆解
前端·vue.js·微信小程序
碳基沙盒4 天前
OpenClaw 多 Agent 配置实战指南
运维