Saltare al contenuto principale
CI/CD

Costruzione automatica e rilascio con Gitlab

Crea il tuo proprio pipeline CI/CD con Gitlab gratuitamente, distribuisci il tuo app ogni volta che puoi spingere su main.

Martin Donadieu

Martin Donadieu

Content Marketer

Costruzione automatica e rilascio con Gitlab

Questa guida si concentra sul GitLab CI, ma puoi adattarla con un piccolo aggiustamento per qualsiasi altra piattaforma CI/CD.

Premessa

Assicurati di aver aggiunto la tua app per primo a Capgo, questa guida si concentra solo sulla fase di caricamento.

Convenzione di commit

Prima di tutto, devi iniziare a seguire la convenzione di commit. Commi commessi ` questo ti aiuterà a capire come aggiornare il numero di versione, ci vuole solo 5 minuti per impararlo.

Commi commessi convenzionali

GitLab CI per tag

Poi devi creare il tuo primo GitLab per automatizzare la creazione e la pubblicazione del tag.

Creare 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

Rilascerà un tag per ogni commit nella tua branch principale. E aggiungerà un'entry di 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 PERSONAL ACCESS TOKEN e aggiungilo alle tue variabili GitLab CI/CD come PERSONAL_ACCESS_TOKEN.

Questo è necessario 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, per far capire al tool dove è salvato il tuo versione, devi creare il file .cz.toml al root del tuo repository.

E aggiungi questo dentro :

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

Imposta la versione in questo file come la stessa che hai nel tuo package.json file.

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

Puoi ora commitare questi due file e vedere comparire il tuo primo tag in GitHub!

GitHub azioni per la costruzione

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

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

Se il tuo comando per la costruzione è diverso, puoi cambiarlo nella build_code fase.

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

You potrai ora committare entrambi i file e vedere comparire il tuo primo tag in GitHub!

Aggiungere il commit genererà una nuova build per il canale di produzione.

Devi aggiungere i tuoi test nel passaggio di build per assicurarti che il tuo code funzioni.

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

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

Continua da Automatic build and release with Gitlab

Se stai utilizzando Automatic build and release with Gitlab per pianificare l'automazione del CI/CD, connettilo con Capgo CI/CD per il flusso di lavoro del prodotto in Capgo CI/CD, Capgo Native Builds 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 la dettaglio di implementazione in Integrazione CI/CD, e GitHub Integrazione azioni per la dettaglio di implementazione in GitHub Integrazione azioni

Aggiornamenti in tempo reale per Capacitor app

Quando un bug del layer web è attivo, invia la correzione attraverso Capgo invece di aspettare 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 veramente professionale.