Hinweis: Inhalt überspringen
CI/CD

Automatisches Build- und Release-Tool mit Github Aktionen

Erstellen Sie Ihre eigene CI/CD-Pipeline mit Github Aktionen kostenlos, deployen Sie Ihre Ionic Capacitor JS-Anwendung bei jedem Push auf main.

Martin Donadieu

Martin Donadieu

Content-Marketing-Beauftragter

Automatisches Build- und Release-Tool mit Github Aktionen

In diesem Tutorial wird sich auf die GitHub-Hosting konzentriert, aber Sie können es mit einigen Anpassungen auf andere CI/CD-Plattformen anwenden.

Vorwort

Stellen Sie sicher, dass Sie Ihre Capacitor-Anwendung zuerst in Capgo hinzugefügt haben, da dieses Tutorial nur auf die Upload-Phase fokussiert ist. Wenn Sie Ihre Anwendung in Capgo hinzufügen müssen, können Sie sich anhand dieses Tutorials anleiten lassen. Tutorial

Commitkonvention

Zuerst müssen Sie mit der Commitkonvention beginnen konventionelle Commits` dies wird den Werkzeugen helfen, die Versionsnummer zu updaten, es dauert 5 Minuten, es zu lernen.

Konventionelle Commits

GitHub Aktionen für die Etikettierung

Dann müssen Sie Ihre erste GitHub Aktion erstellen, um automatisch zu bauen und eine Etikettierung zu erstellen.

Erstellen Sie 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 für jeden Commit in Ihrer Hauptzweig eine Etikettierung erstellen. Und eine Änderungsprotokoll-Eintrag für jeden Commit in der Hauptzweig in CHANGELOG.md.

Sorgen Sie nicht, wenn Sie diese Datei nicht haben, sie wird für Sie erstellt.

Um dies zu machen, erstellen Sie ein Persönlicher Zugriffstoken und fügen Sie es Ihrem GitHub hinzu Geheimnisse als PERSONAL_ACCESS_TOKEN.

Dies ist notwendig, damit der CI den Changelog einreichen kann.

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

Zuletzt setzen Sie die Version in Ihrem package.json Datei, synchronisieren Sie sie mit Ihrer Native-Version-Nummer, die es erleichtern wird, dann folgt der nächste Schritt.

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

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

Beide native und Web-Plattformen werden die Versionsnummer nach jedem Commit erhöhen.

GitHub-Aktionen für die Erstellung

Erstellen Sie ein 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

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

Wenn Ihr Befehl für die Erstellung anders ist, können Sie ihn im 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 Datei committen und sehen, wie Ihr erster Tag in GitHub erscheint!

Der Commit wird eine neue Build für den Produktionskanal generieren.

Fügen Sie Ihren Test in den Aufbau-Schritt hinzu, um sicherzustellen, dass Ihr code funktioniert.

Gehe zu Ihrem Capgo-Dashboard und überprüfe Ihren Aufbau, der 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 stellen Sie ihn auf public.

Sie können auch den nativen Aufbau Ihres Ionic Capacitor-JavaScript-Apps hinzufügen, indem Sie diese Anleitung befolgen 👇

Live-Updates für Capacitor-Anwendungen

Wenn ein Web-Schicht-Bug live ist, liefern Sie die Reparatur über Capgo anstatt Tage für die Genehmigung durch den App-Store abzuwarten. 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 bietet Ihnen die besten Einblicke, die Sie benötigen, um eine wirklich professionelle mobilen App zu erstellen.