Saltare al contenuto principale
CI/CD

App di costruzione e rilascio automatico con Github azioni

Crea il tuo pipeline CI/CD con Github azioni gratuitamente, distribuisci il tuo app Ionic Capacitor JS ogni volta che pubblichi su main.

Martin Donadieu

Martin Donadieu

Content Marketer

App di costruzione e rilascio automatico con Github azioni

Questa guida si concentra sulla GitHub hosting, ma puoi adattarla con poche modifiche a qualsiasi altra piattaforma CI/CD.

Prefazione

Assicurati di aver aggiunto il tuo Capacitor app prima a Capgo, questa guida si concentra solo sulla fase di caricamento. Se hai bisogno di aggiungere il tuo app a Capgo, puoi seguire questo Tutorial

Convenzione di commit

In primo luogo, devi iniziare a seguire la convenzione di commit Comuni di commit ` questo ti aiuterà a capire come il tooling deve gestire l'aggiornamento del numero di versione, ci vuole solo 5 minuti per impararlo.

Comuni di commit

GitHub azioni per tag

Poi devi creare la tua prima GitHub azione per costruire automaticamente e creare un tag.

Crea un file in questo percorso: .github/workflows/bump_version.yml

con questo contenuto:

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

Questa azione rilascerà un tag per ogni commit nella tua branch principale. E aggiungerà un'ingresso nel changelog per ogni commit nella branch principale in CHANGELOG.md.

Non preoccuparti se non hai questo file, verrà creato per te.

Per far funzionare questo, crea un TOKEN DI ACCESSO PERSONALE e aggiungilo al tuo GitHub segreti come PERSONAL_ACCESS_TOKEN.

Questa è necessaria per far sì che il CI possa commitare il changelog.

Quando crei il token, scegli l'expiration come never e lo scope come repo.

Infine, impostare la versione nel tuo package.json file, sincralo con il numero di versione nativo che facilita, quindi il passo successivo.

Questo è necessario solo la prima volta, poi gli strumenti lo terranno aggiornato.

Ora puoi commitare entrambi i file e vedere comparire il tuo primo tag in GitHub!

Entrambe le piattaforme nativa e web avranno il numero di versione incrementato dopo ogni commit.

azioni GitHub per la build

Crea un file in questo percorso: .github/workflows/build.yml

con questo contenuto:

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

Questo installerà e costruirà la tua dipendenza prima di inviarla a Capgo.

Se il tuo comando per la build è diverso, puoi cambiarlo nel build_code passo.

Per far funzionare questo, hai bisogno di ottenere la tua chiave API per Capgo, aggiungerla nel il segreto del tuo repository GitHub come CAPGO_TOKEN.

Ora puoi commitare entrambi i file e vedere comparire il tuo primo tag nel GitHub!

L'aggiunta del commit genererà una nuova build per il canale di produzione.

Dovresti aggiungere il tuo test nel passo di build per assicurarti che il tuo code funzioni.

Vai al tuo dashboard Capgo e controlla la tua build che è appena apparsa, adesso hai il tuo sistema CI/CD.

Se vuoi che tutti i tuoi utenti ricevano l'aggiornamento non appena sarà disponibile, vai al tuo canale e impostalo su public.

Potresti anche aggiungere la build nativa del tuo app Ionic Capacitor JavaScript seguendo questo tutorial 👇

Continua da Automatic build and release app con Github actions

Se stai utilizzando Automatic build and release app con Github actions per pianificare l'automazione del CI/CD, connettilo con Capgo CI/CD per il flusso di lavoro del prodotto in Capgo CI/CD Capgo Costruzioni Native per il flusso di lavoro del prodotto in Capgo Costruzioni Native Capgo Integrazioni per il flusso di lavoro del prodotto in Capgo Integrazioni Integrazione CI/CD per il dettaglio di implementazione in Integrazione CI/CD, e GitHub Integrazione di Azioni per il dettaglio di implementazione in GitHub Integrazione di Azioni

Aggiornamenti in tempo reale per le Capacitor app

Quando un bug del layer web è attivo, invia la correzione attraverso Capgo invece di attendere giorni per l'approvazione della store. Gli utenti ricevono l'aggiornamento in background mentre le modifiche native rimangono nel normale percorso di revisione.

Inizia subito

Ultimi articoli dal nostro Blog

Capgo ti offre le migliori informazioni che ti servono per creare un'app mobile davvero professionale.