Zum Hauptinhalt springen
CI/CD

Automatische Build- und Releasefunktion mit Gitlab

Erstellen Sie Ihre eigene CI/CD-Pipeline mit Gitlab kostenlos, deployen Sie Ihre App bei jedem Push auf main.

Martin Donadieu

Martin Donadieu

Content-Marketing-Spezialist

Automatische Build- und Releasefunktion mit Gitlab

Diese Anleitung konzentriert sich auf die GitLab CI, aber Sie können sie mit einem kleinen Anpassung auf jede andere CI/CD-Plattform anwenden.

Einleitung

Stellen Sie sicher, dass Sie Ihre App zuerst in Capgo hinzugefügt haben, diese Anleitung konzentriert sich nur auf die Upload-Phase

Commit-Konvention

Zuerst müssen Sie die Commit-Konvention befolgen Konventionelle Commits` dies wird helfen, dass die Werkzeuge verstehen, wie die Versionsnummer aufzubereiten ist, es dauert 5 Minuten, es zu lernen.

Konventionelle Commits

GitLab CI für Tag

Erstelle dann deine erste GitLab, um automatisch zu bauen und einen Tag zu erstellen.

Erstelle ein Datei an diesem Pfad: .github/workflows/bump_version.yml

mit diesem Inhalt:

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

Das wird einen Tag für jeden Commit in deinem Hauptzweig freigeben. Und eine Änderungsprotokoll-Eintrag für jeden Commit in dem Hauptzweig in CHANGELOG.md.

Bedenke nicht, wenn du diese Datei nicht hast, sie wird für dich erstellt.

Um dies zu machen, erstelle ein PERSONAL ACCESS TOKEN und füge es zu deinen GitLab CI/CD Variablen als PERSONAL_ACCESS_TOKEN.

Dies ist notwendig, um dem CI den Änderungsprotokoll-Eintrag zu ermöglichen.

Wenn Sie den Token erstellen, wählen Sie die Ablaufzeit als never und den Umfang als repo.

Zuletzt müssen Sie zum Verständnis des Tools, wo Ihre Version gespeichert ist, einen Datei .cz.toml an der Wurzel Ihres Repository erstellen.

Und fügen Sie dies hinein :

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

Setzen Sie die Version in dieser Datei auf die gleiche, die Sie in Ihrem package.json Datei haben.

Dies ist nur notwendig zum ersten Mal, dann werden die Tools es auf dem Laufenden halten.

Sie können nun diese beiden Dateien committen und sehen, wie Ihr erster Tag in GitHub erscheint!

GitHub-Aktionen für die Erstellung

Erstellen Sie eine Datei an diesem Pfad: .github/workflows/build.yml

mit diesem Inhalt:

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

This wird Ihre Abhängigkeit installieren und bauen, bevor sie an Capgo gesendet wird.

Wenn Ihr Befehl für das Build anders ist, können Sie ihn in der build_code Schritt ändern.

Damit dies funktioniert, müssen Sie Ihren API-Schlüssel für Capgo erhalten, ihn in der Geheimzahl Ihres GitHub-Repositorys hinzufügen als CAPGO_TOKEN.

Sie können jetzt diese beiden Dateien committen und sehen, wie Ihr erster Tag in GitHub erscheint!

Die Commits werden eine neue Build für den Produktionskanal generieren.

Sie sollten Ihre Tests im Build-Schritt hinzufügen, um sicherzustellen, dass Ihr code funktioniert.

Gehen Sie zu Ihrem Capgo-Dashboard und überprüfen Sie Ihre Build, die gerade erschienen ist, jetzt haben Sie Ihr CI/CD-System.

Wenn Sie möchten, dass alle Ihre Benutzer die Aktualisierung erhalten, sobald sie verfügbar ist, gehen Sie zu Ihrem Kanal und setzen Sie ihn auf public.

Fortsetzen Sie mit der automatischen Build- und Release-Verarbeitung mit Gitlab

Wenn Sie CI/CD automatisieren möchten Automatisches Build und Release mit Gitlab um CI/CD-Automatisierung zu planen, verbinden Sie es mit Capgo CI/CD für den Produktworkflow in Capgo CI/CD Capgo Native Builds für den Produktworkflow in Capgo Native Builds Capgo Integrations für den Produktworkflow in Capgo Integrations CI/CD-Integration für die Implementierungsdetails in CI/CD-Integration GitHub Actions Integration für die Implementierungsdetails in GitHub Aktionen-Integration.

Live-Updates für Capacitor Apps

Wenn ein Web-Schichtsfehler live ist, schicken Sie die Reparatur über Capgo anstatt Tage zu warten, bis die App-Store-Zulassung genehmigt ist. Die Benutzer erhalten die Aktualisierung im Hintergrund, während native Änderungen im normalen Review-Prozess bleiben.

Los geht's jetzt

Neueste aus unserem Blog

Capgo gibt Ihnen die besten Einblicke, die Sie benötigen, um ein wirklich professionelles mobiles App zu erstellen.