Questa guida si concentra sul GitLab CI, ma puoi adattarla con un piccolo aggiustamento a qualsiasi altra piattaforma CI/CD.
Prefazione
Assicurati di aver aggiunto la tua app per primo a Capgo, questa guida si concentra solo sulla fase di caricamento.
Convenzione di commit
In primo luogo, devi iniziare a seguire la convenzione di commit Comuni commit` questo ti aiuterà a capire come il tooling deve gestire l'aggiornamento del numero di versione, ci vuole solo 5 minuti per impararlo.

GitLab CI per tag
Poi devi creare il tuo primo GitLab 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
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 TOKEN DI ACCESSO PERSONALE e aggiungilo alle tue variabili GitLab CI/CD come PERSONAL_ACCESS_TOKEN.
Ciò è necessario per consentire al CI di commitare il changelog.
Quando crei il token, scegli l'expiration come never e lo scope come repo.
Infine, per far capire allo strumento 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 come CAPGO_TOKEN.
Puoi ora commitare entrambi i file e vedere comparire il tuo primo tag in GitHub!
Aggiungere il 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 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 è 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 il dettaglio di implementazione in Integrazione CI/CD, e GitHub Integrazione azioni per il dettaglio di implementazione in GitHub Integrazione azioni.