跳过主内容
CI/CD

自动构建和发布与Gitlab

使用Gitlab免费创建自己的CI/CD管道,部署您的应用程序每次推送到主分支。

马丁·多纳迪乌

马丁·多纳迪厄

内容营销

自动构建和发布与 Gitlab

本教程重点介绍 GitLab CI,但您可以轻松适应任何其他 CI/CD 平台。

序言

确保您已将应用程序添加到 Capgo,本教程仅关注上传阶段

提交约定

首先,您需要遵循提交约定 规范提交` 这将有助于工具了解如何升级版本号,学习时间仅 5 分钟。

规范提交

GitLab CI for tag

然后你需要创建第一个 GitLab 来自动构建并创建标签。

在这个路径创建一个文件: .github/workflows/bump_version.yml

内容如下:

name: Bump version

on:
  push:
    branches:
      - main

jobs:
  bump-version:
    if: "!startsWith(github.event.head_commit.message, 'chore(release):')"
    runs-on: ubuntu-latest
    name: "Bump version and create changelog with standard version"
    steps:
      - name: Check out
        uses: actions/checkout@v6
        with:
          fetch-depth: 0
          filter: blob:none
          token: '${{ secrets.PERSONAL_ACCESS_TOKEN }}'
      - name: Git config
        run: |
          git config --local user.name "github-actions[bot]"
          git config --local user.email "github-actions[bot]@users.noreply.github.com"
      - name: Create bump and changelog
        run: npx capacitor-standard-version
      - name: Push to origin
        run: |
          CURRENT_BRANCH=$(git rev-parse --abbrev-ref HEAD)
          remote_repo="https://${GITHUB_ACTOR}:${{ secrets.PERSONAL_ACCESS_TOKEN }}@github.com/${GITHUB_REPOSITORY}.git"
          git pull $remote_repo $CURRENT_BRANCH
          git push $remote_repo HEAD:$CURRENT_BRANCH --follow-tags --tags

这将为每个主分支的提交发布一个标签。并为每个主分支的提交在 CHANGELOG.md.

如果你没有这个文件,不用担心,它会自动创建。

为了让这个功能工作,创建一个 并将其添加到你的 GitLab CI/CD 变量中作为 这是让 CI 能够提交更改日志的必要步骤。 PERSONAL_ACCESS_TOKEN.

当你创建令牌时,请选择

并选择 never 最后,为了让工具理解你的版本保存在哪里,你需要创建一个文件 repo.

PERSONAL ACCESS TOKEN .cz.toml 在您的仓库根目录。

并在此处添加:

[tool.commitizen]
name = "cz_conventional_commits"
tag_format = "$major.$minor.$patch$prerelease"
version = "0.11.5"
version_files = [
    "package.json:version",
    ".cz.toml"
]

将此文件中的版本设置为您在"file"中使用的版本。 package.json 文件。

这只需要在第一次使用时,工具会自动更新。

您现在可以提交这两个文件并看到第一个标签出现在GitHub中!

GitHub 构建动作

在此路径创建一个文件: .github/workflows/build.yml

内容:

name: Build source code and send to Capgo

on:
  push:
    tags:
      - '*'
      
jobs:
  deploy:
    runs-on: ubuntu-latest
    name: "Build code and release"
    steps:
      - name: Check out
        uses: actions/checkout@v6
      - name: Install dependencies
        id: install_code
        run: npm i
      - name: Build
        id: build_code
        run: npm run build
        env: # Remove both lines  if you don't need it
          FIREBASE_CONFIG: ${{ secrets.FIREBASE_CONFIG }} # Example of env var coming from a secret
      - name: Create Release
        id: create_release
        run: npx @capgo/cli@latest bundle upload -a ${{ secrets.CAPGO_TOKEN }} -c production

这将安装并构建您的依赖项,然后将其发送到Capgo。

如果您的构建命令不同,您可以在"step"中进行更改。 build_code 步骤

为了使其工作,您需要获取您的API密钥,用于Capgo,添加它到 您的GitHub仓库的密钥中 作为 CAPGO_TOKEN.

您现在可以提交这两个文件并在GitHub中看到您的第一个标签!

添加提交将为生产渠道生成一个新的构建。

您应该在构建步骤中添加您的测试,以确保您的code正在工作。

前往您的Capgo控制台并检查刚刚出现的构建,您现在有了您的CI/CD系统。

如果您想让所有用户在它可用时都能获得更新,请前往您的渠道并将其设置为 public.

Capacitor 应用的实时更新

当有 web-layer 的 bug 时,通过 Capgo 直接发布修复,而不是等待几天的 app store 审核。用户在后台接收更新,而原生代码的变更仍然在正常的审查路径中。

立即开始

最新博客

Capgo 提供了您创建真正专业的移动应用所需的最佳见解。