Electron + GitHub Actions | 自动化流程详解

自动化部署

上篇介绍了 Electron Forge 打包应用教程。在实际开发中,自动化是提升效率和产出质量的关键。本篇我们将详细介绍如何将构建和发布 Electron 应用的过程自动化。

代码挂在 GitHub 仓库上,如果有帮助,记得给仓库点个赞:RexWzh/Electron-demo

GitHub Actions 简介

GitHub Actions 是一个集成的 CI/CD 服务,通过创建 workflows,在代码提交后自动启动构建过程,测试代码,甚至部署到生产环境,极大地提高开发效率和部署频率。

更深入的自动化测试可以参考官方文档:

  • 在 Electron 应用程序上运行端到端自动化测试
  • 在无头 CI 系统上进行测试(如 Travis CI、Jenkins)

类似平台如 Jenkins、CircleCI、Travis CI 以及 GitLab Runner 等也有广泛的应用,本教程将专注于介绍 GitHub Actions。

使用限制

在使用 GitHub Actions 时,需要了解一些基本的使用限制和计费信息(参考文档)。

保存期限

默认情况下,GitHub Actions 生成的工作流日志和项目文件将保存 90 天,之后自动删除。不过,这个期限可以根据仓库的属性和用户的需要调整:

  • 公共仓库:对于托管在 GitHub 的公共仓库,使用 GitHub 托管的运行器完全免费,日志保存期限可以设定在 1 至 90 天之间。
  • 私人仓库:私人仓库可以根据账户的计划享受一定量的免费分钟数和存储空间。超出这些限制则需要支付额外费用,而日志的保存期限可以设定在 1 至 400 天之间。
并发限制

GitHub Actions 对并发作业的数量有一定的限制,这取决于用户的 GitHub 计划:

GitHub 计划标准托管运行器总并发作业macOS 最大并发作业GPU 最大并发作业
免费205N/A
专业版405N/A
团队60 / 10005100
企业500 / 100050100

可以在账号设置的billing-summary 中查看具体限制,比如

GitHub ProGitHub Free
无限制的公开/私有仓库无限制的公开/私有仓库
无限制的协作者无限制的协作者
3,000分钟/月 的 GitHub Actions 使用时间2,000分钟/月 的 GitHub Actions 使用时间
2GB 的 Packages 存储空间500MB 的 Packages 存储空间
180 核心小时的 Codespaces 计算时间120 核心小时的 Codespaces 计算时间
20GB 的 Codespaces 存储空间15GB 的 Codespaces 存储空间
社区支持N/A

注:用 GITHUB 学生包白嫖的 4$/月的 Pro 会员。

自动构建的配置

为了提高工作流程的可读性并简化脚本配置,我们选择使用 npx electron-forge make 命令来执行构建任务,而不是在 package.json 中配置的 npm run make

注意事项

在设置 forge.config.js 文件时,特别是配置 makers 字段,如果指定了特定平台的构建目标,如仅限 Linux:

makers: [{name: '@electron-forge/maker-zip',platforms: ['linux'],}
]

这样的配置在尝试在 macOS 上执行构建时可能会引发错误。为了避免这种情况,在多平台构建场景下,建议不要指定 platforms 字段,或适当调整该配置,甚至可以考虑删除该字段。

macOS 平台的 GitHub Actions 示例

下面是一个工作流示例,在 macOS 平台上针对不同架构(x64 和 arm64)及目标格式(DMG 和 ZIP)进行构建:

name: macOS Buildon:push:branches:- mainpull_request:branches:- mainjobs:build-macos:runs-on: macos-lateststrategy:matrix:arch: [x64, arm64]target: [dmg, zip]steps:- name: Checkout codeuses: actions/checkout@v3- name: Set up Node.jsuses: actions/setup-node@v3with:node-version: '20'- name: Install Python 3.11.4uses: actions/setup-python@v4with:python-version: '3.11.4'- name: Install dependenciesrun: npm install- name: Build applicationrun: npm run build- name: Package application for macOS ${{ matrix.arch }} ${{ matrix.target }}run: npx electron-forge make --platform=darwin --arch=${{ matrix.arch }} --targets="@electron-forge/maker-${{ matrix.target }}" --icon=public/avatar- name: Upload Artifactsuses: actions/upload-artifact@v3with:name: electron-app-${{ matrix.arch }}-${{ matrix.target }}path: ${{ github.workspace }}/**/make/**/*.${{ matrix.target == 'dmg' && 'dmg' || 'zip' }}

构建顺利的话,在工作流底部能看到产出文件

20240511040008

常见错误及解决方案

在首次编写和测试工作流脚本时,可能会遇到如下构建错误:

✔ Finalizing package
✖ Making a dmg distributable for darwin/arm64 [FAILED: Cannot find module 'appdmg']
✔ Packaging for arm64 on darwin

根据官方 Issue “Cannot find module ‘appdmg’”,这是由 GitHub 的 macOS 镜像配置引起的。解决这一问题的方法包括使用指定版本的 macOS 容器,或更改默认的 Python 版本,如本示例中所采用的后者方法。

类似可根据需要修改为 Windows 和 Linux 平台的脚本,在配置这些脚本时,Python 的这一步可以省略。

自动发布

使用 Electron Forge 的官方插件发布到 GitHub 是一种简单且高效的方式。

关联文档:

  • 官方教程 Publishing and Updating
  • GitHub 插件:https://update.electronjs.org
  • 其他平台:官方插件 Publishers
设置 GitHub 令牌

首先,需要在 GitHub 创建一个个人访问令牌(Personal Access Token),以授权 GitHub Actions 自动发布应用。可以通过以下链接创建新的访问令牌:Create New Token。

20240511045447

创建时,请确保至少启用以下权限:

  • Contents: 允许访问仓库内容,提交,分支,下载,发布和合并。

GitHub Token Permissions

在 GitHub Actions YAML 配置文件中设置 GITHUB_TOKEN 环境变量,以使用这个令牌。

配置自动发布

使用 Electron Forge 的 GitHub Publisher 插件可以简化发布过程。首先,需要安装这个插件:

npm install --save-dev @electron-forge/publisher-github

接着,在 package.json 中添加相应的脚本来支持自动发布:

"scripts": {"start": "electron-forge start","package": "electron-forge package","make": "electron-forge make","publish": "electron-forge publish"
},

forge.config.js 文件中配置发布选项:

module.exports = {publishers: [{name: '@electron-forge/publisher-github',config: {repository: {owner: 'github-user-name',name: 'github-repo-name'},prerelease: false,draft: true}}]
}

在 GitHub 中创建 Release 的这两个选项 draftprerelease

  • Draft 指一个还未完成的 Release。当你创建一个草稿 Release 时,它不会对你的用户公开显示,只有拥有仓库写权限的用户可以看到和编辑它。这允许你或你的团队在公开之前仔细审查和完善发布内容。
  • Prerelease 用于标识尚未完全稳定、可能还在测试或开发中的 Release。尽管它是公开的,用户可以看到并下载,但通过标记为预发布,你可以明确告知用户这不是最终的稳定版本,可能还存在一些未解决的问题或需要进一步测试。
添加仓库信息

package.json 中添加或更新以下信息,确保项目描述和仓库信息正确无误:

"author": "Rex Wang",
"description": "An electron demo with vite and vue3",
"repository": {"type": "git","url": "https://github.com/rexwzh/electron-demo.git"
},
执行发布

设置好环境变量后,使用以下命令推送更新并自动发布:

export GITHUB_TOKEN=github_xxxxxx
npx electron-forge publish --platform=darwin --arch=arm64 --targets="@electron-forge/maker-zip" --icon=public/avatar

当然,这些在命令行执行的操作,都可以在 GitHub Actions 中配置,实现自动化发布。参考代码:Electron-demo。

配置自动更新

Electron 提供了一个 autoUpdater 模块,用于获取和安装更新。为了简化自动更新的实现,Electron 社区提供了一个实用的模块 update-electron-app,它自动配置 autoUpdater 来使用 update.electronjs.org 服务。

首先,需要安装 update-electron-app 模块:

npm install update-electron-app --save-dev

在主进程文件 main.js 中,引入并初始化 update-electron-app

const { updateElectronApp } = require('update-electron-app')
updateElectronApp()

该函数调用将配置 autoUpdater,以自动从与项目的 package.json 中的 "repository" 字段匹配的 URL 检查更新。

相关文档:

  • 官方 autoUpdater 文档:autoUpdater
  • update-electron-app 项目地址:update-electron-app on GitHub

以上,代码细节可以查看:RexWzh/Electron-demo

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/695808.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

STM32_HAL_系统定时器(SysTick)_实现计时

1介绍 系统定时器(SysTick)是ARM Cortex-M处理器系列中的一个特殊定时器,它不属于STM32F1系列微控制器的外设,而是处理器内部的一个组件。SysTick定时器的作用是为操作系统或其他需要精确时钟计数和中断服务的应用提供基础的时间…

SD-WAN供应商选择指南

企业网络日益演变,尤其是跨国企业、出海电商和外贸企业,其网络需求变得愈发复杂多样。SD-WAN技术因此备受瞩目,成为连接分支机构和数据中心的关键解决方案。然而,市面上的SD-WAN供应商众多,如何选择适合的服务商成为了…

消息队列——Kafka

1、什么是消息队列,什么是Kafka? 我们通常说的消息队列,简称MQ(Message Queue),它其实就指消息中间件,比较流行的开源消息中间件有:Kafka、RabbitMQ、RocketMQ等。今天我们要介绍的…

【光线重塑技术】小姐姐,美得不可方物——lllyasviel/ic-light

在英伟达自18年宣布光追技术之后,RTX显卡也成了目前Steam游戏的常客。就连 AMD、Intel 和 Apple Silicon 都宣布要在GPU上支持光追算法。这次我要介绍的是huggingface上比较火的relight技术—— ic-light 介绍 IC-Light 是一个操纵图像照明的项目。 IC-Light &qu…

出现Duplicate key

解决: 第一种情况: 添加一个字段prjId ,和数据库表映射时,映射的字段存在映射关系了。 将第二个 TableField中的prj_num改成prj_id 即可。 第二种情况: 转成map的形式时:key重复了,不知道把值赋…

华火5.0台嵌式喷火电燃单灶,更懂未来生活需求

在厨电技术不断革新的今天,第五代华火电燃灶以其独特的技术升级和卓越性能,成功吸引了市场的广泛关注。作为华火品牌的最新力作,第五代电燃灶不仅继承了前代产品的优点,更在多个方面进行了显著的升级和创新。下面,我们…

难以重现的 Bug如何处理

对很多测试人员(尤其是对新手来说)在工作过程中最不愿遇到的一件事情就是:在测试过 程中发现了一个问题,觉得是 bug,再试的时候又正常了。 碰到这样的事情,职业素养和测试人员长期养成的死磕的习性会让她…

【C++】命名空间、缺省参数、函数重载、引用

文章目录 1.认识命名空间2.命名空间的使用3.C的输入和输出4.缺省参数4.1缺省参数的概念4.2缺省参数的分类 5.函数重载6.引用6.1引用的概念6.2引用的特性6.3常引用(重点题目)6.4引用和指针的区别 1.认识命名空间 C总计63个关键字,C语言32个关键字 下面让我们学习一…

防火墙技术基础篇:状态检测的概念与功能

防火墙技术基础篇:状态检测的概念与功能解析 一、防火墙数据转发流程概述 在防火墙收到一个数据报文后,处理和转发流程一共可以分为三个阶段: 查询会话表前的基本处理。首包建立会话,非首包查询会话。对查询会话后的报文进行处…

前端XHR请求数据

axios封装了XHR(XMLHttpRequest) 效果 项目结构 Jakarta EE9&#xff0c;Web项目。 无额外的maven依赖 1、Web页面 index.html <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><title>Title</title&…

【异常】SpringBoot整合RabbitMQ-发送消息报错

错误信息 reply-code406, reply-textPRECONDITION_FAILED - inequivalent arg ‘x-message-ttl’ for queue ‘hello-queue’ in vhost ‘/lq’: received none but current is the value ‘10000’ of type ‘signedint’, class-id50, method-id10 错误原因 hello-queue这…

哈希重要思想——位图详解

一&#xff0c;概念 所谓位图&#xff0c;就是用每一位来存放某种状态&#xff0c;适用于海量数据&#xff0c;数据无重复的场景。通常是用来判断某个数据存不存在的。 为了方便理解我们引入一道面试题&#xff0c; 给40亿个不重复的无符号整数&#xff0c;没排过序。给一个无…