Pular al contenido principal
CI/CD

Automatic Capacitor Android build with GitLab

Cómo configurar una pipeline de CI/CD para tu aplicación de Android Ionic utilizando fastlane y GitLab en 5 minutos

Anik Dhabal Babu

Anik Dhabal Babu

Gerente de contenido

Automatic Capacitor Android build with GitLab

Construcción automática de Android con GitLab CI

Configurar CI/CD para aplicaciones Capacitor puede ser complejo y tiempo consumidor. Aquí está lo que necesitas saber:

Requisitos previos

Antes de empezar, necesitarás configurar:

  • Una cuenta de GitLab con acceso administrativo
  • Tu aplicación ya publicada en Google Play Store con firmado correctamente
  • Clave de firma de Android y archivos de keystore
  • Proyecto de Google Cloud Console con Play Store API habilitado
  • Cuenta de servicio con permisos adecuados
  • Conocimiento de flujos de trabajo de GitLab CI/CD
  • Conocimiento de la configuración de Fastlane
  • Tiempo para mantener y depurar la pipeline

Capgo Construye para CI/CD mediante Capgo

Saltarse la mantenimiento de Fastlane, Gradle runner, keystore y upload-script. Capgo Construye ejecuta compilaciones nativas firmadas de Android desde tu pipeline de CI/CD existente:

  • Funciona con tu pipeline: Desencadena Capgo Construye desde GitLab CI, GitHub Actions, Jenkins o scripts locales después de tu compilación web y npx cap sync.
  • La firma desde secretos de CI: Mantenga los keystore de Android, alias de clave, contraseñas y servicio de cuenta de Play Console en tus propios secretos de CI.
  • No mantenimiento de ejecutor nativo: Capgo Construye proporciona entornos de compilación de Android mantenidos, por lo que no tienes que gestionar SDK imágenes, problemas de caché de Gradle o rutas de Fastlane.
  • Artículos y presentación: Descargue artículos firmados para QA o presente compilaciones de lanzamiento a través de Capgo CLI.

Precio

  • Capgo planes comienzan a $12/mes
  • Incluye actualizaciones OTA y aproximadamente 15 compilaciones nativas por mes
  • Los minutos de compilación adicionales se facturan por minuto a través de créditos

Configura Capgo Build en CI/CD

Guía de configuración manual

Esto es lo que debes hacer:

Pasos a seguir en el post

  1. Copia archivos de Fastlane
  2. Almacenar tus secretos en GitLab secretos cifrados
  3. Crear y almacenar tu clave de servicio de Google Play
  4. Almacenar tu clave de firma de Android
  5. Configura tu archivo .yml de flujo de trabajo de GitLab.

1. Copia los archivos de Fastlane.

Fastlane es una biblioteca de Ruby creada para automatizar tareas de desarrollo móvil comunes. Al utilizar Fastlane, puedes configurar

lanes

default_platform(:android)

KEYSTORE_KEY_ALIAS = ENV["KEYSTORE_KEY_ALIAS"]
KEYSTORE_KEY_PASSWORD = ENV["KEYSTORE_KEY_PASSWORD"]
KEYSTORE_STORE_PASSWORD = ENV["KEYSTORE_STORE_PASSWORD"]

platform :android do
    desc "Deploy a beta version to the Google Play"
    private_lane :verify_changelog_exists do |version_code: |
      changelog_path = "android/metadata/en-US/changelogs/#{version_code}.txt"
      UI.user_error!("Missing changelog file at #{changelog_path}") unless File.exist?(changelog_path)
      UI.message("Changelog exists for version code #{version_code}")
    end

    private_lane :verify_upload_to_staging do |version_name: |
      UI.message "Skipping staging verification step"
    end
    lane :beta do
				keystore_path = "#{Dir.tmpdir}/build_keystore.keystore"
				File.write(keystore_path, Base64.decode64(ENV['ANDROID_KEYSTORE_FILE']))
				json_key_data = Base64.decode64(ENV['PLAY_CONFIG_JSON'])
				previous_build_number = google_play_track_version_codes(
					package_name: ENV['DEVELOPER_PACKAGE_NAME'],
					track: "internal",
					json_key_data: json_key_data,
				)[0]

				current_build_number = previous_build_number + 1
				sh("export NEW_BUILD_NUMBER=#{current_build_number}")
        gradle(
          task: "clean bundleRelease",
          project_dir: 'android/',
          print_command: false,
          properties: {
            "android.injected.signing.store.file" => "#{keystore_path}",
            "android.injected.signing.store.password" => "#{KEYSTORE_STORE_PASSWORD}",
            "android.injected.signing.key.alias" => "#{KEYSTORE_KEY_ALIAS}",
            "android.injected.signing.key.password" => "#{KEYSTORE_KEY_PASSWORD}",
						'versionCode' => current_build_number
          })
        upload_to_play_store(
					package_name: ENV['DEVELOPER_PACKAGE_NAME'],
					json_key_data: json_key_data,
          track: 'internal',
          release_status: 'completed',
          skip_upload_metadata: true,
          skip_upload_changelogs: true,
          skip_upload_images: true,
          skip_upload_screenshots: true,
        )
    end
    lane :build do
      gradle(
        task: "clean bundleRelease",
        project_dir: 'android/',
        print_command: false,
        properties: {
          "android.injected.signing.store.file" => "#{keystore_path}",
          "android.injected.signing.store.password" => "#{KEYSTORE_STORE_PASSWORD}",
          "android.injected.signing.key.alias" => "#{KEYSTORE_KEY_ALIAS}",
          "android.injected.signing.key.password" => "#{KEYSTORE_KEY_PASSWORD}",
        })
    end
    lane :prod_release do
      build_gradle = File.read("../android/app/build.gradle")

      verify_changelog_exists(version_code: build_gradle.match(/versionCode (\d+)/)[1])
      verify_upload_to_staging(version_name: build_gradle.match(/versionName '([\d\.]+)'/)[1])

      supply(
        track_promote_to: 'beta',
        skip_upload_apk: true,
        skip_upload_aab: true,
        skip_upload_metadata: false,
        skip_upload_changelogs: false,
        skip_upload_images: false,
        skip_upload_screenshots: false
      )
    end
end

personalizados que agrupan una serie de

GitLab provides a way to store encrypted CI/CD variables, similar to GitHub’s repository secrets. To store your sensitive information securely.

  1. que realizan tareas que normalmente realizarías utilizando Android Studio. Puedes hacer mucho con Fastlane, pero para los fines de este tutorial, utilizaremos solo una pequeña cantidad de acciones básicas.
  2. Crea un carpeta de Fastlane en la raíz de tu proyecto y copia los siguientes archivos: Fastlane
  3. Almacenar tus secretos en variables de CI/CD de GitLab.
  • GitLab proporciona una forma de almacenar variables de CI/CD cifradas, similar a los secretos de repositorio de __CAPGO_KEEP_0__. .jks Ve a la configuración de tu proyecto de GitLab. .keystore Navega a CI/CD > Variables > Agregar variable: ANDROID_KEYSTORE_FILE: el archivo base64 codificado utilizado para firmar tus builds de Android. Este será el archivo del keystore asociado con tu clave de carga (si estás utilizando Play App Signing), o tu clave de firma de la aplicación.
  • CONTRASEÑA_DE_LA_CAJA_DE_LLAVES: la contraseña asociada con el archivo de la caja de llaves
  • ALIAS_DE_LA_CAJA_DE_LLAVES: el alias de la caja de llaves
  • CONTRASEÑA_DE_LA_CAJA_DE_LLAVES: la contraseña de la llave privada
  • NOMBRE_DE_PAQUETE_DEL_DESARROLLADOR: su ID de aplicación Android como com.example.app
  • CONFIGURACIÓN_DE_JUEGO_DE_PLAY_JSON: la clave JSON de servicio de cuenta base64 codificada.

Crear una clave de servicio de Google Play

Para generar el PLAY_CONFIG_JSON segreto, siga estos pasos:

  1. Ir a la Consola de Cloud de Google
  2. Crear un nuevo proyecto o seleccionar uno existente
  3. Habilitar el Google Play Android Developer API
  4. Crear una cuenta de servicio:
    • Vaya a “IAM & Admin” > “Cuentas de servicio”
    • Haga clic en “Crear Cuenta de Servicio”
    • Déle un nombre y una descripción
    • Haga clic en “Crear y Continuar”
    • Saltar la asignación de roles y haga clic en “Hecho”
  5. Generar una clave JSON:
    • Encuentre su cuenta de servicio en la lista
    • Haga clic en el menú de tres puntos > “Administrar claves”
    • Haga clic en “Agregar Clave” > “Crear nueva clave”
    • Elige el formato JSON
    • Haga clic en “Crear”
  6. Otorgue acceso al servicio al usuario de su aplicación en el Console de Play:
    • Vaya a Console de Play
    • Navegue a “Usuarios y permisos”
    • Haga clic en “Invitar a nuevos usuarios”
    • Ingrese el correo electrónico del servicio de cuenta (que termina con @*.iam.gserviceaccount.com)
    • Otorgue la permiso “Lanzar a producción”
    • Haga clic en “Invitar a usuario”
  7. Convierta la clave JSON a base64:
    base64 -i path/to/your/service-account-key.json | pbcopy
  8. Agregue la cadena base64 codificada como la PLAY_CONFIG_JSON variable en GitLab

Configuración de la Pipeline de CI/CD de GitLab

Crear un archivo .gitlab-ci.yml en la raíz de tu proyecto para definir tu pipeline de CI/CD. A continuación, se muestra un ejemplo de cómo estructurar tu pipeline:


image: mingc/android-build-box:latest

stages:
  - build
  - upload_to_capgo
  - build_and_upload_android

build:
  stage: build
  tags:
    - saas-linux-xlarge-amd64
  cache:
    - key:
        files:
          - bun.lockb
      paths:
        - .node_modules/
  script:
    - npm install
    - npm run build
  artifacts:
    paths:
      - node_modules/
      - dist/
  only:
    - master

upload_to_capgo:
  stage: upload_to_capgo
  tags:
    - saas-linux-xlarge-amd64
  script:
    - npx @capgo/cli@latest bundle upload -a $CAPGO_TOKEN -c dev
  dependencies:
    - build
  when: manual
  only:
    - master

build_and_upload_android:
  tags:
    - saas-linux-xlarge-amd64
  stage:    build_and_upload_android
  cache:
    - key:
        files:
          - android/gradle/wrapper/gradle-wrapper.properties
      paths:
        - ~/.gradle/caches/
  script:
    - npx cap sync android
    - npx cap copy android
    - bundle exec fastlane android beta # We do create a tag for the build to trigger XCode cloud builds
  dependencies:
    - build
  when: manual
  only:
    - master

Activar la Pipeline

Cuando subas una nueva etiqueta a tu repositorio de GitLab, GitLab CI/CD activará automáticamente la pipeline definida, que construirá y desplegará tu aplicación Android utilizando Fastlane.

Asegúrate de ajustar los caminos y dependencias según la estructura y requisitos de tu proyecto. Esta configuración te ayudará a automatizar el despliegue de tu aplicación Android en GitLab CI/CD.

Conclusión

Al configurar GitLab CI/CD con la imagen de Docker mingc/android-build-box, puedes automatizar el proceso de compilación de la aplicación Android, lo que hará que tu flujo de trabajo de desarrollo sea más eficiente y confiable. Esta automatización te permite liberar tiempo para enfocarte en los aspectos clave del desarrollo de aplicaciones, lo que te ayuda a entregar aplicaciones Android de alta calidad de manera más eficiente.

Keep going from Automatic Capacitor Android build with GitLab

Si estás utilizando Automatic Capacitor Android build with 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 Construcciones Nativas para el flujo de trabajo del producto en Capgo Construcciones Nativas, 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 aplicaciones Capacitor

Cuando haya un error en la capa web, envíe 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 obtienen la actualización en segundo plano mientras los cambios nativos siguen en el camino de revisión normal.

Iniciar Ahora

Últimas noticias de nuestro Blog

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