Pasar al contenido principal
CI/CD

Creación automática y lanzamiento con Gitlab

Crea tu propio pipeline de CI/CD con Gitlab de forma gratuita, despliega tu aplicación cada vez que pulses en main.

Martin Donadieu

Martin Donadieu

Gerente de contenido

Creación automática y lanzamiento con Gitlab

This tutorial focuses on the GitLab CI, but you can adapt it with a little tweak to any other CI/CD platform.

Introducción

Asegúrese de que agregó su aplicación primero a Capgo, este tutorial solo se centra en la fase de carga

Convenio de commit

Primero, necesita empezar a seguir el convenio de commit comits convencionales` esto ayudará a las herramientas a entender cómo actualizar el número de versión, solo lleva 5 minutos aprenderlo.

Comits convencionales

CI de GitLab para etiquetas

Luego necesita crear su primer CI de GitLab para que automatice la creación de etiquetas.

Crear un archivo en este path: .github/workflows/bump_version.yml

con este contenido:

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

Esto liberará una etiqueta para cada commit en tu rama principal. Y agregará una entrada de cambios para cada commit en la rama principal en CHANGELOG.md.

No te preocupes si no tienes este archivo, se creará para ti.

Para que esto funcione, crea un __CAPGO_KEEP_0__ y agrega a tus variables de CI de GitLab como PERSONAL_ACCESS_TOKEN.

Esto es necesario para permitir que la CI cometa los cambios de versión.

Cuando crees el token, elige expiración como never y el alcance como repo.

Por último, para que la herramienta entienda dónde se guarda tu versión, debes crear el archivo .cz.toml en la raíz de tu repositorio.

Y agrega esto dentro:

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

Establece la versión en este archivo como la misma que tienes en tu package.json archivo.

Esto solo es necesario la primera vez, luego las herramientas lo mantendrán actualizado.

Puedes ahora cometer estos dos archivos y ver tu primera etiqueta aparecer en GitHub!

GitHub acciones para la compilación

Crea un archivo en este camino: .github/workflows/build.yml

con este contenido:

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

Esto instalará y compilará tu dependencia antes de enviarla a Capgo.

Si tu comando para la compilación es diferente, puedes cambiarlo en el build_code paso.

Para que esto funcione, necesitas obtener tu API clave para Capgo, agregarla en el secreto de tu repositorio de GitHub como CAPGO_TOKEN.

Puedes ahora cometer estos dos archivos y ver tu primera etiqueta aparecer en GitHub!

Agregar el commit generará una nueva compilación para el canal de producción.

Deberías agregar tus pruebas en el paso de compilación para asegurarte de que tu code está funcionando.

Ve a tu panel de control de Capgo y verifica tu compilación que acaba de aparecer, ahora tienes tu sistema CI/CD.

Si deseas que todos tus usuarios obtengan la actualización siempre que esté disponible, ve a tu canal y establece a public.

Sigue adelante con la compilación y lanzamiento automático con Gitlab

Si estás utilizando Compilación y lanzamiento automático con Gitlab para planificar la automatización de CI/CD, conecta con Capgo CI/CD para el flujo de trabajo del producto en Capgo CI/CD, Capgo Compilaciones Nativas para el flujo de trabajo del producto en Capgo Construcción Nativa, Capgo Integraciones para el flujo de trabajo del producto en Capgo Integraciones, Integración CI/CD para el detalle de implementación en Integración CI/CD, y GitHub Integración de Acciones para el detalle de implementación en GitHub Integración de Acciones.

Actualizaciones en vivo para Capacitor aplicaciones

Cuando un bug en la capa web está vivo, envía la corrección a través de Capgo en lugar de esperar días para la aprobación de la tienda de aplicaciones. Los usuarios reciben la actualización en segundo plano mientras los cambios nativos siguen en el camino de revisión normal.

Comienza ahora

Últimas noticias de nuestro Blog

Capgo te da las mejores pistas que necesitas para crear una aplicación móvil verdaderamente profesional.